summaryrefslogtreecommitdiffstats
path: root/src/phHciNfc_CE_B.h
diff options
context:
space:
mode:
authorNick Pelly <npelly@google.com>2010-09-23 12:47:58 -0700
committerNick Pelly <npelly@google.com>2010-09-23 13:53:18 -0700
commit5d9927ba30ba449badb9f6df0fbeb4d6aedc6e2a (patch)
tree190f9251c6db03d3550ec7f30b51a2561c01d9cf /src/phHciNfc_CE_B.h
parent4ff7c86a2c706b150078274455406f1b04966e1a (diff)
downloadexternal_libnfc-nxp-5d9927ba30ba449badb9f6df0fbeb4d6aedc6e2a.zip
external_libnfc-nxp-5d9927ba30ba449badb9f6df0fbeb4d6aedc6e2a.tar.gz
external_libnfc-nxp-5d9927ba30ba449badb9f6df0fbeb4d6aedc6e2a.tar.bz2
Initial libnfc checkin
Source: Trusted_NFC_Device_Host_AA03.01e02_google.zip code drop (23-Sep-2010) Change-Id: Ie47f18423f949a8d3e0815d13f55c814312add24 Signed-off-by: Nick Pelly <npelly@google.com>
Diffstat (limited to 'src/phHciNfc_CE_B.h')
-rw-r--r--src/phHciNfc_CE_B.h284
1 files changed, 284 insertions, 0 deletions
diff --git a/src/phHciNfc_CE_B.h b/src/phHciNfc_CE_B.h
new file mode 100644
index 0000000..e34e2db
--- /dev/null
+++ b/src/phHciNfc_CE_B.h
@@ -0,0 +1,284 @@
+/*
+ * 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_CE_B.h *
+* \brief HCI card emulation management routines. *
+* *
+* *
+* Project: NFC-FRI-1.1 *
+* *
+* $Date: Fri Aug 14 17:01:26 2009 $ *
+* $Author: ing04880 $ *
+* $Revision: 1.4 $ *
+* $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 $ *
+* *
+* =========================================================================== *
+*/
+
+
+#ifndef PHHCINFC_CE_B_H
+#define PHHCINFC_CE_B_H
+
+/*@}*/
+
+
+/**
+* \name HCI
+*
+* File: \ref phHciNfc_CE_B.h
+*
+*/
+/*@{*/
+#define PHHCINFC_CE_B_FILEREVISION "$Revision: 1.4 $" /**< \ingroup grp_file_attributes */
+#define PHHCINFC_CE_B_FILEALIASES "$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 $" /**< \ingroup grp_file_attributes */
+/*@}*/
+
+/*
+***************************** Header File Inclusion ****************************
+*/
+
+#include <phHciNfc_Generic.h>
+
+/*
+****************************** Macro Definitions *******************************
+*/
+#define HOST_CE_B_MODE_INDEX (0x01U)
+#define HOST_CE_B_PUPI_INDEX (0x02U)
+#define HOST_CE_B_AFI_INDEX (0x03U)
+#define HOST_CE_B_ATQB_INDEX (0x04U)
+#define HOST_CE_B_HIGH_LAYER_RESP_INDEX (0x05U)
+#define HOST_CE_B_DATA_RATE_MAX_INDEX (0x05U)
+
+/*
+******************** Enumeration and Structure Definition **********************
+*/
+
+/* Sequence list */
+typedef enum phHciNfc_CE_B_Seq{
+ HOST_CE_B_INVALID_SEQ,
+ HOST_CE_B_PIPE_OPEN,
+ HOST_CE_B_PUPI_SEQ,
+ HOST_CE_B_ATQB_SEQ,
+ HOST_CE_B_ENABLE_SEQ,
+ HOST_CE_B_DISABLE_SEQ,
+ HOST_CE_B_PIPE_CLOSE,
+ HOST_CE_B_PIPE_DELETE
+}phHciNfc_CE_B_Seq_t;
+
+/* Information structure for the card emulation B gate */
+typedef struct phHciNfc_CE_B_Info{
+ phHciNfc_CE_B_Seq_t current_seq;
+ phHciNfc_CE_B_Seq_t next_seq;
+ /* Pointer to the card emulation B pipe information */
+ phHciNfc_Pipe_Info_t *p_pipe_info;
+ uint8_t pipe_id;
+
+} phHciNfc_CE_B_Info_t;
+
+/*
+*********************** Function Prototype Declaration *************************
+*/
+
+/*!
+ * \brief Allocates the resources of card emulation B management gate.
+ *
+ * This function Allocates the resources of the card emulation B management
+ * gate Information Structure.
+ *
+ */
+extern
+NFCSTATUS
+phHciNfc_CE_B_Init_Resources(
+ phHciNfc_sContext_t *psHciContext
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Get_PipeID function gives the pipe id of the card
+* emulation B gate
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pHwRef pHwRef is the Information of
+* the Device Interface Link
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+extern
+NFCSTATUS
+phHciNfc_CE_B_Get_PipeID(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t *ppipe_id
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Update_PipeInfo function updates the pipe_id of the card
+* emulation B gate management Structure.
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pipeID pipeID of the card emulation A gate
+* \param[in] pPipeInfo Update the pipe Information of the reader
+* A gate
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+
+extern
+NFCSTATUS
+phHciNfc_CE_B_Update_PipeInfo(
+ phHciNfc_sContext_t *psHciContext,
+ uint8_t pipeID,
+ phHciNfc_Pipe_Info_t *pPipeInfo
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_SendData_Event function sends data to the PN544
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pHwRef pHwRef is the Information of
+* the Device Interface Link
+* \param[in] pipeID pipeID of the card emulation B gate
+* \param[in] pPipeInfo Update the pipe Information of the card
+* emulation B gate
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+#ifdef CE_B_SEND_EVENT
+extern
+NFCSTATUS
+phHciNfc_CE_B_SendData_Event(
+ void *psContext,
+ void *pHwRef,
+ uint8_t *pEvent,
+ uint8_t length
+ );
+#endif /* #ifdef CE_B_SEND_EVENT */
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Mode function sends data to the set the card emulation mode
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pHwRef pHwRef is the Information of
+* the Device Interface Link
+* \param[in] enable_type type to enable
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+NFCSTATUS
+phHciNfc_CE_B_Mode(
+ void *psHciHandle,
+ void *pHwRef,
+ uint8_t enable_type
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Initialise function opens the CE B and set all the
+* required parameters for CE B
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pHwRef pHwRef is the Information of
+* the Device Interface Link
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+extern
+NFCSTATUS
+phHciNfc_CE_B_Initialise(
+ phHciNfc_sContext_t *psHciContext,
+ void *pHwRef
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Initialise function close the CE B and reset all the
+* required parameters to default value of CE B
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] pHwRef pHwRef is the Information of
+* the Device Interface Link
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+extern
+NFCSTATUS
+phHciNfc_CE_B_Release(
+ phHciNfc_sContext_t *psHciContext,
+ void *pHwRef
+ );
+
+/**
+* \ingroup grp_hci_nfc
+*
+* The phHciNfc_CE_B_Update_Seq function to update CE B sequence depending on the
+* specified \ref seq_type
+*
+* \param[in] psHciContext psHciContext is the pointer to HCI Layer
+* context Structure.
+* \param[in] seq_type sequence type specified in
+* \ref phHciNfc_eSeqType_t
+*
+* \retval NFCSTATUS_SUCCESS Function execution is successful.
+* \retval NFCSTATUS_INVALID_PARAMETER One or more of the supplied parameters
+* could not be interpreted properly.
+*
+*/
+extern
+NFCSTATUS
+phHciNfc_CE_B_Update_Seq(
+ phHciNfc_sContext_t *psHciContext,
+ phHciNfc_eSeqType_t seq_type
+ );
+
+#endif /* PHHCINFC_CE_B_H */
+
+