/******************************************************************************
*
* Copyright (C) 2010-2013 Broadcom Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
******************************************************************************/
/******************************************************************************
*
* This file contains the LLCP API definitions
*
******************************************************************************/
#ifndef LLCP_API_H
#define LLCP_API_H
#include "nfc_target.h"
#include "llcp_defs.h"
/*****************************************************************************
** Constants
*****************************************************************************/
#define LLCP_STATUS_SUCCESS 0 /* Successfully done */
#define LLCP_STATUS_FAIL 1 /* Failed without specific reason */
#define LLCP_STATUS_CONGESTED 2 /* Data link is congested */
typedef UINT8 tLLCP_STATUS;
#define LLCP_MIN_OFFSET (NCI_MSG_OFFSET_SIZE + NCI_DATA_HDR_SIZE + LLCP_PDU_HEADER_SIZE + LLCP_SEQUENCE_SIZE)
#define LLCP_INVALID_SAP 0xFF /* indication of failure to allocate data link resource */
/*****************************************************************************
** Type Definitions
*****************************************************************************/
typedef struct
{
BOOLEAN is_initiator; /* TRUE if we are POLL mode */
UINT8 max_payload_size; /* 64, 128, 192 or 254 */
UINT8 waiting_time;
UINT8 *p_gen_bytes;
UINT8 gen_bytes_len;
} tLLCP_ACTIVATE_CONFIG;
typedef struct
{
UINT16 miu; /* Local receiving MIU */
UINT8 rw; /* Local receiving window */
char sn[LLCP_MAX_SN_LEN + 1]; /* Service name to connect */
} tLLCP_CONNECTION_PARAMS;
/*********************************
** Callback Functions Prototypes
**********************************/
/* Link Management Callback Events */
#define LLCP_LINK_ACTIVATION_FAILED_EVT 0x00 /* Fail to activate link */
#define LLCP_LINK_ACTIVATION_COMPLETE_EVT 0x01 /* LLCP Link is activated */
#define LLCP_LINK_DEACTIVATED_EVT 0x02 /* LLCP Link is deactivated */
#define LLCP_LINK_FIRST_PACKET_RECEIVED_EVT 0x03 /* First LLCP packet received from remote */
/* Link Management Callback Reasons */
#define LLCP_LINK_SUCCESS 0x00 /* Success */
#define LLCP_LINK_VERSION_FAILED 0x01 /* Failed to agree version */
#define LLCP_LINK_BAD_GEN_BYTES 0x02 /* Failed to parse received general bytes */
#define LLCP_LINK_INTERNAL_ERROR 0x03 /* internal error */
#define LLCP_LINK_LOCAL_INITIATED 0x04 /* Link has been deactivated by local */
#define LLCP_LINK_REMOTE_INITIATED 0x05 /* Link has been deactivated by remote */
#define LLCP_LINK_TIMEOUT 0x06 /* Link has been deactivated by timeout */
#define LLCP_LINK_FRAME_ERROR 0x07 /* Link has been deactivated by frame error */
#define LLCP_LINK_RF_LINK_LOSS_NO_RX_LLC 0x08 /* RF link loss without any rx LLC PDU */
#define LLCP_LINK_RF_TRANSMISSION_ERR NFC_STATUS_RF_TRANSMISSION_ERR
#define LLCP_LINK_RF_PROTOCOL_ERR NFC_STATUS_RF_PROTOCOL_ERR
#define LLCP_LINK_RF_TIMEOUT NFC_STATUS_TIMEOUT
#define LLCP_LINK_RF_LINK_LOSS_ERR NFC_STATUS_LINK_LOSS
typedef void (tLLCP_LINK_CBACK) (UINT8 event, UINT8 reason);
/* Minimum length of Gen Bytes for LLCP */
/* In CE4 low power mode, NFCC can store up to 21 bytes */
#define LLCP_MIN_GEN_BYTES 20
/* Service Access Point (SAP) Callback Events */
#define LLCP_SAP_EVT_DATA_IND 0x00 /* Received data on SAP */
#define LLCP_SAP_EVT_CONNECT_IND 0x01 /* Connection request from peer */
#define LLCP_SAP_EVT_CONNECT_RESP 0x02 /* Connection accepted by peer */
#define LLCP_SAP_EVT_DISCONNECT_IND 0x03 /* Received disconnect request */
#define LLCP_SAP_EVT_DISCONNECT_RESP 0x04 /* Received disconnect response */
#define LLCP_SAP_EVT_CONGEST 0x05 /* congested status is changed */
#define LLCP_SAP_EVT_LINK_STATUS 0x06 /* Change of LLCP Link status */
#define LLCP_SAP_EVT_TX_COMPLETE 0x07 /* tx queue is empty and all PDU is acked */
#define LLCP_LINK_TYPE_LOGICAL_DATA_LINK 0x01
#define LLCP_LINK_TYPE_DATA_LINK_CONNECTION 0x02
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_DATA_IND */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
UINT8 link_type; /* link type */
} tLLCP_SAP_DATA_IND;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_CONNECT_IND */
UINT8 server_sap; /* SAP of local server */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
UINT16 miu; /* MIU of peer device */
UINT8 rw; /* RW of peer device */
char *p_service_name; /* Service name (only for SDP) */
} tLLCP_SAP_CONNECT_IND;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_CONNECT_RESP */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
UINT16 miu; /* MIU of peer device */
UINT8 rw; /* RW of peer device */
} tLLCP_SAP_CONNECT_RESP;
#define LLCP_SAP_DISCONNECT_REASON_TIMEOUT 0x80
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_DISCONNECT_IND */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
} tLLCP_SAP_DISCONNECT_IND;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_DISCONNECT_RESP */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
UINT8 reason; /* Reason of DM PDU if not timeout */
} tLLCP_SAP_DISCONNECT_RESP;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_CONGEST */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
BOOLEAN is_congested; /* TRUE if congested */
UINT8 link_type; /* congested link type */
} tLLCP_SAP_CONGEST;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_LINK_STATUS */
UINT8 local_sap; /* SAP of local device */
BOOLEAN is_activated; /* TRUE if LLCP link is activated */
BOOLEAN is_initiator; /* TRUE if local LLCP is initiator */
} tLLCP_SAP_LINK_STATUS;
typedef struct
{
UINT8 event; /* LLCP_SAP_EVT_TX_COMPLETE */
UINT8 local_sap; /* SAP of local device */
UINT8 remote_sap; /* SAP of remote device */
} tLLCP_SAP_TX_COMPLETE;
typedef struct
{
UINT8 event; /* event */
UINT8 local_sap; /* SAP of local device */
} tLLCP_SAP_HEADER;
typedef union
{
tLLCP_SAP_HEADER hdr; /* common header */
tLLCP_SAP_DATA_IND data_ind; /* LLCP_SAP_EVT_DATA_IND */
tLLCP_SAP_CONNECT_IND connect_ind; /* LLCP_SAP_EVT_CONNECT_IND */
tLLCP_SAP_CONNECT_RESP connect_resp; /* LLCP_SAP_EVT_CONNECT_RESP */
tLLCP_SAP_DISCONNECT_IND disconnect_ind; /* LLCP_SAP_EVT_DISCONNECT_IND */
tLLCP_SAP_DISCONNECT_RESP disconnect_resp; /* LLCP_SAP_EVT_DISCONNECT_RESP */
tLLCP_SAP_CONGEST congest; /* LLCP_SAP_EVT_CONGEST */
tLLCP_SAP_LINK_STATUS link_status; /* LLCP_SAP_EVT_LINK_STATUS */
tLLCP_SAP_TX_COMPLETE tx_complete; /* LLCP_SAP_EVT_TX_COMPLETE */
} tLLCP_SAP_CBACK_DATA;
typedef void (tLLCP_APP_CBACK) (tLLCP_SAP_CBACK_DATA *p_data);
/* Service Discovery Callback */
typedef void (tLLCP_SDP_CBACK) (UINT8 tid, UINT8 remote_sap);
/* LLCP DTA Callback - notify DTA responded SNL for connectionless echo service */
typedef void (tLLCP_DTA_CBACK) (void);
/*****************************************************************************
** External Function Declarations
*****************************************************************************/
#ifdef __cplusplus
extern "C"
{
#endif
/*******************************************************************************
**
** Function LLCP_SetConfig
**
** Description Set configuration parameters for LLCP
** - Local Link MIU
** - Option parameter
** - Waiting Time Index
** - Local Link Timeout
** - Inactivity Timeout as initiator role
** - Inactivity Timeout as target role
** - Delay SYMM response
** - Data link connection timeout
** - Delay timeout to send first PDU as initiator
**
** Returns void
**
*******************************************************************************/
LLCP_API extern void LLCP_SetConfig (UINT16 link_miu,
UINT8 opt,
UINT8 wt,
UINT16 link_timeout,
UINT16 inact_timeout_init,
UINT16 inact_timeout_target,
UINT16 symm_delay,
UINT16 data_link_timeout,
UINT16 delay_first_pdu_timeout);
/*******************************************************************************
**
** Function LLCP_GetConfig
**
** Description Get configuration parameters for LLCP
** - Local Link MIU
** - Option parameter
** - Response Waiting Time Index
** - Local Link Timeout
** - Inactivity Timeout as initiator role
** - Inactivity Timeout as target role
** - Delay SYMM response
** - Data link connection timeout
** - Delay timeout to send first PDU as initiator
**
** Returns void
**
*******************************************************************************/
LLCP_API extern void LLCP_GetConfig (UINT16 *p_link_miu,
UINT8 *p_opt,
UINT8 *p_wt,
UINT16 *p_link_timeout,
UINT16 *p_inact_timeout_init,
UINT16 *p_inact_timeout_target,
UINT16 *p_symm_delay,
UINT16 *p_data_link_timeout,
UINT16 *p_delay_first_pdu_timeout);
/*******************************************************************************
**
** Function LLCP_GetDiscoveryConfig
**
** Description Returns discovery config for LLCP MAC link activation
** This function is called to get general bytes for NFC_PMID_ATR_REQ_GEN_BYTES
** or NFC_PMID_ATR_RES_GEN_BYTES before starting discovery.
**
** wt:Waiting time 0 - 8, only for listen
** p_gen_bytes: pointer to store LLCP magic number and paramters
** p_gen_bytes_len: length of buffer for gen bytes as input
** (NOTE:it must be bigger than LLCP_MIN_GEN_BYTES)
** actual gen bytes size as output
**
** Restrictions on the use of ISO 18092
** 1. The DID features shall not be used.
** 2. the NAD features shall not be used.
** 3. Frame waiting time extentions (WTX) shall not be used.
**
** Returns None
**
*******************************************************************************/
LLCP_API extern void LLCP_GetDiscoveryConfig (UINT8 *p_wt,
UINT8 *p_gen_bytes,
UINT8 *p_gen_bytes_len);
/*******************************************************************************
**
** Function LLCP_ActivateLink
**
** Description This function will activate LLCP link with LR, WT and Gen Bytes
** in activation NTF from NFCC.
**
** LLCP_LINK_ACTIVATION_COMPLETE_EVT will be returned through
** callback function if successful.
** Otherwise, LLCP_LINK_ACTIVATION_FAILED_EVT will be returned.
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_ActivateLink (tLLCP_ACTIVATE_CONFIG config,
tLLCP_LINK_CBACK *p_link_cback);
/*******************************************************************************
**
** Function LLCP_DeactivateLink
**
** Description Deactivate LLCP link
**
** LLCP_LINK_DEACTIVATED_EVT will be returned through callback
** when LLCP link is deactivated. Then NFC link may be deactivated.
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_DeactivateLink (void);
/*******************************************************************************
**
** Function LLCP_RegisterServer
**
** Description Register server and callback function
**
** reg_sap : Well-Known SAP except LM and SDP (0x02 - 0x0F)
** Advertized by SDP (0x10 - 0x1F)
** LLCP_INVALID_SAP, LLCP will allocate between 0x10 and 0x1F
** link_type : LLCP_LINK_TYPE_LOGICAL_DATA_LINK
** and/or LLCP_LINK_TYPE_DATA_LINK_CONNECTION
** p_service_name : Null-terminated string up to LLCP_MAX_SN_LEN
**
** Returns SAP between 0x02 and 0x1F, if success
** LLCP_INVALID_SAP, otherwise
**
*******************************************************************************/
LLCP_API extern UINT8 LLCP_RegisterServer (UINT8 reg_sap,
UINT8 link_type,
char *p_service_name,
tLLCP_APP_CBACK *p_sap_cback);
/*******************************************************************************
**
** Function LLCP_RegisterClient
**
** Description Register client and callback function
**
** link_type : LLCP_LINK_TYPE_LOGICAL_DATA_LINK
** and/or LLCP_LINK_TYPE_DATA_LINK_CONNECTION
**
** Returns SAP between 0x20 and 0x3F, if success
** LLCP_INVALID_SAP, otherwise
**
*******************************************************************************/
LLCP_API extern UINT8 LLCP_RegisterClient (UINT8 link_type,
tLLCP_APP_CBACK *p_sap_cback);
/*******************************************************************************
**
** Function LLCP_Deregister
**
** Description Deregister server or client
**
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_Deregister (UINT8 sap);
/*******************************************************************************
**
** Function LLCP_IsLogicalLinkCongested
**
** Description Check if logical link is congested
**
**
** Returns TRUE if congested
**
*******************************************************************************/
LLCP_API extern BOOLEAN LLCP_IsLogicalLinkCongested (UINT8 local_sap,
UINT8 num_pending_ui_pdu,
UINT8 total_pending_ui_pdu,
UINT8 total_pending_i_pdu);
/*******************************************************************************
**
** Function LLCP_SendUI
**
** Description Send connnectionless data to DSAP
**
**
** Returns LLCP_STATUS_SUCCESS if success
** LLCP_STATUS_CONGESTED if logical link is congested
** LLCP_STATUS_FAIL, otherwise
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_SendUI (UINT8 ssap, UINT8 dsap, BT_HDR *p_buf);
/*******************************************************************************
**
** Function LLCP_ReadLogicalLinkData
**
** Description Read information of UI PDU for local SAP
**
** - Remote SAP who sent UI PDU is returned.
** - Information of UI PDU up to max_data_len is copied into p_data.
** - Information of next UI PDU is not concatenated.
** - Recommended max_data_len is link MIU of local device
**
** Returns TRUE if more information of UI PDU or more UI PDU in queue
**
*******************************************************************************/
LLCP_API extern BOOLEAN LLCP_ReadLogicalLinkData (UINT8 local_sap,
UINT32 max_data_len,
UINT8 *p_remote_sap,
UINT32 *p_data_len,
UINT8 *p_data);
/*******************************************************************************
**
** Function LLCP_FlushLogicalLinkRxData
**
** Description Discard received data in logical data link of local SAP
**
**
** Returns length of data flushed
**
*******************************************************************************/
LLCP_API extern UINT32 LLCP_FlushLogicalLinkRxData (UINT8 local_sap);
/*******************************************************************************
**
** Function LLCP_ConnectReq
**
** Description Create data link connection between registered SAP and DSAP
** in peer LLCP,
**
**
** Returns LLCP_STATUS_SUCCESS if success
** LLCP_STATUS_FAIL, otherwise
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_ConnectReq (UINT8 reg_sap, UINT8 dsap,
tLLCP_CONNECTION_PARAMS *p_params);
/*******************************************************************************
**
** Function LLCP_ConnectCfm
**
** Description Accept connection request from peer LLCP
**
**
** Returns LLCP_STATUS_SUCCESS if success
** LLCP_STATUS_FAIL, otherwise
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_ConnectCfm (UINT8 local_sap,
UINT8 remote_sap,
tLLCP_CONNECTION_PARAMS *p_params);
/*******************************************************************************
**
** Function LLCP_ConnectReject
**
** Description Reject connection request from peer LLCP
**
** reason : LLCP_SAP_DM_REASON_APP_REJECTED
** LLCP_SAP_DM_REASON_PERM_REJECT_THIS
** LLCP_SAP_DM_REASON_PERM_REJECT_ANY
** LLCP_SAP_DM_REASON_TEMP_REJECT_THIS
** LLCP_SAP_DM_REASON_TEMP_REJECT_ANY
**
** Returns LLCP_STATUS_SUCCESS if success
** LLCP_STATUS_FAIL, otherwise
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_ConnectReject (UINT8 local_sap,
UINT8 remote_sap,
UINT8 reason);
/*******************************************************************************
**
** Function LLCP_IsDataLinkCongested
**
** Description Check if data link is congested
**
**
** Returns TRUE if congested
**
*******************************************************************************/
LLCP_API extern BOOLEAN LLCP_IsDataLinkCongested (UINT8 local_sap,
UINT8 remote_sap,
UINT8 num_pending_i_pdu,
UINT8 total_pending_ui_pdu,
UINT8 total_pending_i_pdu);
/*******************************************************************************
**
** Function LLCP_SendData
**
** Description Send connection-oriented data
**
**
** Returns LLCP_STATUS_SUCCESS if success
** LLCP_STATUS_CONGESTED if data link is congested
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_SendData (UINT8 local_sap,
UINT8 remote_sap,
BT_HDR *p_buf);
/*******************************************************************************
**
** Function LLCP_ReadDataLinkData
**
** Description Read information of I PDU for data link connection
**
** - Information of I PDU up to max_data_len is copied into p_data.
** - Information of next I PDU is not concatenated.
** - Recommended max_data_len is data link connection MIU of local
** end point
**
** Returns TRUE if more data in queue
**
*******************************************************************************/
LLCP_API extern BOOLEAN LLCP_ReadDataLinkData (UINT8 local_sap,
UINT8 remote_sap,
UINT32 max_data_len,
UINT32 *p_data_len,
UINT8 *p_data);
/*******************************************************************************
**
** Function LLCP_FlushDataLinkRxData
**
** Description Discard received data in data link connection
**
**
** Returns length of rx data flushed
**
*******************************************************************************/
LLCP_API extern UINT32 LLCP_FlushDataLinkRxData (UINT8 local_sap,
UINT8 remote_sap);
/*******************************************************************************
**
** Function LLCP_DisconnectReq
**
** Description Disconnect data link
** discard any pending data if flush is set to TRUE
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_DisconnectReq (UINT8 local_sap,
UINT8 remote_sap,
BOOLEAN flush);
/*******************************************************************************
**
** Function LLCP_SetTxCompleteNtf
**
** Description This function is called to get LLCP_SAP_EVT_TX_COMPLETE
** when Tx queue is empty and all PDU is acked.
** This is one time event, so upper layer shall call this function
** again to get next LLCP_SAP_EVT_TX_COMPLETE.
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_SetTxCompleteNtf (UINT8 local_sap,
UINT8 remote_sap);
/*******************************************************************************
**
** Function LLCP_SetLocalBusyStatus
**
** Description Set local busy status
**
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_SetLocalBusyStatus (UINT8 local_sap,
UINT8 remote_sap,
BOOLEAN is_busy);
/*******************************************************************************
**
** Function LLCP_GetRemoteWKS
**
** Description Return well-known service bitmap of connected device
**
**
** Returns WKS bitmap if success
**
*******************************************************************************/
LLCP_API extern UINT16 LLCP_GetRemoteWKS (void);
/*******************************************************************************
**
** Function LLCP_GetRemoteLSC
**
** Description Return link service class of connected device
**
**
** Returns link service class
**
*******************************************************************************/
LLCP_API extern UINT8 LLCP_GetRemoteLSC (void);
/*******************************************************************************
**
** Function LLCP_GetLinkMIU
**
** Description Return local and remote link MIU
**
**
** Returns None
**
*******************************************************************************/
LLCP_API extern void LLCP_GetLinkMIU (UINT16 *p_local_link_miu, UINT16 *p_remote_link_miu);
/*******************************************************************************
**
** Function LLCP_DiscoverService
**
** Description Return SAP of service name in connected device through callback
**
**
** Returns LLCP_STATUS_SUCCESS if success
**
*******************************************************************************/
LLCP_API extern tLLCP_STATUS LLCP_DiscoverService (char *p_name,
tLLCP_SDP_CBACK *p_cback,
UINT8 *p_tid);
/*******************************************************************************
**
** Function LLCP_SetTraceLevel
**
** Description This function sets the trace level for LLCP. If called with
** a value of 0xFF, it simply returns the current trace level.
**
** Returns The new or current trace level
**
*******************************************************************************/
LLCP_API extern UINT8 LLCP_SetTraceLevel (UINT8 new_level);
/*******************************************************************************
**
** Function LLCP_RegisterDtaCback
**
** Description Register callback function for LLCP DTA testing
**
**
** Returns void
**
*******************************************************************************/
LLCP_API extern void LLCP_RegisterDtaCback (tLLCP_DTA_CBACK *p_dta_cback);
#if (LLCP_TEST_INCLUDED == TRUE)
/*******************************************************************************
**
** Function LLCP_SetTestParams
**
** Description Set test parameters for LLCP
**
**
** Returns void
**
*******************************************************************************/
LLCP_API extern void LLCP_SetTestParams (UINT8 version, UINT16 wks);
#endif
#ifdef __cplusplus
}
#endif
#endif /* LLCP_API_H */