/* * Copyright (C) 2010-2014 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. */ /* * OSAL header files related to memory, debug, random, semaphore and mutex * functions. */ #ifndef PHNFCCOMMON_H #define PHNFCCOMMON_H /* ************************* Include Files **************************************** */ #include <phDal4Nfc_messageQueueLib.h> #include <phNfcCompId.h> #include <phNfcStatus.h> #include <phOsalNfc_Timer.h> #include <pthread.h> #include <semaphore.h> #define FW_LIB_ROOT_DIR "/vendor/lib/" #define FW_BIN_ROOT_DIR "/vendor/firmware/" #define FW_LIB_EXTENSION ".so" #define FW_BIN_EXTENSION ".bin" /* HAL Version number (Updated as per release) */ #define NXP_MW_VERSION_MAJ (3U) #define NXP_MW_VERSION_MIN (5U) /* ***************************************************************** *********** System clock source selection configuration ******** ***************************************************************** */ #define CLK_SRC_UNDEF 0 #define CLK_SRC_XTAL 1 #define CLK_SRC_PLL 2 #define CLK_SRC_PADDIRECT 3 /*Extern crystal clock source*/ /* Use one of CLK_SRC_<value> */ #define NXP_SYS_CLK_SRC_SEL CLK_SRC_PLL /*Direct clock*/ /* ***************************************************************** *********** System clock frequency selection configuration **************** * If Clk_Src is set to PLL, make sure to set the Clk_Freq also* ***************************************************************** */ #define CLK_FREQ_UNDEF 0 #define CLK_FREQ_13MHZ 1 #define CLK_FREQ_19_2MHZ 2 #define CLK_FREQ_24MHZ 3 #define CLK_FREQ_26MHZ 4 #define CLK_FREQ_38_4MHZ 5 #define CLK_FREQ_52MHZ 6 /* Set to one of CLK_FREQ_<value> */ #define NXP_SYS_CLK_FREQ_SEL CLK_FREQ_19_2MHZ #define CLK_TO_CFG_DEF 1 #define CLK_TO_CFG_MAX 6 /* * information to configure OSAL */ typedef struct phOsalNfc_Config { uint8_t* pLogFile; /* Log File Name*/ uintptr_t dwCallbackThreadId; /* Client ID to which message is posted */ } phOsalNfc_Config_t, *pphOsalNfc_Config_t /* Pointer to #phOsalNfc_Config_t */; /* * Deferred call declaration. * This type of API is called from ClientApplication (main thread) to notify * specific callback. */ typedef void (*pphOsalNfc_DeferFuncPointer_t)(void*); /* * Deferred message specific info declaration. */ typedef struct phOsalNfc_DeferedCallInfo { pphOsalNfc_DeferFuncPointer_t pDeferedCall; /* pointer to Deferred callback */ void* pParam; /* contains timer message specific details*/ } phOsalNfc_DeferedCallInfo_t; /* * States in which a OSAL timer exist. */ typedef enum { eTimerIdle = 0, /* Indicates Initial state of timer */ eTimerRunning = 1, /* Indicate timer state when started */ eTimerStopped = 2 /* Indicates timer state when stopped */ } phOsalNfc_TimerStates_t; /* Variable representing State of timer */ /* **Timer Handle structure containing details of a timer. */ typedef struct phOsalNfc_TimerHandle { uint32_t TimerId; /* ID of the timer */ timer_t hTimerHandle; /* Handle of the timer */ /* Timer callback function to be invoked */ pphOsalNfc_TimerCallbck_t Application_callback; void* pContext; /* Parameter to be passed to the callback function */ phOsalNfc_TimerStates_t eState; /* Timer states */ /* Osal Timer message posted on User Thread */ phLibNfc_Message_t tOsalMessage; /* Deferred Call structure to Invoke Callback function */ phOsalNfc_DeferedCallInfo_t tDeferedCallInfo; /* Variables for Structure Instance and Structure Ptr */ } phOsalNfc_TimerHandle_t, *pphOsalNfc_TimerHandle_t; #endif /* PHOSALNFC_H */