/*
* 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 phOsalNfc.h
* \brief OSAL Implementation.
*
* Project: NFC-FRI 1.1
* $Date: Fri Jun 26 14:41:31 2009 $
* $Author: ing04880 $
* $Revision: 1.21 $
* $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 $
*
*/
#ifndef PHOSALNFC_H
#define PHOSALNFC_H
/** \defgroup grp_osal_nfc OSAL Component
*
*\note: API listed here encompasses Operating System Abstraction Layer interfaces required to be mapped to underlying OS platforms.
*
*/
#include <phNfcTypes.h>
#ifdef PH_NFC_CUSTOMINTEGRATION
#include <phNfcCustomInt.h>
#else
#include <memory.h>
/**< OSAL Message Type */
#ifdef WIN32
//#define PH_OSALNFC_MESSAGE_BASE (WM_USER+0x3FF)
#define PH_OSALNFC_MESSAGE_BASE PH_LIBNFC_MESSAGE_BASE
#endif
/*!
* \ingroup grp_osal_nfc
*
* OSAL Message structure contains message specific details like
* message type, message specific data block details, etc.
*/
//typedef struct phOsalNfc_Message
//{
// uint32_t eMsgType;/**< Type of the message to be posted*/
// void * pMsgData;/**< Pointer to message specific data block in case any*/
// uint16_t Size;/**< Size of the datablock*/
//} phOsalNfc_Message_t,*pphOsalNfc_Message_t;
typedef phLibNfc_Message_t phOsalNfc_Message_t;
typedef pphLibNfc_Message_t pphOsalNfc_Message_t;
/*!
* \ingroup grp_osal_nfc
*
* Enum definition contains supported exception types
*/
typedef enum
{
phOsalNfc_e_NoMemory, /**<Memory allocation failed */
phOsalNfc_e_PrecondFailed, /**<precondition wasn't met */
phOsalNfc_e_InternalErr, /**<Unrecoverable error */
phOsalNfc_e_UnrecovFirmwareErr, /**<Unrecoverable firmware error */
phOsalNfc_e_DALerror, /**<Unrecoverable DAL error */
phOsalNfc_e_Noerror /**<No errortype */
} phOsalNfc_ExceptionType_t ;
/*!
* \ingroup grp_osal_nfc
*
* OSAL Exception structure containing exception type and reason.
*/
typedef struct phOsalNfc_Exception
{
phOsalNfc_ExceptionType_t eExceptionType;
uint16_t reason;
} phOsalNfc_Exception_t;
#ifdef ANDROID
extern phOsalNfc_Exception_t phOsalNfc_Exception;
#endif
/* OsalNfc Status Type */
/** \ingroup grp_retval1
A new semaphore could not be created due to
a system error. */
#define NFCSTATUS_SEMAPHORE_CREATION_ERROR (0x1010)
/** \ingroup grp_retval1
The given semaphore could not be released due to
a system error or invalid handle. */
#define NFCSTATUS_SEMAPHORE_PRODUCE_ERROR (0x1011)
/** \ingroup grp_retval11
The given semaphore could not be consumed due to a
system error or invalid handle. */
#define NFCSTATUS_SEMAPHORE_CONSUME_ERROR (0x1012)
/*!
* \ingroup grp_osal_nfc
* \brief Raises exception
*
* The program jumps out of the current execution flow, i.e. this function
* doesn't return. The given exception contains information on what has
* happened and how severe the error is. @warning This function should only be
* used for exceptional error situations where there is no means to recover.
*
* \param[in] eExceptiontype exception type.
* \param[in] reason additional reason value that gives a vendor specific reason
* code.
*
* \retval None
*/
void phOsalNfc_RaiseException(phOsalNfc_ExceptionType_t eExceptiontype,
uint16_t reason);
/*!
* \ingroup grp_osal_nfc
* \brief Output debug trace
*
* Outputs trace log of requested size as string
*
* \param[in] data Data block.
* \param[in] size buffer size of the data block.
*
* \retval None
*/
void phOsalNfc_DbgTrace(uint8_t data[], uint32_t size);
/*!
* \ingroup grp_osal_nfc
* \brief Print string
*
* Outputs given string to debug port.
*
* \param[in] pString pointer to buffer content to be displayed.
*
* \retval None
*/
void phOsalNfc_DbgString(const char *pString);
/*!
* \ingroup grp_osal_nfc
* \brief Print data buffer
*
* Outputs given string to debug port.
*
* \param[in] pString pointer to string to be displayed.
* \param[in] length number of bytes to be displayed.
* \param[in] pBuffer pointer to data bytes to be displayed.
*
* \retval None
*/
void phOsalNfc_PrintData(const char *pString, uint32_t length, uint8_t *pBuffer);
/*!
* \ingroup grp_osal_nfc
* \brief Allocates some memory
*
* \param[in] Size Size, in uint8_t, to be allocated
*
* \retval NON-NULL value: The memory was successfully allocated ; the return value points to the allocated memory location
* \retval NULL: The operation was not successful, certainly because of insufficient resources.
*
*/
extern void * phOsalNfc_GetMemory(uint32_t Size);
/*!
* \ingroup grp_osal_nfc
* \brief This API allows to free already allocated memory.
* \param[in] pMem Pointer to the memory block to deallocated
* \retval None
*/
void phOsalNfc_FreeMemory(void * pMem);
/*!
* \ingroup grp_osal_nfc
* \brief Compares the values stored in the source memory with the
* values stored in the destination memory.
*
* \param[in] src Pointer to the Source Memory
* \param[in] dest Pointer to the Destination Memory
* \param[in] n Number of bytes to be compared.
*
* \retval Zero value: The comparison was successful,
Both the memory areas contain the identical values.
* \retval Non-Zero Value: The comparison failed, both the memory
* areas are non-identical.
*
*/
int phOsalNfc_MemCompare(void *src, void *dest, unsigned int n);
#endif
#endif /* PHOSALNFC_H */