1 /* 2 * Copyright (C) 2010 NXP Semiconductors 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 /* 18 * \file phOsalNfc.h 19 * \brief OSAL Implementation. 20 * 21 * Project: NFC-FRI 1.1 22 * $Date: Fri Jun 26 14:41:31 2009 $ 23 * $Author: ing04880 $ 24 * $Revision: 1.21 $ 25 * $Aliases: NFC_FRI1.1_WK926_R28_1,NFC_FRI1.1_WK928_R29_1,NFC_FRI1.1_WK930_R30_1,NFC_FRI1.1_WK934_PREP_1,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 $ 26 * 27 */ 28 #ifndef PHOSALNFC_H 29 #define PHOSALNFC_H 30 31 32 /** \defgroup grp_osal_nfc OSAL Component 33 * 34 *\note: API listed here encompasses Operating System Abstraction Layer interfaces required to be mapped to underlying OS platforms. 35 * 36 */ 37 #include <phNfcTypes.h> 38 39 #ifdef PH_NFC_CUSTOMINTEGRATION 40 #include <phNfcCustomInt.h> 41 #else 42 #include <memory.h> 43 44 /**< OSAL Message Type */ 45 #ifdef WIN32 46 //#define PH_OSALNFC_MESSAGE_BASE (WM_USER+0x3FF) 47 #define PH_OSALNFC_MESSAGE_BASE PH_LIBNFC_MESSAGE_BASE 48 #endif 49 50 /*! 51 * \ingroup grp_osal_nfc 52 * 53 * OSAL Message structure contains message specific details like 54 * message type, message specific data block details, etc. 55 */ 56 //typedef struct phOsalNfc_Message 57 //{ 58 // uint32_t eMsgType;/**< Type of the message to be posted*/ 59 // void * pMsgData;/**< Pointer to message specific data block in case any*/ 60 // uint16_t Size;/**< Size of the datablock*/ 61 //} phOsalNfc_Message_t,*pphOsalNfc_Message_t; 62 typedef phLibNfc_Message_t phOsalNfc_Message_t; 63 typedef pphLibNfc_Message_t pphOsalNfc_Message_t; 64 65 /*! 66 * \ingroup grp_osal_nfc 67 * 68 * Enum definition contains supported exception types 69 */ 70 typedef enum 71 { 72 phOsalNfc_e_NoMemory, /**<Memory allocation failed */ 73 phOsalNfc_e_PrecondFailed, /**<precondition wasn't met */ 74 phOsalNfc_e_InternalErr, /**<Unrecoverable error */ 75 phOsalNfc_e_UnrecovFirmwareErr, /**<Unrecoverable firmware error */ 76 phOsalNfc_e_DALerror, /**<Unrecoverable DAL error */ 77 phOsalNfc_e_Noerror /**<No errortype */ 78 } phOsalNfc_ExceptionType_t ; 79 80 /*! 81 * \ingroup grp_osal_nfc 82 * 83 * OSAL Exception structure containing exception type and reason. 84 */ 85 typedef struct phOsalNfc_Exception 86 { 87 phOsalNfc_ExceptionType_t eExceptionType; 88 uint16_t reason; 89 } phOsalNfc_Exception_t; 90 91 #ifdef ANDROID 92 extern phOsalNfc_Exception_t phOsalNfc_Exception; 93 #endif 94 95 /* OsalNfc Status Type */ 96 97 /** \ingroup grp_retval1 98 A new semaphore could not be created due to 99 a system error. */ 100 #define NFCSTATUS_SEMAPHORE_CREATION_ERROR (0x1010) 101 102 /** \ingroup grp_retval1 103 The given semaphore could not be released due to 104 a system error or invalid handle. */ 105 #define NFCSTATUS_SEMAPHORE_PRODUCE_ERROR (0x1011) 106 107 /** \ingroup grp_retval11 108 The given semaphore could not be consumed due to a 109 system error or invalid handle. */ 110 #define NFCSTATUS_SEMAPHORE_CONSUME_ERROR (0x1012) 111 112 113 /*! 114 * \ingroup grp_osal_nfc 115 * \brief Raises exception 116 * 117 * The program jumps out of the current execution flow, i.e. this function 118 * doesn't return. The given exception contains information on what has 119 * happened and how severe the error is. @warning This function should only be 120 * used for exceptional error situations where there is no means to recover. 121 * 122 * \param[in] eExceptiontype exception type. 123 * \param[in] reason additional reason value that gives a vendor specific reason 124 * code. 125 * 126 * \retval None 127 */ 128 void phOsalNfc_RaiseException(phOsalNfc_ExceptionType_t eExceptiontype, 129 uint16_t reason); 130 131 /*! 132 * \ingroup grp_osal_nfc 133 * \brief Output debug trace 134 * 135 * Outputs trace log of requested size as string 136 * 137 * \param[in] data Data block. 138 * \param[in] size buffer size of the data block. 139 * 140 * \retval None 141 */ 142 void phOsalNfc_DbgTrace(uint8_t data[], uint32_t size); 143 144 145 /*! 146 * \ingroup grp_osal_nfc 147 * \brief Print string 148 * 149 * Outputs given string to debug port. 150 * 151 * \param[in] pString pointer to buffer content to be displayed. 152 * 153 * \retval None 154 */ 155 void phOsalNfc_DbgString(const char *pString); 156 157 /*! 158 * \ingroup grp_osal_nfc 159 * \brief Print data buffer 160 * 161 * Outputs given string to debug port. 162 * 163 * \param[in] pString pointer to string to be displayed. 164 * \param[in] length number of bytes to be displayed. 165 * \param[in] pBuffer pointer to data bytes to be displayed. 166 * 167 * \retval None 168 */ 169 void phOsalNfc_PrintData(const char *pString, uint32_t length, uint8_t *pBuffer); 170 171 /*! 172 * \ingroup grp_osal_nfc 173 * \brief Allocates some memory 174 * 175 * \param[in] Size Size, in uint8_t, to be allocated 176 * 177 * \retval NON-NULL value: The memory was successfully allocated ; the return value points to the allocated memory location 178 * \retval NULL: The operation was not successful, certainly because of insufficient resources. 179 * 180 */ 181 extern void * phOsalNfc_GetMemory(uint32_t Size); 182 183 184 /*! 185 * \ingroup grp_osal_nfc 186 * \brief This API allows to free already allocated memory. 187 * \param[in] pMem Pointer to the memory block to deallocated 188 * \retval None 189 */ 190 void phOsalNfc_FreeMemory(void * pMem); 191 192 /*! 193 * \ingroup grp_osal_nfc 194 * \brief Compares the values stored in the source memory with the 195 * values stored in the destination memory. 196 * 197 * \param[in] src Pointer to the Source Memory 198 * \param[in] dest Pointer to the Destination Memory 199 * \param[in] n Number of bytes to be compared. 200 * 201 * \retval Zero value: The comparison was successful, 202 Both the memory areas contain the identical values. 203 * \retval Non-Zero Value: The comparison failed, both the memory 204 * areas are non-identical. 205 * 206 */ 207 int phOsalNfc_MemCompare(void *src, void *dest, unsigned int n); 208 209 #endif 210 #endif /* PHOSALNFC_H */ 211