/* * Copyright (C) 2010-2014 NXP Semiconductors * * 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. */ #ifndef _PHNXPNCIHAL_H_ #define _PHNXPNCIHAL_H_ #include <hardware/nfc.h> #include <phNxpNciHal_utils.h> #include "NxpNfcCapability.h" /********************* Definitions and structures *****************************/ #define MAX_RETRY_COUNT 5 #define NCI_MAX_DATA_LEN 300 #define NCI_POLL_DURATION 500 #define HAL_NFC_ENABLE_I2C_FRAGMENTATION_EVT 0x07 #undef P2P_PRIO_LOGIC_HAL_IMP #define NCI_VERSION_2_0 0x20 #define NCI_VERSION_1_1 0x11 #define NCI_VERSION_1_0 0x10 #define NCI_VERSION_UNKNOWN 0x00 typedef void(phNxpNciHal_control_granted_callback_t)(); /*ROM CODE VERSION FW*/ #define FW_MOBILE_ROM_VERSION_PN551 0x10 #define FW_MOBILE_ROM_VERSION_PN553 0x11 #define FW_MOBILE_ROM_VERSION_PN557 0x12 /* NCI Data */ #define NCI_MT_CMD 0x20 #define NCI_MT_RSP 0x40 #define NCI_MT_NTF 0x60 #define CORE_RESET_TRIGGER_TYPE_CORE_RESET_CMD_RECEIVED 0x02 #define CORE_RESET_TRIGGER_TYPE_POWERED_ON 0x01 #define NCI_MSG_CORE_RESET 0x00 #define NCI_MSG_CORE_INIT 0x01 #define NCI_MT_MASK 0xE0 #define NCI_OID_MASK 0x3F #define NXP_MAX_CONFIG_STRING_LEN 260 typedef struct nci_data { uint16_t len; uint8_t p_data[NCI_MAX_DATA_LEN]; } nci_data_t; typedef enum { HAL_STATUS_CLOSE = 0, HAL_STATUS_OPEN, HAL_STATUS_MIN_OPEN } phNxpNci_HalStatus; typedef enum { GPIO_UNKNOWN = 0x00, GPIO_STORE = 0x01, GPIO_STORE_DONE = 0x02, GPIO_RESTORE = 0x10, GPIO_RESTORE_DONE = 0x20, GPIO_CLEAR = 0xFF } phNxpNciHal_GpioInfoState; typedef struct phNxpNciGpioInfo { phNxpNciHal_GpioInfoState state; uint8_t values[2]; } phNxpNciGpioInfo_t; /* Macros to enable and disable extensions */ #define HAL_ENABLE_EXT() (nxpncihal_ctrl.hal_ext_enabled = 1) #define HAL_DISABLE_EXT() (nxpncihal_ctrl.hal_ext_enabled = 0) typedef struct phNxpNciInfo { uint8_t nci_version; bool_t wait_for_ntf; } phNxpNciInfo_t; /* NCI Control structure */ typedef struct phNxpNciHal_Control { phNxpNci_HalStatus halStatus; /* Indicate if hal is open or closed */ pthread_t client_thread; /* Integration thread handle */ uint8_t thread_running; /* Thread running if set to 1, else set to 0 */ phLibNfc_sConfig_t gDrvCfg; /* Driver config data */ /* Rx data */ uint8_t* p_rx_data; uint16_t rx_data_len; /* Rx data */ uint8_t* p_rx_ese_data; uint16_t rx_ese_data_len; /* libnfc-nci callbacks */ nfc_stack_callback_t* p_nfc_stack_cback; nfc_stack_data_callback_t* p_nfc_stack_data_cback; /* control granted callback */ phNxpNciHal_control_granted_callback_t* p_control_granted_cback; /* HAL open status */ bool_t hal_open_status; /* HAL extensions */ uint8_t hal_ext_enabled; /* Waiting semaphore */ phNxpNciHal_Sem_t ext_cb_data; sem_t syncSpiNfc; uint16_t cmd_len; uint8_t p_cmd_data[NCI_MAX_DATA_LEN]; uint16_t rsp_len; uint8_t p_rsp_data[NCI_MAX_DATA_LEN]; /* retry count used to force download */ uint16_t retry_cnt; uint8_t read_retry_cnt; phNxpNciInfo_t nci_info; /* to store and restore gpio values */ phNxpNciGpioInfo_t phNxpNciGpioInfo; bool bIsForceFwDwnld; } phNxpNciHal_Control_t; typedef struct phNxpNciClock { bool_t isClockSet; uint8_t p_rx_data[20]; bool_t issetConfig; } phNxpNciClock_t; typedef struct phNxpNciRfSetting { bool_t isGetRfSetting; uint8_t p_rx_data[20]; } phNxpNciRfSetting_t; typedef struct phNxpNciMwEepromArea { bool_t isGetEepromArea; uint8_t p_rx_data[32]; } phNxpNciMwEepromArea_t; typedef enum { NFC_FORUM_PROFILE, EMV_CO_PROFILE, INVALID_PROFILe } phNxpNciProfile_t; /* NXP Poll Profile control structure */ typedef struct phNxpNciProfile_Control { phNxpNciProfile_t profile_type; uint8_t bClkSrcVal; /* Holds the System clock source read from config file */ uint8_t bClkFreqVal; /* Holds the System clock frequency read from config file */ uint8_t bTimeout; /* Holds the Timeout Value */ } phNxpNciProfile_Control_t; /* Internal messages to handle callbacks */ #define NCI_HAL_OPEN_CPLT_MSG 0x411 #define NCI_HAL_CLOSE_CPLT_MSG 0x412 #define NCI_HAL_POST_INIT_CPLT_MSG 0x413 #define NCI_HAL_PRE_DISCOVER_CPLT_MSG 0x414 #define NCI_HAL_ERROR_MSG 0x415 #define NCI_HAL_HCI_NETWORK_RESET_MSG 0x416 #define NCI_HAL_RX_MSG 0xF01 #define NCIHAL_CMD_CODE_LEN_BYTE_OFFSET (2U) #define NCIHAL_CMD_CODE_BYTE_LEN (3U) /******************** NCI HAL exposed functions *******************************/ int phNxpNciHal_check_ncicmd_write_window(uint16_t cmd_len, uint8_t* p_cmd); void phNxpNciHal_request_control(void); void phNxpNciHal_release_control(void); int phNxpNciHal_write_unlocked(uint16_t data_len, const uint8_t* p_data); /******************************************************************************* ** ** Function phNxpNciHal_configFeatureList ** ** Description Configures the featureList based on chip type ** Returns none *******************************************************************************/ void phNxpNciHal_configFeatureList(uint8_t* init_rsp, uint16_t rsp_len); #endif /* _PHNXPNCIHAL_H_ */