summaryrefslogtreecommitdiffstats
path: root/src/phHciNfc_SWP.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/phHciNfc_SWP.c')
-rw-r--r--src/phHciNfc_SWP.c828
1 files changed, 828 insertions, 0 deletions
diff --git a/src/phHciNfc_SWP.c b/src/phHciNfc_SWP.c
new file mode 100644
index 0000000..88b877c
--- /dev/null
+++ b/src/phHciNfc_SWP.c
@@ -0,0 +1,828 @@
+/*
+ * Copyright (C) 2010 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.
+ */
+
+/*!
+* =========================================================================== *
+* *
+* *
+* \file phHciNfc_SWP.c *
+* \brief HCI SWP gate Management Routines. *
+* *
+* *
+* Project: NFC-FRI-1.1 *
+* *
+* $Date: Tue Aug 18 10:16:36 2009 $ *
+* $Author: ing04880 $ *
+* $Revision: 1.31 $ *
+* $Aliases: NFC_FRI1.1_WK934_R31_1,NFC_FRI1.1_WK941_PREP1,NFC_FRI1.1_WK941_PREP2,NFC_FRI1.1_WK941_1,NFC_FRI1.1_WK943_R32_1,NFC_FRI1.1_WK949_PREP1,NFC_FRI1.1_WK943_R32_10,NFC_FRI1.1_WK943_R32_13,NFC_FRI1.1_WK943_R32_14,NFC_FRI1.1_WK1007_R33_1,NFC_FRI1.1_WK1007_R33_4,NFC_FRI1.1_WK1017_PREP1,NFC_FRI1.1_WK1017_R34_1,NFC_FRI1.1_WK1017_R34_2,NFC_FRI1.1_WK1023_R35_1 $ * *
+* =========================================================================== *
+*/
+
+/*
+***************************** Header File Inclusion ****************************
+*/
+#include <phNfcCompId.h>
+#include <phHciNfc_Pipe.h>
+#include <phHciNfc_SWP.h>
+#include <phOsalNfc.h>
+#include <phHciNfc_Emulation.h>
+#include <phHciNfc_DevMgmt.h>
+/*
+****************************** Macro Definitions *******************************
+*/
+
+/* SWP Gate regsitry Settings */
+/* set default mode mode as virtual mode */
+#define NXP_SWP_DEFAULT_MODE_INDEX (0x01U)
+/* Get the Status of the UICC Connection */
+#define NXP_SWP_STATUS_INDEX (0x02U)
+
+/* Configure the Secure Element Protected Mode */
+#define NXP_SWP_PROTECTED_INDEX (0x03U)
+
+/* Switch mode index */
+#define NXP_EVT_SWP_SWITCH_MODE (0x03U)
+
+/* Protected Event from the Host Controller */
+#define NXP_EVT_SWP_PROTECTED (0x04U)
+
+/****************** Structure and Enumeration ****************************/
+
+/****************** Static Function Declaration **************************/
+
+static
+NFCSTATUS
+phHciNfc_Recv_SWP_Response(
+ void *psContext,
+ void *pHwRef,
+ uint8_t *pResponse,
+#ifdef ONE_BYTE_LEN
+ uint8_t length
+#else
+ uint16_t length
+#endif
+ );
+
+static
+NFCSTATUS
+phHciNfc_Send_SWP_Event(
+ phHciNfc_sContext_t *psHciContext,
+ void *pHwRef,
+ uint8_t pipe_id,
+ uint8_t event
+ );
+
+
+static
+NFCSTATUS
+phHciNfc_Recv_SWP_Event(
+ void *psContext,
+ void *pHwRef,
+ uint8_t *pEvent,
+#ifdef ONE_BYTE_LEN
+ uint8_t length
+#else
+ uint16_t length
+#endif
+ );
+
+static
+NFCSTATUS
+phHciNfc_SWP_InfoUpdate(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t index,
+ uint8_t *reg_value,
+ uint8_t reg_length
+ );
+
+/*
+*************************** Function Definitions ***************************
+*/
+
+NFCSTATUS
+phHciNfc_SWP_Get_PipeID(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t *ppipe_id
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+
+ if( (NULL != psHciContext)
+ && ( NULL != ppipe_id )
+ && ( NULL != psHciContext->p_swp_info )
+ )
+ {
+ phHciNfc_SWP_Info_t *p_swp_info=NULL;
+ p_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+ *ppipe_id = p_swp_info->pipe_id ;
+ }
+ else
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ return status;
+}
+
+NFCSTATUS
+phHciNfc_SWP_Init_Resources(phHciNfc_sContext_t *psHciContext)
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+
+ if( NULL == psHciContext )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else
+ {
+ if(( NULL == psHciContext->p_swp_info ) &&
+ (phHciNfc_Allocate_Resource((void **)(&ps_swp_info),
+ sizeof(phHciNfc_SWP_Info_t))== NFCSTATUS_SUCCESS))
+ {
+ psHciContext->p_swp_info = ps_swp_info;
+ ps_swp_info->current_seq = SWP_INVALID_SEQUENCE;
+ ps_swp_info->next_seq = SWP_INVALID_SEQUENCE;
+ ps_swp_info->pipe_id = (uint8_t)HCI_UNKNOWN_PIPE_ID;
+ }
+ else
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INSUFFICIENT_RESOURCES);
+ }
+
+ }
+ return status;
+}
+
+
+NFCSTATUS
+phHciNfc_SWP_Update_PipeInfo(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t pipeID,
+ phHciNfc_Pipe_Info_t *pPipeInfo
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+
+ if( NULL == psHciContext )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ ps_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+ /* Update the pipe_id of the SWP Gate obtained from HCI Response */
+ ps_swp_info->pipe_id = pipeID;
+ ps_swp_info->p_pipe_info = pPipeInfo;
+ if (NULL != pPipeInfo)
+ {
+ /* Update the Response Receive routine of the SWP Gate */
+ pPipeInfo->recv_resp = &phHciNfc_Recv_SWP_Response;
+ pPipeInfo->recv_event =&phHciNfc_Recv_SWP_Event;
+ }
+ }
+ return status;
+}
+
+
+static
+NFCSTATUS
+phHciNfc_Recv_SWP_Response(
+ void *psContext,
+ void *pHwRef,
+ uint8_t *pResponse,
+#ifdef ONE_BYTE_LEN
+ uint8_t length
+#else
+ uint16_t length
+#endif
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_sContext_t *psHciContext =
+ (phHciNfc_sContext_t *)psContext ;
+
+
+ if( (NULL == psHciContext) || (NULL == pHwRef) || (NULL == pResponse)
+ || (length == 0))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ uint8_t prev_cmd = ANY_GET_PARAMETER;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+ if( NULL == ps_swp_info->p_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ prev_cmd = ps_swp_info->p_pipe_info->prev_msg ;
+ switch(prev_cmd)
+ {
+ case ANY_GET_PARAMETER:
+ {
+ HCI_PRINT(" Getting the SWP Parameter \n");
+ status = phHciNfc_SWP_InfoUpdate(psHciContext,
+ ps_swp_info->p_pipe_info->reg_index,
+ &pResponse[HCP_HEADER_LEN],
+ (uint8_t)(length - HCP_HEADER_LEN));
+
+ break;
+ }
+ case ANY_SET_PARAMETER:
+ {
+ HCI_PRINT("SWP Parameter Set \n");
+ break;
+ }
+ case ANY_OPEN_PIPE:
+ {
+ HCI_PRINT("SWP gate open pipe complete\n");
+ break;
+ }
+ case ANY_CLOSE_PIPE:
+ {
+ HCI_PRINT("SWP close pipe complete\n");
+ break;
+ }
+ default:
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_HCI_RESPONSE);
+ break;
+ }
+ }
+ if( NFCSTATUS_SUCCESS == status )
+ {
+ status = phHciNfc_EmuMgmt_Update_Seq(psHciContext,
+ UPDATE_SEQ);
+ ps_swp_info->p_pipe_info->prev_status = NFCSTATUS_SUCCESS;
+ ps_swp_info->current_seq = ps_swp_info->next_seq;
+ }
+ }
+ }
+ return status;
+}
+
+
+NFCSTATUS
+phHciNfc_SWP_Configure_Default(
+ void *psHciHandle,
+ void *pHwRef,
+ uint8_t enable_type
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ static uint8_t param = 0 ;
+ phHciNfc_sContext_t *psHciContext = ((phHciNfc_sContext_t *)psHciHandle);
+
+ if((NULL == psHciContext)||(NULL == pHwRef))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ phHciNfc_Pipe_Info_t *ps_pipe_info=NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t*)psHciContext->p_swp_info;
+ ps_pipe_info = ps_swp_info->p_pipe_info;
+
+ if(NULL == ps_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ ps_pipe_info->reg_index = NXP_SWP_DEFAULT_MODE_INDEX;
+ /* Enable/Disable SWP link */
+ param = (uint8_t)enable_type;
+ ps_pipe_info->param_info =(void*)&param ;
+ ps_pipe_info->param_length = sizeof(param) ;
+ status = phHciNfc_Send_Generic_Cmd(psHciContext, pHwRef,
+ ps_swp_info->pipe_id,
+ (uint8_t)ANY_SET_PARAMETER);
+ }
+
+ }
+ return status;
+}
+
+
+NFCSTATUS
+phHciNfc_SWP_Get_Status(
+ void *psHciHandle,
+ void *pHwRef
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ /* static uint8_t param = 0 ; */
+ phHciNfc_sContext_t *psHciContext = ((phHciNfc_sContext_t *)psHciHandle);
+
+ if((NULL == psHciContext)||(NULL == pHwRef))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ phHciNfc_Pipe_Info_t *ps_pipe_info=NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t*)psHciContext->p_swp_info;
+ ps_pipe_info = ps_swp_info->p_pipe_info;
+
+ if(NULL == ps_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ ps_pipe_info->reg_index = NXP_SWP_STATUS_INDEX;
+ status = phHciNfc_Send_Generic_Cmd(psHciContext, pHwRef,
+ ps_swp_info->pipe_id,
+ (uint8_t)ANY_GET_PARAMETER);
+ }
+ }
+ return status;
+}
+
+
+NFCSTATUS
+phHciNfc_SWP_Get_Bitrate(
+ void *psHciHandle,
+ void *pHwRef
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_sContext_t *psHciContext = ((phHciNfc_sContext_t *)
+ psHciHandle);
+
+ if((NULL == psHciContext) || (NULL == pHwRef))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info = NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t*)psHciContext->p_swp_info;
+
+ status = phHciNfc_DevMgmt_Get_Info(psHciContext, pHwRef,
+ NFC_ADDRESS_SWP_BITRATE, &(ps_swp_info->uicc_bitrate));
+
+ }
+ return status;
+}
+
+
+NFCSTATUS
+phHciNfc_SWP_Protection(
+ void *psHciHandle,
+ void *pHwRef,
+ uint8_t mode
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ static uint8_t param = 0 ;
+ phHciNfc_sContext_t *psHciContext = ((phHciNfc_sContext_t *)psHciHandle);
+
+ if((NULL == psHciContext)||(NULL == pHwRef))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ phHciNfc_Pipe_Info_t *ps_pipe_info=NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t*)psHciContext->p_swp_info;
+ ps_pipe_info = ps_swp_info->p_pipe_info;
+
+ if(NULL == ps_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ ps_pipe_info->reg_index = NXP_SWP_PROTECTED_INDEX;
+ /* Enable/Disable SWP Protection */
+ param = (uint8_t)mode;
+ ps_pipe_info->param_info =(void*)&param ;
+ ps_pipe_info->param_length = sizeof(param) ;
+ status = phHciNfc_Send_Generic_Cmd(psHciContext, pHwRef,
+ ps_swp_info->pipe_id,
+ (uint8_t)ANY_SET_PARAMETER);
+ }
+
+ }
+ return status;
+}
+
+
+
+
+static
+NFCSTATUS
+phHciNfc_SWP_InfoUpdate(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t index,
+ uint8_t *reg_value,
+ uint8_t reg_length
+ )
+{
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+
+ /* To remove "warning (VS C4100) : unreferenced formal parameter" */
+ PHNFC_UNUSED_VARIABLE(reg_length);
+ switch(index)
+ {
+ case NXP_SWP_DEFAULT_MODE_INDEX:
+ {
+ HCI_PRINT_BUFFER("\tUICC Enable Register:",reg_value,reg_length);
+ break;
+ }
+ /* Get the Status of the UICC Connection */
+ case NXP_SWP_STATUS_INDEX:
+ {
+ HCI_PRINT_BUFFER("\tUICC Connection Status:", reg_value, reg_length);
+ ps_swp_info->uicc_status = (phHciNfc_SWP_Status_t ) *reg_value ;
+ break;
+ }
+ case NXP_SWP_PROTECTED_INDEX:
+ {
+ HCI_PRINT_BUFFER("\t UICC Card Emulation Rights :",reg_value,reg_length);
+
+ break;
+ }
+ default:
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_HCI_INFORMATION);
+ break;
+ }
+ } /* End of switch(index) */
+
+ return status;
+}
+
+NFCSTATUS
+phHciNfc_SWP_Configure_Mode(
+ void *psHciHandle,
+ void *pHwRef,
+ uint8_t uicc_mode
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ static uint8_t param = 0;
+ phHciNfc_sContext_t *psHciContext = ((phHciNfc_sContext_t *)
+ psHciHandle);
+
+ if( (NULL == psHciContext)||(NULL == pHwRef))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if ( NULL == psHciContext->p_swp_info )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ phHciNfc_Pipe_Info_t *ps_pipe_info=NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t*)psHciContext->p_swp_info;
+
+ ps_pipe_info = ps_swp_info->p_pipe_info;
+ if(NULL == ps_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ /* Switch the Mode of the SmartMx */
+ param = uicc_mode;
+ ps_pipe_info->param_info =(void*)&param ;
+ ps_pipe_info->param_length = sizeof(param) ;
+ status = phHciNfc_Send_SWP_Event( psHciContext, pHwRef,
+ ps_swp_info->pipe_id,
+ NXP_EVT_SWP_SWITCH_MODE );
+
+ /* Send the Success Status as this is an event */
+ status = ((status == NFCSTATUS_PENDING)?
+ NFCSTATUS_SUCCESS : status);
+
+ }/* End of else part*/
+ }
+ return status;
+}
+
+static
+NFCSTATUS
+phHciNfc_Recv_SWP_Event(
+ void *psContext,
+ void *pHwRef,
+ uint8_t *pEvent,
+#ifdef ONE_BYTE_LEN
+ uint8_t length
+#else
+ uint16_t length
+#endif
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_sContext_t *psHciContext =
+ (phHciNfc_sContext_t *)psContext ;
+ static phHal_sEventInfo_t EventInfo;
+
+
+ if( (NULL == psHciContext) || (NULL == pHwRef) || (NULL == pEvent)
+ || (length == 0))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if(NULL == psHciContext->p_swp_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_FEATURE_NOT_SUPPORTED);
+ }
+ else
+ {
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+
+ ps_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+ if( NULL == ps_swp_info->p_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ phHciNfc_HCP_Packet_t *p_packet = NULL;
+ phHciNfc_HCP_Message_t *message = NULL;
+ uint8_t EventType = 0;
+
+ p_packet = (phHciNfc_HCP_Packet_t *)pEvent;
+ message = &(p_packet->msg.message);
+ /* Get the instruction bits from the Message Header */
+ EventType = (uint8_t) GET_BITS8( message->msg_header,
+ HCP_MSG_INSTRUCTION_OFFSET, HCP_MSG_INSTRUCTION_LEN);
+
+ EventInfo.eventHost = phHal_eHostController;
+ EventInfo.eventSource = phHal_ePICC_DevType;
+ /* Occurrence of the Protected events for reporting */
+ if (NXP_EVT_SWP_PROTECTED == EventType)
+ {
+ EventInfo.eventType = NFC_EVT_PROTECTED;
+ }
+ else
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_HCI_RESPONSE);
+ }
+
+ if (NFCSTATUS_SUCCESS == status )
+ {
+ phHciNfc_Notify_Event( psHciContext, pHwRef,
+ NFC_NOTIFY_EVENT, (void*)&EventInfo);
+ }
+
+ }
+ }
+ return status;
+}
+
+
+
+static
+NFCSTATUS
+phHciNfc_Send_SWP_Event(
+ phHciNfc_sContext_t *psHciContext,
+ void *pHwRef,
+ uint8_t pipe_id,
+ uint8_t event
+ )
+{
+ phHciNfc_HCP_Packet_t *hcp_packet = NULL;
+ phHciNfc_HCP_Message_t *hcp_message = NULL;
+ phHciNfc_Pipe_Info_t *p_pipe_info = NULL;
+ uint8_t length = 0;
+ uint8_t i=0;
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+
+ p_pipe_info = (phHciNfc_Pipe_Info_t *)
+ psHciContext->p_pipe_list[pipe_id];
+ psHciContext->tx_total = 0 ;
+ length = (length + HCP_HEADER_LEN);
+
+ hcp_packet = (phHciNfc_HCP_Packet_t *) psHciContext->send_buffer;
+ /* Construct the HCP Frame */
+ phHciNfc_Build_HCPFrame(hcp_packet,HCP_CHAINBIT_DEFAULT,
+ (uint8_t) pipe_id,
+ HCP_MSG_TYPE_EVENT, event);
+
+ hcp_message = &(hcp_packet->msg.message);
+
+ phHciNfc_Append_HCPFrame((uint8_t *)hcp_message->payload,
+ i,
+ (uint8_t *)p_pipe_info->param_info,
+ p_pipe_info->param_length);
+ length = (uint8_t)(length + i + p_pipe_info->param_length);
+
+ p_pipe_info->sent_msg_type = HCP_MSG_TYPE_EVENT ;
+ p_pipe_info->prev_msg = event ;
+ psHciContext->tx_total = length;
+
+ /* Send the Constructed HCP packet to the lower layer */
+ status = phHciNfc_Send_HCP( psHciContext, pHwRef );
+ if(NFCSTATUS_PENDING == status)
+ {
+ ((phHciNfc_SWP_Info_t *)psHciContext->p_swp_info)->current_seq =
+ ((phHciNfc_SWP_Info_t *)psHciContext->p_swp_info)->next_seq;
+ p_pipe_info->prev_status = status;
+ }
+
+ return status;
+}
+
+NFCSTATUS
+phHciNfc_SWP_Update_Sequence(
+ phHciNfc_sContext_t *psHciContext,
+ phHciNfc_eSeqType_t SWP_seq
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+ if( NULL == psHciContext )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if( NULL == psHciContext->p_swp_info )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ ps_swp_info = (phHciNfc_SWP_Info_t *)
+ psHciContext->p_swp_info ;
+ switch(SWP_seq)
+ {
+ case RESET_SEQ:
+ case INIT_SEQ:
+ {
+ ps_swp_info->current_seq = SWP_INVALID_SEQUENCE;
+ ps_swp_info->next_seq = SWP_INVALID_SEQUENCE ;
+ break;
+ }
+ case UPDATE_SEQ:
+ {
+ ps_swp_info->current_seq = ps_swp_info->next_seq;
+ break;
+ }
+ case REL_SEQ:
+ {
+ ps_swp_info->current_seq = SWP_INVALID_SEQUENCE;
+ ps_swp_info->next_seq = SWP_INVALID_SEQUENCE;
+ break;
+ }
+ case CONFIG_SEQ:
+ {
+ ps_swp_info->current_seq = SWP_STATUS_SEQ;
+ ps_swp_info->next_seq = SWP_STATUS_SEQ;
+ break;
+ }
+ default:
+ {
+ break;
+ }
+ }
+ }
+ return status;
+}
+
+NFCSTATUS
+phHciNfc_SWP_Config_Sequence(
+ phHciNfc_sContext_t *psHciContext,
+ void *pHwRef,
+ phHal_sEmulationCfg_t *ps_emulation_cfg
+ )
+{
+ NFCSTATUS status = NFCSTATUS_SUCCESS;
+ phHciNfc_SWP_Info_t *ps_swp_info=NULL;
+
+ if ((NULL == psHciContext) || (NULL == pHwRef) ||
+ (NULL == ps_emulation_cfg))
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI, NFCSTATUS_INVALID_PARAMETER);
+ }
+ else if( NULL == psHciContext->p_swp_info )
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ phHciNfc_Pipe_Info_t *ps_pipe_info = NULL;
+ phHal_sUiccEmuCfg_t *uicc_config =
+ &(ps_emulation_cfg->config.uiccEmuCfg);
+
+ ps_swp_info = (phHciNfc_SWP_Info_t *)psHciContext->p_swp_info;
+ ps_pipe_info = ps_swp_info->p_pipe_info;
+
+ if (NULL == ps_pipe_info)
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ }
+ else
+ {
+ switch(ps_swp_info->current_seq)
+ {
+ case SWP_STATUS_SEQ :
+ {
+ status = phHciNfc_SWP_Configure_Default( psHciContext,
+ pHwRef, uicc_config->enableUicc );
+
+ if(status == NFCSTATUS_PENDING)
+ {
+ ps_swp_info->next_seq = SWP_STATUS_SEQ;
+ status = NFCSTATUS_SUCCESS;
+ }
+ break;
+ }
+ case SWP_MODE_SEQ :
+ {
+ status = phHciNfc_SWP_Configure_Mode( psHciContext,
+ pHwRef, UICC_SWITCH_MODE_DEFAULT );
+ /* UICC_SWITCH_MODE_ON */
+ if(status == NFCSTATUS_PENDING)
+ {
+ ps_swp_info->next_seq = SWP_STATUS_SEQ;
+ status = NFCSTATUS_SUCCESS;
+ }
+ break;
+ }
+ default :
+ {
+ status = PHNFCSTVAL(CID_NFC_HCI,
+ NFCSTATUS_INVALID_HCI_INFORMATION);
+ break;
+ }
+ }
+ }
+ }
+ return status;
+}
+
+
+