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;
62typedef phLibNfc_Message_t phOsalNfc_Message_t;
63typedef pphLibNfc_Message_t pphOsalNfc_Message_t;
64
65/*!
66 * \ingroup grp_osal_nfc
67 *
68 * Enum definition contains  supported exception types
69  */
70typedef 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 */
85typedef struct phOsalNfc_Exception
86{
87   phOsalNfc_ExceptionType_t eExceptionType;
88   uint16_t reason;
89} phOsalNfc_Exception_t;
90
91#ifdef ANDROID
92extern 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 */
128void 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 */
142void 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 */
155void 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 */
169void phOsalNfc_PrintData(const char *pString, uint32_t length, uint8_t *pBuffer,
170        int verbosity);
171
172/*!
173 * \ingroup grp_osal_nfc
174 * \brief Allocates some memory
175 *
176 * \param[in] Size   Size, in uint8_t, to be allocated
177 *
178 * \retval NON-NULL value:  The memory was successfully allocated ; the return value points to the allocated memory location
179 * \retval NULL:            The operation was not successful, certainly because of insufficient resources.
180 *
181 */
182extern void * phOsalNfc_GetMemory(uint32_t Size);
183
184
185/*!
186 * \ingroup grp_osal_nfc
187 * \brief This API allows to free already allocated memory.
188 * \param[in] pMem  Pointer to the memory block to deallocated
189 * \retval None
190 */
191void   phOsalNfc_FreeMemory(void * pMem);
192
193/*!
194 * \ingroup grp_osal_nfc
195 * \brief Compares the values stored in the source memory with the
196 * values stored in the destination memory.
197 *
198 * \param[in] src   Pointer to the Source Memory
199 * \param[in] dest  Pointer to the Destination Memory
200 * \param[in] n     Number of bytes to be compared.
201 *
202 * \retval Zero value:        The comparison was successful,
203                    Both the memory areas contain the identical values.
204 * \retval Non-Zero Value:    The comparison failed, both the memory
205 *                  areas are non-identical.
206 *
207 */
208int phOsalNfc_MemCompare(void *src, void *dest, unsigned int n);
209
210#endif
211#endif /*  PHOSALNFC_H  */
212