/****************************************************************************** * * Copyright 2020-2021 NXP * * 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. * ******************************************************************************/ #pragma once /* Basic type definitions */ #include /*! * \brief Start of frame marker */ #define SEND_PACKET_SOF 0x5A /*! * \brief ESE Poll timeout (max 2 seconds) */ #define ESE_POLL_TIMEOUT (2 * 1000) /*! * \brief ESE Max Poll retry count */ #define ESE_NAD_POLLING_MAX (2000) /*! * \brief ESE wakeup delay in case of write error retry */ #define WAKE_UP_DELAY_USECS 100 #define GET_WAKE_UP_DELAY() \ ((GET_CHIP_OS_VERSION() != OS_VERSION_4_0) ? (WAKE_UP_DELAY_USECS) \ : (10 * WAKE_UP_DELAY_USECS)) /*! * \brief ESE wakeup delay in case of write error retry */ #define NAD_POLLING_SCALER 1 /*! * \brief ESE wakeup delay in case of write error retry */ #define CHAINED_PKT_SCALER 1 /*! * \brief Magic type specific to the ESE device driver */ #define P61_MAGIC 0xEA /*! * \brief IOCTL number to set ESE PWR */ #define P61_SET_PWR _IOW(P61_MAGIC, 0x01, long) /*! * \brief IOCTL number to set debug state */ #define P61_SET_DBG _IOW(P61_MAGIC, 0x02, long) /*! * \brief IOCTL number to enable poll mode */ #define P61_SET_POLL _IOW(P61_MAGIC, 0x03, long) /*! * \brief SPI Request NFCC to enable p61 power, only in param * Only for SPI * level 1 = Enable power * level 0 = Disable power */ #define P61_SET_SPM_PWR _IOW(P61_MAGIC, 0x04, long) /*! * \brief SPI or DWP can call this ioctl to get the current * power state of P61 * */ #define P61_GET_SPM_STATUS _IOR(P61_MAGIC, 0x05, long) /*! * \brief IOCTL to add throughput measurement source code in device driver * */ #define P61_SET_THROUGHPUT _IOW(P61_MAGIC, 0x06, long) /*! * \brief IOCTL to get the ESE access * */ #define P61_GET_ESE_ACCESS _IOW(P61_MAGIC, 0x07, long) /*! * \brief IOCTL to set the power scheme * */ #define P61_SET_POWER_SCHEME _IOW(P61_MAGIC, 0x08, long) /*! * \brief This function is used to set the ESE jcop * download state. */ #define P61_SET_DWNLD_STATUS _IOW(P61_MAGIC, 0x09, long) /*! * \brief This function is used to set disable ESE GPIO * state On&Off */ #define P61_INHIBIT_PWR_CNTRL _IOW(P61_MAGIC, 0x0A, long) /*! * \brief IOCTL to set the GPIO for the eSE to distinguish * the logical interface */ #define ESE_SET_TRUSTED_ACCESS _IOW(P61_MAGIC, 0x0B, long) /*! * \brief IOCTL to perform the eSE COLD_RESET via NFC driver. */ #define ESE_PERFORM_COLD_RESET _IOW(P61_MAGIC, 0x0C, long) /*! * \brief IOCTL to enable/disable GPIO/COLD reset protection. */ #define PERFORM_RESET_PROTECTION _IOW(P61_MAGIC, 0x0D, long) class EseTransport { public: virtual void Close(void* pDevHandle) = 0; virtual ESESTATUS OpenAndConfigure(pphPalEse_Config_t pConfig) = 0; virtual int Read(void* pDevHandle, uint8_t* pBuffer, int nNbBytesToRead) = 0; virtual int Write(void* pDevHandle, uint8_t* pBuffer, int nNbBytesToWrite) = 0; virtual ESESTATUS Ioctl(phPalEse_ControlCode_t eControlCode, void* pDevHandle, long level) = 0; virtual ~EseTransport(){}; };