1 /******************************************************************************
2  *
3  *  Copyright 2020-2022 NXP
4  *
5  *  Licensed under the Apache License, Version 2.0 (the "License");
6  *  you may not use this file except in compliance with the License.
7  *  You may obtain a copy of the License at
8  *
9  *  http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *  Unless required by applicable law or agreed to in writing, software
12  *  distributed under the License is distributed on an "AS IS" BASIS,
13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *  See the License for the specific language governing permissions and
15  *  limitations under the License.
16  *
17  ******************************************************************************/
18 #pragma once
19 
20 /* Basic type definitions */
21 #include <phNxpEsePal.h>
22 
23 /*!
24  * \brief Start of frame marker
25  */
26 #define SEND_PACKET_SOF 0x5A
27 /*!
28  * \brief ESE Poll timeout (max 2 seconds)
29  */
30 #define ESE_POLL_TIMEOUT (2 * 1000)
31 /*!
32  * \brief ESE Max Poll retry count
33  */
34 
35 #define ESE_NAD_POLLING_MAX (2000)
36 
37 /*!
38  * \brief ESE wakeup delay in case of write error retry
39  */
40 
41 #define WAKE_UP_DELAY_USECS 100
42 
43 #define GET_WAKE_UP_DELAY()                                          \
44   ((GET_CHIP_OS_VERSION() != OS_VERSION_4_0) ? (WAKE_UP_DELAY_USECS) \
45                                              : (10 * WAKE_UP_DELAY_USECS))
46 
47 /*!
48  * \brief ESE wakeup delay in case of write error retry
49  */
50 
51 #define NAD_POLLING_SCALER 1
52 
53 /*!
54  * \brief ESE wakeup delay in case of write error retry
55  */
56 #define CHAINED_PKT_SCALER 1
57 /*!
58  * \brief Magic type specific to the ESE device driver
59  */
60 #define P61_MAGIC 0xEA
61 
62 /*!
63  * \brief IOCTL number to set ESE PWR
64  */
65 #define P61_SET_PWR _IOW(P61_MAGIC, 0x01, uint64_t)
66 /*!
67  * \brief IOCTL number to set debug state
68  */
69 #define P61_SET_DBG _IOW(P61_MAGIC, 0x02, uint64_t)
70 /*!
71  * \brief IOCTL number to enable poll mode
72  */
73 #define P61_SET_POLL _IOW(P61_MAGIC, 0x03, uint64_t)
74 /*!
75  * \brief SPI Request NFCC to enable p61 power, only in param
76  *         Only for SPI
77  *         level 1 = Enable power
78  *         level 0 = Disable power
79  */
80 #define P61_SET_SPM_PWR _IOW(P61_MAGIC, 0x04, uint64_t)
81 
82 /*!
83  * \brief SPI or DWP can call this ioctl to get the current
84  *         power state of P61
85  *
86  */
87 #define P61_GET_SPM_STATUS _IOR(P61_MAGIC, 0x05, uint64_t)
88 /*!
89  * \brief IOCTL to add throughput measurement source code in device driver
90  *
91  */
92 #define P61_SET_THROUGHPUT _IOW(P61_MAGIC, 0x06, uint64_t)
93 /*!
94  * \brief IOCTL to get the ESE access
95  *
96  */
97 #define P61_GET_ESE_ACCESS _IOW(P61_MAGIC, 0x07, uint64_t)
98 /*!
99  * \brief IOCTL to set the power scheme
100  *
101  */
102 #define P61_SET_POWER_SCHEME _IOW(P61_MAGIC, 0x08, uint64_t)
103 /*!
104  * \brief This function is used to set the ESE jcop
105  *  download state.
106  */
107 #define P61_SET_DWNLD_STATUS _IOW(P61_MAGIC, 0x09, uint64_t)
108 
109 /*!
110  * \brief This function is used to set disable ESE GPIO
111  *  state On&Off
112  */
113 #define P61_INHIBIT_PWR_CNTRL _IOW(P61_MAGIC, 0x0A, uint64_t)
114 /*!
115  * \brief IOCTL to set the GPIO for the eSE to distinguish
116  *        the logical interface
117  */
118 #define ESE_SET_TRUSTED_ACCESS _IOW(P61_MAGIC, 0x0B, uint64_t)
119 
120 /*!
121  * \brief IOCTL to perform the eSE COLD_RESET  via NFC driver.
122  */
123 #define ESE_PERFORM_COLD_RESET _IOW(P61_MAGIC, 0x0C, uint64_t)
124 /*!
125  * \brief IOCTL to enable/disable GPIO/COLD reset protection.
126  */
127 #define PERFORM_RESET_PROTECTION _IOW(P61_MAGIC, 0x0D, uint64_t)
128 
129 class EseTransport {
130  public:
131   virtual void Close(void* pDevHandle) = 0;
132   virtual ESESTATUS OpenAndConfigure(pphPalEse_Config_t pConfig) = 0;
133   virtual int Read(void* pDevHandle, uint8_t* pBuffer, int nNbBytesToRead) = 0;
134   virtual int Write(void* pDevHandle, uint8_t* pBuffer,
135                     int nNbBytesToWrite) = 0;
136   virtual ESESTATUS Ioctl(phPalEse_ControlCode_t eControlCode, void* pDevHandle,
137                           long level) = 0;
~EseTransport()138   virtual ~EseTransport(){};
139 };
140