| /* |
| * 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 phDal4Nfc.h |
| * \brief Common DAL for the upper layer. |
| * |
| * Project: NFC-FRI-1.1 |
| * |
| * $Date: Tue Nov 10 13:56:45 2009 $ |
| * $Author: ing07299 $ |
| * $Revision: 1.38 $ |
| * $Aliases: 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 PHDAL4NFC_H |
| #define PHDAL4NFC_H |
| |
| /** |
| * \name DAl4 NFC |
| * |
| * File: \ref phDal4Nfc.h |
| * |
| */ |
| /*@{*/ |
| #define PH_DAL4NFC_FILEREVISION "$Revision: 1.38 $" /**< \ingroup grp_file_attributes */ |
| #define PH_DAL4NFC_FILEALIASES "$Aliases: 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 */ |
| /*@}*/ |
| /*************************** Includes *******************************/ |
| /** \defgroup grp_nfc_dal DAL Component |
| * |
| * |
| * |
| */ |
| /**< Basic type definitions */ |
| #include <phNfcTypes.h> |
| /**< Generic Interface Layer Function Definitions */ |
| #include <phNfcInterface.h> |
| /*********************** End of includes ****************************/ |
| |
| /***************************** Macros *******************************/ |
| /**< Used for messaging by DAL as well as Upper Layers */ |
| #define PH_DAL4NFC_MESSAGE_BASE PH_LIBNFC_DEFERREDCALL_MSG |
| |
| /************************ End of macros *****************************/ |
| |
| |
| /********************* Structures and enums *************************/ |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * DAL context : This contains the information of the upper layer callback |
| * and hardware reference. |
| */ |
| typedef struct phDal4Nfc_SContext |
| { |
| phNfcIF_sCallBack_t cb_if; /**<Callback info registered by upper layer*/ |
| volatile uint8_t hw_valid; /**<Flag - shows Hardware present or not */ |
| void *pHwRef; /**<Hardware Reference*/ |
| }phDal4Nfc_SContext_t,*pphDal4Nfc_SContext_t; |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * DAL enum for Messages : This contains the enums used for |
| * posting messages to the application. |
| */ |
| typedef enum phDal4Nfc_Messages_en |
| { |
| /**<Read message type used to post Read DAL Message to dispatch routine.Dispatch routine |
| calls read callback registered by upper layer */ |
| PHDAL4NFC_READ_MESSAGE = 0, |
| /**<Readwait message type used to post Read wait DAL Message to dispatch routine.Dispatch routine |
| calls read wait callback registered by upper layer */ |
| PHDAL4NFC_READWAIT_MESSAGE, |
| /**<Write message type used to post write DAL Message to dispatch routine.Dispatch routine |
| calls write wait callback registered by upper layer */ |
| PHDAL4NFC_WRITE_MESSAGE, |
| /**<Notify message type used to post Notify DAL Message to dispatch routine.Dispatch routine |
| calls notify callback registered by upper layer */ |
| PHDAL4NFC_NOTIFY_MESSAGE |
| }phDal4Nfc_Messages_en_t; |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief DAL Message structure definition.This structure contains |
| * |
| * This structure contains details like message type,read ,read wait and write callbacks |
| * reference details as registered by upper layer. |
| */ |
| typedef struct phDal4Nfc_Message |
| { |
| /**<Refenrece to context.Context can be DAL context */ |
| void *pContext; |
| /**<Reference to hardware reference strucutre */ |
| void *pHwRef; |
| /**<DAL message of type \ref phDal4Nfc_Messages_en_t*/ |
| phDal4Nfc_Messages_en_t eMsgType; |
| /**<Transaction specific information of type \ref phNfc_sTransactionInfo_t*/ |
| phNfc_sTransactionInfo_t transactInfo; |
| /**<Reference to read callback,registered by upper layer.This is of type \ref pphNfcIF_Transact_Completion_CB_t*/ |
| pphNfcIF_Transact_Completion_CB_t readCbPtr; |
| /**<Reference to write callback ,registered by upper layer.This is of type \ref pphNfcIF_Transact_Completion_CB_t*/ |
| pphNfcIF_Transact_Completion_CB_t writeCbPtr; |
| } phDal4Nfc_Message_t,*pphDal4Nfc_Message_t; |
| |
| /** |
| * \ingroup grp_nfc_dal |
| *\brief Possible DAL Configuration exposed to upper layer. |
| * Typically this should be port name (Ex:"COM1","COM2") to which PN544 is connected. |
| */ |
| #define ENUM_DAL_LINK_TYPE_COM1 ENUM_LINK_TYPE_COM1 |
| #define ENUM_DAL_LINK_TYPE_COM2 ENUM_LINK_TYPE_COM2 |
| #define ENUM_DAL_LINK_TYPE_COM3 ENUM_LINK_TYPE_COM3 |
| #define ENUM_DAL_LINK_TYPE_COM4 ENUM_LINK_TYPE_COM4 |
| #define ENUM_DAL_LINK_TYPE_COM5 ENUM_LINK_TYPE_COM5 |
| #define ENUM_DAL_LINK_TYPE_COM6 ENUM_LINK_TYPE_COM6 |
| #define ENUM_DAL_LINK_TYPE_COM7 ENUM_LINK_TYPE_COM7 |
| #define ENUM_DAL_LINK_TYPE_COM8 ENUM_LINK_TYPE_COM8 |
| #define ENUM_DAL_LINK_TYPE_I2C ENUM_LINK_TYPE_I2C |
| #define ENUM_DAL_LINK_TYPE_USB ENUM_LINK_TYPE_USB |
| #define ENUM_DAL_LINK_TYPE_TCP ENUM_LINK_TYPE_TCP |
| |
| #define ENUM_DAL_LINK_TYPE_NB ENUM_LINK_TYPE_NB |
| typedef phLibNfc_eConfigLinkType phDal4Nfc_eConfigLinkType; |
| |
| typedef phLibNfc_sConfig_t phDal4Nfc_sConfig_t; |
| typedef phLibNfc_sConfig_t *pphDal4Nfc_sConfig_t; |
| |
| /****************** End of structures and enums *********************/ |
| |
| /******************** Function declarations *************************/ |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| *\brief Allows to register upper layer with DAL layer. |
| * This API allows upper layer to register with DAL layer.As part of registration |
| *<br>1.Exports DAL interfaces and DAL layer context to upper layer. |
| *Exported DAL interfaces are : |
| *<br><br>.phDal4Nfc_Shutdown |
| *<br><br>.phDal4Nfc_Write |
| *<br><br>.phDal4Nfc_Read |
| *<br><br>.phDal4Nfc_ReadWait |
| *<br><br>.phDal4Nfc_ReadWaitCancel |
| *<br><br>phDal4Nfc_Unregister |
| *<br><br>.Registeres upper layer callbacks and upper layer context with DAL layer. |
| *For details refer to \ref phNfcIF_sReference_t. |
| *Registration details are valid unless upper layer calls \ref phDal4Nfc_Unregister() |
| or \ref phDal4Nfc_Shutdown called. |
| |
| * \param[in,out] psRefer holds DAL exported interface references once registration |
| * sucessful.This also contains transmit and receive buffer |
| * references. |
| * |
| * \param[in] if_cb Contains upper layer callback reference details, which are used |
| * by DAL layer during callback notification. |
| * These callbacks gets registered with DAL layer. |
| * |
| |
| * \param[out] psIFConf Currently this parameter not used.This parameter to be other than NULL. |
| * |
| * |
| * \retval NFCSTATUS_SUCCESS Operation is successful. |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function is invalid. |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Register()",URL="\ref phDal4Nfc_Register"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Register( |
| phNfcIF_sReference_t *psRefer, |
| phNfcIF_sCallBack_t if_cb, |
| void *psIFConf |
| ); |
| |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief Allows upper layer to unregister with DAL layer. |
| * This interface allows to unregister upper layer callback interfaces with DAL layer. |
| * \note: Once this this API is called DAL layer stops notifying upper layer callbacks in case |
| * any events reported within DAL. |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL context earlier was given to the |
| * upper layer through the \ref |
| * \e phDal4Nfc_Register() function. |
| * \param[in] pHwRef for future use .Currently this parameter is not used. |
| * This needs to be other than NULL. |
| * |
| * \retval NFCSTATUS_SUCCESS Unregistration successful. |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function is invalid. |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Register()",URL="\ref phDal4Nfc_Register"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="Upper layer can issue Unregistration later"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Unregister()",URL="\ref phDal4Nfc_Unregister"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Unregister( |
| void *pContext, |
| void *pHwRef |
| ); |
| |
| |
| /** |
| |
| * \ingroup grp_nfc_dal |
| * |
| *\brief This interface allows to initialize DAL layer. |
| * This API implements initialization of DAL layer. This includes : |
| * |
| * <br><br>. Initialize parameters for HW Interface. |
| *<br><br>. Initializing read and writer threads. |
| *<br><br>. Initializing read and write task specific events and event specific configurations. |
| *<br><br>. Initializing DAL layer specific details. |
| * |
| * \param[in] pContext DAL context provided by the upper layer. |
| * The DAL context will be exported to the |
| * upper layer via upper layer registration interface. |
| * \param[in] pHwRef information of the hardware |
| * |
| * \retval NFCSTATUS_SUCCESS DAL initialization successful. |
| * \retval NFCSTATUS_INVALID_DEVICE The device is not enumerated or the |
| * Hardware Reference points to a device |
| * which does not exist. Alternatively, |
| * also already open devices produce this |
| * error. |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function |
| * is invalid. |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Register()",URL="\ref phDal4Nfc_Register"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Init()",URL="\ref phDal4Nfc_Init"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="DAL intialised ,read for read /write operations"]; |
| *\endmsc |
| */ |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Init( |
| void *pContext, |
| void *pHwRef |
| ); |
| |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief This API implements Deintialisation of DAL layer. |
| * |
| *This API implements Deintialisation of DAL layer. It includes : |
| *<br><br>.Releases all the resources.( context,memory resources,read/write buffers). |
| *<br><br>.closes COMxx port which is used during DAL session. |
| *<br><br>.Terminates Reader and writer tasks. |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL context earlier was given to the |
| * upper layer through the |
| * \ref \e phDal4Nfc_Register() function |
| * \param[in] pHwRef hardware reference context. |
| * |
| * \retval NFCSTATUS_SUCCESS DAL shutdown successful |
| * \retval NFCSTATUS_FAILED DAL shutdown failed(example.unable to |
| * suspend thread, close HW Interface etc.) |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function |
| * is invalid. |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Register()",URL="\ref phDal4Nfc_Register"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Init()",URL="\ref phDal4Nfc_Init"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="Perform read write operation"]; |
| *--- [label="DAL can be shutdown during upper layer deinit sequence"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Shutdown()",URL="\ref phDal4Nfc_Shutdown"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Shutdown( |
| void *pContext, |
| void *pHwRef |
| ); |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief Allows to write data block to HW Interface. |
| * |
| * This asynchronous function writes the given block of data to the driver. |
| * This interface enables writer thread in case their is no write requests pending and returns |
| * sucessfully.Once writer thread completes write operation, it notifies upper layer using callback |
| * mechanism . |
| * \note writer thread notifies upper layer callback notified using windows messaging mechanism |
| * under deferred call context. |
| * |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL |
| * context earlier was given to the upper layer |
| * through the \ref \e phDal4Nfc_Register() function |
| * \param[in] pHwRef information of the hardware. |
| * \param[in] pBuffer The information given by the upper layer to |
| * send it to the lower layer |
| * \param[in] length The length of pLlc_Buf, that needs to be sent |
| * to the lower layer is given by the upper layer |
| * |
| * \retval NFCSTATUS_PENDING If the command is yet to be process. |
| * \retval NFCSTATUS_BUSY BUSY with previous write operation |
| * \retval NFCSTATUS_INVALID_DEVICE The device has not been opened or has |
| * been disconnected meanwhile |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function |
| * is invalid. |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *--- [label="Configure,intialise DAL layer and Register with DAL "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Write()",URL="\ref phDal4Nfc_Write()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts write message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="send_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| extern |
| NFCSTATUS |
| phDal4Nfc_Write( |
| void *pContext, |
| void *pHwRef, |
| uint8_t *pBuffer, |
| uint16_t length |
| ); |
| |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief Allows to Read data block from HW Interface. |
| * |
| * This asynchronous function reads the data from the driver in which length |
| * and the required buffer are sent by upper layer. This interface enables |
| * reader thread in case there is no read requests pending and returns sucessfully. |
| * Once read operation is complete, it notifies to upper layer through callback |
| * registered in the \b \e phDal4Nfc_Register() function. |
| * |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL context earlier was given to the |
| * upper layer through the |
| * \b \e phDal4Nfc_Register() function |
| * \param[in] pHwRef Information of the hardware |
| * \param[in] pBuffer The information given by the upper layer to |
| * receive data from the lower layer |
| * \param[in] length The length of pBuffer given by the upper layer |
| * |
| * \retval NFCSTATUS_PENDING If the command is yet to be processed. |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function |
| * is invalid. |
| * \retval NFCSTATUS_INVALID_DEVICE The device has not been opened or has |
| * been disconnected meanwhile |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *--- [label="Configure,intialise DAL layer and Register with DAL "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Write()",URL="\ref phDal4Nfc_Write()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts write message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="send_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="upper layer can issue read request"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Read()",URL="\ref phDal4Nfc_Read()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts read message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="receive_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| |
| *\endmsc |
| */ |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Read( |
| void *pContext, |
| void *pHwRef, |
| uint8_t *pBuffer, |
| uint16_t length |
| ); |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief Allows to wait before reading data block from HW Interface. |
| * |
| * This asynchronous function waits before reading the data from the |
| * driver in which length and the required buffer are sent by upper layer. |
| * This interface enables reader thread to wait for predefined time period |
| * (predefined time period is configurable by the DAL implementer) to complete |
| * read request.Once read operation is complete, it notifies to upper layer |
| * through callback registered in the \b \e phDal4Nfc_Register() |
| * function. Read request is expected to get complete within this time. |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL context earlier was given to the |
| * upper layer through the |
| * \b \e phDal4Nfc_Register() function |
| * \param[in] pHwRef Information of the hardware |
| * \param[in] pBuffer The information given by the upper layer to |
| * receive data from the lower layer |
| * \param[in] length The length of pBuffer given by the upper layer |
| * |
| * \retval NFCSTATUS_SUCCESS DAL receive successful |
| * \retval NFCSTATUS_BUSY BUSY with previous receive operation |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the |
| * function is invalid. |
| * \retval NFCSTATUS_INVALID_DEVICE The device has not been opened or has |
| * been disconnected meanwhile |
| * |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *--- [label="Configure,intialise DAL layer and Register with DAL "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Write()",URL="\ref phDal4Nfc_Write()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts write message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="send_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="upper layer can issue read wait request "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_ReadWait()",URL="\ref phDal4Nfc_ReadWait()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts read wait message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="receive_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| * |
| *\endmsc |
| */ |
| |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_ReadWait( |
| void *pContext, |
| void *pHwRef, |
| uint8_t *pBuffer, |
| uint16_t length |
| ); |
| |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| *\brief Aborts read wait opertaion. |
| * |
| * This asynchronous function issues cancellation of the outstanding |
| * \b \e phDal4Nfc_ReadWait request.If upper layer wants to cancel the |
| * ongoing read wait operation this function is used. e.g. to abort the |
| * transactions. |
| * |
| * \param[in] pContext DAL context is provided by the upper layer. |
| * The DAL context earlier was given to the |
| * upper layer through the |
| * \b \e phDal4Nfc_Register() function |
| * \param[in] pHwRef Information of the hardware |
| * |
| * \retval NFCSTATUS_SUCCESS DAL receive successful |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the |
| * function is invalid. |
| * \retval NFCSTATUS_INVALID_DEVICE The device has not been opened |
| * or has been disconnected meanwhile |
| * \retval NFCSTATUS_BOARD_COMMUNICATION_ERROR A board communication error occurred |
| (e.g. configuration went wrong). |
| * |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *--- [label="Configure,intialise DAL layer and Register with DAL "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Write()",URL="\ref phDal4Nfc_Write()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="DAL posts write message to main thread under deferred call context"]; |
| *phDal4Nfc=>phDal4Nfc [label="phDal4Nfc_DeferredCall()",URL="\ref phDal4Nfc_DeferredCall()"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_DeferredCb()",URL="\ref Call phDal4Nfc_DeferredCb()"]; |
| *phDal4Nfc=>UpperLayer [label="send_complete",URL="\ref phDal4Nfc_DeferredCb()"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="upper layer can issue read wait request "]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_ReadWait()",URL="\ref phDal4Nfc_ReadWait()"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_PENDING"]; |
| *--- [label="Issue Read wait cancel request here"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_ReadWaitCancel()",URL="\ref phDal4Nfc_ReadWaitCancel()"]; |
| **UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| extern |
| NFCSTATUS |
| phDal4Nfc_ReadWaitCancel( |
| void *pContext, |
| void *pHwRef |
| ); |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief DAL config function |
| * This synchronous function configures the given HW Interface and |
| * sends the HANDLE to the caller. |
| * |
| * \param[in] config DAL configuration details as provided |
| * by the upper layer. |
| * \param[in,out] phwref pointer to which valid Handle to DAL |
| * interface is assigned. |
| * |
| * \retval NFCSTATUS_SUCCESS Configuration happened successfully. |
| * \retval NFCSTATUS_INVALID_PARAMETER At least one parameter of the function |
| * is invalid. |
| * \retval NFCSTATUS_FAILED Configuration failed(example.unable to |
| * open HW Interface). |
| * \retval NFCSTATUS_INVALID_DEVICE The device has not been opened or |
| * has been disconnected meanwhile |
| * \retval NFCSTATUS_BOARD_COMMUNICATION_ERROR A board communication error occurred |
| (e.g. configuration went wrong). |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| extern |
| NFCSTATUS |
| phDal4Nfc_Config ( |
| pphDal4Nfc_sConfig_t config, |
| void **phwref |
| ); |
| |
| /** |
| * \ingroup grp_nfc_dal |
| * |
| * \brief Release configuration for the given HW Interface. |
| * |
| * \copydoc page_reg Release all the variables of the DAL component, that has been |
| * initialised in \b phDal4Nfc_Config function (Synchronous function). |
| * |
| * \param[in] pHwRef Link information of the hardware |
| * |
| * \retval NFCSTATUS_SUCCESS DAL Configuration Released successfully. |
| * \retval NFCSTATUS_FAILED Configuration release failed(example: Unable to close Com port). |
| * |
| *\msc |
| *ClientApp,UpperLayer,phDal4Nfc; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_Config()",URL="\ref phDal4Nfc_Config"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Register()",URL="\ref phDal4Nfc_Register"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Init()",URL="\ref phDal4Nfc_Init"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *--- [label="Perform read write operation"]; |
| *--- [label="DAL resources can be released during upper layer deinit sequence"]; |
| *UpperLayer=>phDal4Nfc [label="phDal4Nfc_Shutdown()",URL="\ref phDal4Nfc_Shutdown"]; |
| *UpperLayer<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *ClientApp=>phDal4Nfc [label="phDal4Nfc_ConfigRelease()",URL="\ref phDal4Nfc_ConfigRelease"]; |
| *ClientApp<<phDal4Nfc [label="NFCSTATUS_SUCCESS"]; |
| *\endmsc |
| */ |
| extern |
| NFCSTATUS |
| phDal4Nfc_ConfigRelease( |
| void *pHwRef); |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Reset(long level); |
| |
| extern |
| NFCSTATUS |
| phDal4Nfc_Download(); |
| |
| /******************** Function declarations *************************/ |
| |
| #endif /* PHDALNFC_H */ |
| |
| /****************************************** END OF FILE ***************************************************/ |
| |