rfal_nfc.c 82 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118
  1. /**
  2. ******************************************************************************
  3. *
  4. * COPYRIGHT(c) 2020 STMicroelectronics
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. * 1. Redistributions of source code must retain the above copyright notice,
  9. * this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright notice,
  11. * this list of conditions and the following disclaimer in the documentation
  12. * and/or other materials provided with the distribution.
  13. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  14. * may be used to endorse or promote products derived from this software
  15. * without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  18. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  20. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  21. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  23. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  24. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  25. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  26. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. *
  28. ******************************************************************************
  29. */
  30. /*! \file rfal_nfc.c
  31. *
  32. * \author Gustavo Patricio
  33. *
  34. * \brief RFAL NFC device
  35. *
  36. * This module provides the required features to behave as an NFC Poller
  37. * or Listener device. It grants an easy to use interface for the following
  38. * activities: Technology Detection, Collision Resollution, Activation,
  39. * Data Exchange, and Deactivation
  40. *
  41. * This layer is influenced by (but not fully aligned with) the NFC Forum
  42. * specifications, in particular: Activity 2.0 and NCI 2.0
  43. *
  44. */
  45. /*
  46. ******************************************************************************
  47. * INCLUDES
  48. ******************************************************************************
  49. */
  50. #include "rfal_nfc.h"
  51. #include "utils.h"
  52. #include "rfal_analogConfig.h"
  53. /*
  54. ******************************************************************************
  55. * GLOBAL DEFINES
  56. ******************************************************************************
  57. */
  58. #define RFAL_NFC_MAX_DEVICES 5U /* Max number of devices supported */
  59. /*
  60. ******************************************************************************
  61. * GLOBAL MACROS
  62. ******************************************************************************
  63. */
  64. #define rfalNfcNfcNotify(st) \
  65. if(gNfcDev.disc.notifyCb != NULL) gNfcDev.disc.notifyCb(st)
  66. /*
  67. ******************************************************************************
  68. * GLOBAL TYPES
  69. ******************************************************************************
  70. */
  71. /*! Buffer union, only one interface is used at a time */
  72. typedef union { /* PRQA S 0750 # MISRA 19.2 - Members of the union will not be used concurrently, only one interface at a time */
  73. rfalIsoDepBufFormat isoDepBuf; /*!< ISO-DEP buffer format (with header/prologue) */
  74. rfalNfcDepBufFormat nfcDepBuf; /*!< NFC-DEP buffer format (with header/prologue) */
  75. } rfalNfcTmpBuffer;
  76. typedef struct {
  77. rfalNfcState state; /* Main state */
  78. uint16_t techsFound; /* Technologies found bitmask */
  79. uint16_t techs2do; /* Technologies still to be performed */
  80. rfalBitRate ap2pBR; /* Bit rate to poll for AP2P */
  81. uint8_t selDevIdx; /* Selected device index */
  82. rfalNfcDevice* activeDev; /* Active device pointer */
  83. rfalNfcDiscoverParam disc; /* Discovery parameters */
  84. rfalNfcDevice devList[RFAL_NFC_MAX_DEVICES]; /*!< Location of device list */
  85. uint8_t devCnt; /* Decices found counter */
  86. uint32_t discTmr; /* Discovery Total duration timer */
  87. ReturnCode dataExErr; /* Last Data Exchange error */
  88. bool discRestart; /* Restart discover after deactivation flag */
  89. bool isRxChaining; /* Flag indicating Other device is chaining */
  90. uint32_t lmMask; /* Listen Mode mask */
  91. bool isTechInit; /* Flag indicating technology has been set */
  92. bool isOperOngoing; /* Flag indicating opration is ongoing */
  93. rfalNfcBuffer txBuf; /* Tx buffer for Data Exchange */
  94. rfalNfcBuffer rxBuf; /* Rx buffer for Data Exchange */
  95. uint16_t rxLen; /* Length of received data on Data Exchange */
  96. #if RFAL_FEATURE_NFC_DEP || RFAL_FEATURE_ISO_DEP
  97. rfalNfcTmpBuffer tmpBuf; /* Tmp buffer for Data Exchange */
  98. #endif /* RFAL_FEATURE_NFC_DEP || RFAL_FEATURE_ISO_DEP */
  99. } rfalNfc;
  100. /*
  101. ******************************************************************************
  102. * LOCAL VARIABLES
  103. ******************************************************************************
  104. */
  105. #ifdef RFAL_TEST_MODE
  106. rfalNfc gNfcDev;
  107. #else /* RFAL_TEST_MODE */
  108. static rfalNfc gNfcDev;
  109. #endif /* RFAL_TEST_MODE */
  110. /*
  111. ******************************************************************************
  112. * LOCAL FUNCTION PROTOTYPES
  113. ******************************************************************************
  114. */
  115. static ReturnCode rfalNfcPollTechDetetection(void);
  116. static ReturnCode rfalNfcPollCollResolution(void);
  117. static ReturnCode rfalNfcPollActivation(uint8_t devIt);
  118. static ReturnCode rfalNfcDeactivation(void);
  119. #if RFAL_FEATURE_NFC_DEP
  120. static ReturnCode rfalNfcNfcDepActivate(
  121. rfalNfcDevice* device,
  122. rfalNfcDepCommMode commMode,
  123. const uint8_t* atrReq,
  124. uint16_t atrReqLen);
  125. #endif /* RFAL_FEATURE_NFC_DEP */
  126. #if RFAL_FEATURE_LISTEN_MODE
  127. static ReturnCode rfalNfcListenActivation(void);
  128. #endif /* RFAL_FEATURE_LISTEN_MODE*/
  129. /*******************************************************************************/
  130. ReturnCode rfalNfcInitialize(void) {
  131. ReturnCode err;
  132. gNfcDev.state = RFAL_NFC_STATE_NOTINIT;
  133. rfalAnalogConfigInitialize(); /* Initialize RFAL's Analog Configs */
  134. EXIT_ON_ERR(err, rfalInitialize()); /* Initialize RFAL */
  135. gNfcDev.state = RFAL_NFC_STATE_IDLE; /* Go to initialized */
  136. return ERR_NONE;
  137. }
  138. /*******************************************************************************/
  139. ReturnCode rfalNfcDiscover(const rfalNfcDiscoverParam* disParams) {
  140. /* Check if initialization has been performed */
  141. if(gNfcDev.state != RFAL_NFC_STATE_IDLE) {
  142. return ERR_WRONG_STATE;
  143. }
  144. /* Check valid parameters */
  145. if((disParams == NULL) || (disParams->devLimit > RFAL_NFC_MAX_DEVICES) ||
  146. (disParams->devLimit == 0U) ||
  147. ((disParams->maxBR > RFAL_BR_1695) && (disParams->maxBR != RFAL_BR_KEEP)) ||
  148. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_F) != 0U) &&
  149. (disParams->nfcfBR != RFAL_BR_212) && (disParams->nfcfBR != RFAL_BR_424)) ||
  150. ((((disParams->techs2Find & RFAL_NFC_POLL_TECH_AP2P) != 0U) &&
  151. (disParams->ap2pBR > RFAL_BR_424)) ||
  152. (disParams->GBLen > RFAL_NFCDEP_GB_MAX_LEN))) {
  153. return ERR_PARAM;
  154. }
  155. if((((disParams->techs2Find & RFAL_NFC_POLL_TECH_A) != 0U) && !((bool)RFAL_FEATURE_NFCA)) ||
  156. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_B) != 0U) && !((bool)RFAL_FEATURE_NFCB)) ||
  157. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_F) != 0U) && !((bool)RFAL_FEATURE_NFCF)) ||
  158. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_V) != 0U) && !((bool)RFAL_FEATURE_NFCV)) ||
  159. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_ST25TB) != 0U) &&
  160. !((bool)RFAL_FEATURE_ST25TB)) ||
  161. (((disParams->techs2Find & RFAL_NFC_POLL_TECH_AP2P) != 0U) &&
  162. !((bool)RFAL_FEATURE_NFC_DEP)) ||
  163. (((disParams->techs2Find & RFAL_NFC_LISTEN_TECH_A) != 0U) && !((bool)RFAL_FEATURE_NFCA)) ||
  164. (((disParams->techs2Find & RFAL_NFC_LISTEN_TECH_B) != 0U) && !((bool)RFAL_FEATURE_NFCB)) ||
  165. (((disParams->techs2Find & RFAL_NFC_LISTEN_TECH_F) != 0U) && !((bool)RFAL_FEATURE_NFCF)) ||
  166. (((disParams->techs2Find & RFAL_NFC_LISTEN_TECH_AP2P) != 0U) &&
  167. !((bool)RFAL_FEATURE_NFC_DEP))) {
  168. return ERR_DISABLED; /* PRQA S 2880 # MISRA 2.1 - Unreachable code due to configuration option being set/unset */
  169. }
  170. /* Initialize context for discovery */
  171. gNfcDev.activeDev = NULL;
  172. gNfcDev.techsFound = RFAL_NFC_TECH_NONE;
  173. gNfcDev.devCnt = 0;
  174. gNfcDev.discRestart = true;
  175. gNfcDev.isTechInit = false;
  176. gNfcDev.disc = *disParams;
  177. /* Calculate Listen Mask */
  178. gNfcDev.lmMask = 0U;
  179. gNfcDev.lmMask |=
  180. (((gNfcDev.disc.techs2Find & RFAL_NFC_LISTEN_TECH_A) != 0U) ? RFAL_LM_MASK_NFCA : 0U);
  181. gNfcDev.lmMask |=
  182. (((gNfcDev.disc.techs2Find & RFAL_NFC_LISTEN_TECH_B) != 0U) ? RFAL_LM_MASK_NFCB : 0U);
  183. gNfcDev.lmMask |=
  184. (((gNfcDev.disc.techs2Find & RFAL_NFC_LISTEN_TECH_F) != 0U) ? RFAL_LM_MASK_NFCF : 0U);
  185. gNfcDev.lmMask |=
  186. (((gNfcDev.disc.techs2Find & RFAL_NFC_LISTEN_TECH_AP2P) != 0U) ? RFAL_LM_MASK_ACTIVE_P2P :
  187. 0U);
  188. #if !RFAL_FEATURE_LISTEN_MODE
  189. /* Check if Listen Mode is supported/Enabled */
  190. if(gNfcDev.lmMask != 0U) {
  191. return ERR_DISABLED;
  192. }
  193. #endif
  194. gNfcDev.state = RFAL_NFC_STATE_START_DISCOVERY;
  195. return ERR_NONE;
  196. }
  197. /*******************************************************************************/
  198. ReturnCode rfalNfcDeactivate(bool discovery) {
  199. /* Check for valid state */
  200. if(gNfcDev.state <= RFAL_NFC_STATE_IDLE) {
  201. return ERR_WRONG_STATE;
  202. }
  203. /* Check if discovery is to continue afterwards */
  204. if((discovery == true) && (gNfcDev.disc.techs2Find != RFAL_NFC_TECH_NONE)) {
  205. /* If so let the state machine continue*/
  206. gNfcDev.discRestart = discovery;
  207. gNfcDev.state = RFAL_NFC_STATE_DEACTIVATION;
  208. } else {
  209. /* Otherwise deactivate immediately and go to IDLE */
  210. rfalNfcDeactivation();
  211. gNfcDev.state = RFAL_NFC_STATE_IDLE;
  212. }
  213. return ERR_NONE;
  214. }
  215. /*******************************************************************************/
  216. ReturnCode rfalNfcSelect(uint8_t devIdx) {
  217. /* Check for valid state */
  218. if(gNfcDev.state != RFAL_NFC_STATE_POLL_SELECT) {
  219. return ERR_WRONG_STATE;
  220. }
  221. gNfcDev.selDevIdx = devIdx;
  222. gNfcDev.state = RFAL_NFC_STATE_POLL_ACTIVATION;
  223. return ERR_NONE;
  224. }
  225. /*******************************************************************************/
  226. rfalNfcState rfalNfcGetState(void) {
  227. return gNfcDev.state;
  228. }
  229. /*******************************************************************************/
  230. ReturnCode rfalNfcGetDevicesFound(rfalNfcDevice** devList, uint8_t* devCnt) {
  231. /* Check for valid state */
  232. if(gNfcDev.state < RFAL_NFC_STATE_POLL_SELECT) {
  233. return ERR_WRONG_STATE;
  234. }
  235. /* Check valid parameters */
  236. if((devList == NULL) || (devCnt == NULL)) {
  237. return ERR_PARAM;
  238. }
  239. *devCnt = gNfcDev.devCnt;
  240. *devList = gNfcDev.devList;
  241. return ERR_NONE;
  242. }
  243. /*******************************************************************************/
  244. ReturnCode rfalNfcGetActiveDevice(rfalNfcDevice** dev) {
  245. /* Check for valid state */
  246. if(gNfcDev.state < RFAL_NFC_STATE_ACTIVATED) {
  247. return ERR_WRONG_STATE;
  248. }
  249. /* Check valid parameter */
  250. if(dev == NULL) {
  251. return ERR_PARAM;
  252. }
  253. /* Check for valid state */
  254. if((gNfcDev.devCnt == 0U) || (gNfcDev.activeDev == NULL)) {
  255. return ERR_REQUEST;
  256. }
  257. *dev = gNfcDev.activeDev;
  258. return ERR_NONE;
  259. }
  260. /*******************************************************************************/
  261. void rfalNfcWorker(void) {
  262. ReturnCode err;
  263. rfalWorker(); /* Execute RFAL process */
  264. switch(gNfcDev.state) {
  265. /*******************************************************************************/
  266. case RFAL_NFC_STATE_NOTINIT:
  267. case RFAL_NFC_STATE_IDLE:
  268. break;
  269. /*******************************************************************************/
  270. case RFAL_NFC_STATE_START_DISCOVERY:
  271. /* Initialize context for discovery cycle */
  272. gNfcDev.devCnt = 0;
  273. gNfcDev.selDevIdx = 0;
  274. gNfcDev.techsFound = RFAL_NFC_TECH_NONE;
  275. gNfcDev.techs2do = gNfcDev.disc.techs2Find;
  276. gNfcDev.state = RFAL_NFC_STATE_POLL_TECHDETECT;
  277. #if RFAL_FEATURE_WAKEUP_MODE
  278. /* Check if Low power Wake-Up is to be performed */
  279. if(gNfcDev.disc.wakeupEnabled) {
  280. /* Initialize Low power Wake-up mode and wait */
  281. err = rfalWakeUpModeStart(
  282. (gNfcDev.disc.wakeupConfigDefault ? NULL : &gNfcDev.disc.wakeupConfig));
  283. if(err == ERR_NONE) {
  284. gNfcDev.state = RFAL_NFC_STATE_WAKEUP_MODE;
  285. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller that WU was started */
  286. }
  287. }
  288. #endif /* RFAL_FEATURE_WAKEUP_MODE */
  289. break;
  290. /*******************************************************************************/
  291. case RFAL_NFC_STATE_WAKEUP_MODE:
  292. #if RFAL_FEATURE_WAKEUP_MODE
  293. /* Check if the Wake-up mode has woke */
  294. if(rfalWakeUpModeHasWoke()) {
  295. rfalWakeUpModeStop(); /* Disable Wake-up mode */
  296. gNfcDev.state = RFAL_NFC_STATE_POLL_TECHDETECT; /* Go to Technology detection */
  297. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller that WU has woke */
  298. }
  299. #endif /* RFAL_FEATURE_WAKEUP_MODE */
  300. break;
  301. /*******************************************************************************/
  302. case RFAL_NFC_STATE_POLL_TECHDETECT:
  303. /* Start total duration timer */
  304. platformTimerDestroy(gNfcDev.discTmr);
  305. gNfcDev.discTmr = (uint32_t)platformTimerCreate(gNfcDev.disc.totalDuration);
  306. err =
  307. rfalNfcPollTechDetetection(); /* Perform Technology Detection */
  308. if(err != ERR_BUSY) /* Wait until all technologies are performed */
  309. {
  310. if((err != ERR_NONE) ||
  311. (gNfcDev.techsFound ==
  312. RFAL_NFC_TECH_NONE)) /* Check if any error occurred or no techs were found */
  313. {
  314. rfalFieldOff();
  315. gNfcDev.state =
  316. RFAL_NFC_STATE_LISTEN_TECHDETECT; /* Nothing found as poller, go to listener */
  317. break;
  318. }
  319. gNfcDev.techs2do =
  320. gNfcDev.techsFound; /* Store the found technologies for collision resolution */
  321. gNfcDev.state =
  322. RFAL_NFC_STATE_POLL_COLAVOIDANCE; /* One or more devices found, go to Collision Avoidance */
  323. }
  324. break;
  325. /*******************************************************************************/
  326. case RFAL_NFC_STATE_POLL_COLAVOIDANCE:
  327. err =
  328. rfalNfcPollCollResolution(); /* Resolve any eventual collision */
  329. if(err != ERR_BUSY) /* Wait until all technologies are performed */
  330. {
  331. if((err != ERR_NONE) ||
  332. (gNfcDev.devCnt == 0U)) /* Check if any error occurred or no devices were found */
  333. {
  334. gNfcDev.state = RFAL_NFC_STATE_DEACTIVATION;
  335. break; /* Unable to retrieve any device, restart loop */
  336. }
  337. /* Check if more than one device has been found */
  338. if(gNfcDev.devCnt > 1U) {
  339. /* If more than one device was found inform upper layer to choose which one to activate */
  340. if(gNfcDev.disc.notifyCb != NULL) {
  341. gNfcDev.state = RFAL_NFC_STATE_POLL_SELECT;
  342. gNfcDev.disc.notifyCb(gNfcDev.state);
  343. break;
  344. }
  345. }
  346. /* If only one device or no callback has been set, activate the first device found */
  347. gNfcDev.selDevIdx = 0U;
  348. gNfcDev.state = RFAL_NFC_STATE_POLL_ACTIVATION;
  349. }
  350. break;
  351. /*******************************************************************************/
  352. case RFAL_NFC_STATE_POLL_ACTIVATION:
  353. err = rfalNfcPollActivation(gNfcDev.selDevIdx);
  354. if(err != ERR_BUSY) /* Wait until all Activation is complete */
  355. {
  356. if(err != ERR_NONE) /* Activation failed selected device */
  357. {
  358. gNfcDev.state =
  359. RFAL_NFC_STATE_DEACTIVATION; /* If Activation failed, restart loop */
  360. break;
  361. }
  362. gNfcDev.state = RFAL_NFC_STATE_ACTIVATED; /* Device has been properly activated */
  363. rfalNfcNfcNotify(
  364. gNfcDev.state); /* Inform upper layer that a device has been activated */
  365. }
  366. break;
  367. /*******************************************************************************/
  368. case RFAL_NFC_STATE_DATAEXCHANGE:
  369. rfalNfcDataExchangeGetStatus(); /* Run the internal state machine */
  370. if(gNfcDev.dataExErr != ERR_BUSY) /* If Dataexchange has terminated */
  371. {
  372. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE_DONE; /* Go to done state */
  373. rfalNfcNfcNotify(gNfcDev.state); /* And notify caller */
  374. }
  375. if(gNfcDev.dataExErr == ERR_SLEEP_REQ) /* Check if Listen mode has to go to Sleep */
  376. {
  377. gNfcDev.state = RFAL_NFC_STATE_LISTEN_SLEEP; /* Go to Listen Sleep state */
  378. rfalNfcNfcNotify(gNfcDev.state); /* And notify caller */
  379. }
  380. break;
  381. /*******************************************************************************/
  382. case RFAL_NFC_STATE_DEACTIVATION:
  383. rfalNfcDeactivation(); /* Deactivate current device */
  384. gNfcDev.state =
  385. ((gNfcDev.discRestart) ? RFAL_NFC_STATE_START_DISCOVERY : RFAL_NFC_STATE_IDLE);
  386. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller */
  387. break;
  388. /*******************************************************************************/
  389. case RFAL_NFC_STATE_LISTEN_TECHDETECT:
  390. if(platformTimerIsExpired(gNfcDev.discTmr)) {
  391. #if RFAL_FEATURE_LISTEN_MODE
  392. rfalListenStop();
  393. #else
  394. rfalFieldOff();
  395. #endif /* RFAL_FEATURE_LISTEN_MODE */
  396. gNfcDev.state = RFAL_NFC_STATE_START_DISCOVERY; /* Restart the discovery loop */
  397. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller */
  398. break;
  399. }
  400. #if RFAL_FEATURE_LISTEN_MODE
  401. if(gNfcDev.lmMask != 0U) /* Check if configured to perform Listen mode */
  402. {
  403. err = rfalListenStart(
  404. gNfcDev.lmMask,
  405. &gNfcDev.disc.lmConfigPA,
  406. NULL,
  407. &gNfcDev.disc.lmConfigPF,
  408. (uint8_t*)&gNfcDev.rxBuf.rfBuf,
  409. (uint16_t)rfalConvBytesToBits(sizeof(gNfcDev.rxBuf.rfBuf)),
  410. &gNfcDev.rxLen);
  411. if(err == ERR_NONE) {
  412. gNfcDev.state =
  413. RFAL_NFC_STATE_LISTEN_COLAVOIDANCE; /* Wait for listen mode to be activated */
  414. }
  415. }
  416. break;
  417. /*******************************************************************************/
  418. case RFAL_NFC_STATE_LISTEN_COLAVOIDANCE:
  419. if(platformTimerIsExpired(
  420. gNfcDev.discTmr)) /* Check if the total duration has been reached */
  421. {
  422. rfalListenStop();
  423. gNfcDev.state = RFAL_NFC_STATE_START_DISCOVERY; /* Restart the discovery loop */
  424. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller */
  425. break;
  426. }
  427. /* Check for external field */
  428. if(rfalListenGetState(NULL, NULL) >= RFAL_LM_STATE_IDLE) {
  429. gNfcDev.state =
  430. RFAL_NFC_STATE_LISTEN_ACTIVATION; /* Wait for listen mode to be activated */
  431. }
  432. break;
  433. /*******************************************************************************/
  434. case RFAL_NFC_STATE_LISTEN_ACTIVATION:
  435. case RFAL_NFC_STATE_LISTEN_SLEEP:
  436. err = rfalNfcListenActivation();
  437. if(err != ERR_BUSY) {
  438. if(err == ERR_NONE) {
  439. gNfcDev.activeDev =
  440. gNfcDev.devList; /* Assign the active device to be used further on */
  441. gNfcDev.devCnt++;
  442. gNfcDev.state = RFAL_NFC_STATE_ACTIVATED; /* Device has been properly activated */
  443. rfalNfcNfcNotify(
  444. gNfcDev.state); /* Inform upper layer that a device has been activated */
  445. } else {
  446. rfalListenStop();
  447. gNfcDev.state = RFAL_NFC_STATE_START_DISCOVERY; /* Restart the discovery loop */
  448. rfalNfcNfcNotify(gNfcDev.state); /* Notify caller */
  449. }
  450. }
  451. #endif /* RFAL_FEATURE_LISTEN_MODE */
  452. break;
  453. /*******************************************************************************/
  454. case RFAL_NFC_STATE_ACTIVATED:
  455. case RFAL_NFC_STATE_POLL_SELECT:
  456. case RFAL_NFC_STATE_DATAEXCHANGE_DONE:
  457. default:
  458. return;
  459. }
  460. }
  461. /*******************************************************************************/
  462. ReturnCode rfalNfcDataExchangeStart(
  463. uint8_t* txData,
  464. uint16_t txDataLen,
  465. uint8_t** rxData,
  466. uint16_t** rvdLen,
  467. uint32_t fwt,
  468. uint32_t flags) {
  469. ReturnCode err;
  470. rfalTransceiveContext ctx;
  471. /*******************************************************************************/
  472. /* The Data Exchange is divided in two different moments, the trigger/Start of *
  473. * the transfer followed by the check until its completion */
  474. if((gNfcDev.state >= RFAL_NFC_STATE_ACTIVATED) && (gNfcDev.activeDev != NULL)) {
  475. /*******************************************************************************/
  476. /* In Listen mode is the Poller that initiates the communicatation */
  477. /* Assign output parameters and rfalNfcDataExchangeGetStatus will return */
  478. /* incoming data from Poller/Initiator */
  479. if((gNfcDev.state == RFAL_NFC_STATE_ACTIVATED) &&
  480. rfalNfcIsRemDevPoller(gNfcDev.activeDev->type)) {
  481. if(txDataLen > 0U) {
  482. return ERR_WRONG_STATE;
  483. }
  484. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  485. *rxData = (uint8_t*)( (gNfcDev.activeDev->rfInterface == RFAL_NFC_INTERFACE_ISODEP) ? gNfcDev.rxBuf.isoDepBuf.apdu :
  486. ((gNfcDev.activeDev->rfInterface == RFAL_NFC_INTERFACE_NFCDEP) ? gNfcDev.rxBuf.nfcDepBuf.pdu : gNfcDev.rxBuf.rfBuf));
  487. if(gNfcDev.disc.activate_after_sak) {
  488. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE_DONE;
  489. }
  490. return ERR_NONE;
  491. }
  492. /*******************************************************************************/
  493. switch(gNfcDev.activeDev
  494. ->rfInterface) /* Check which RF interface shall be used/has been activated */
  495. {
  496. /*******************************************************************************/
  497. case RFAL_NFC_INTERFACE_RF:
  498. rfalCreateByteFlagsTxRxContext(
  499. ctx,
  500. (uint8_t*)txData,
  501. txDataLen,
  502. gNfcDev.rxBuf.rfBuf,
  503. sizeof(gNfcDev.rxBuf.rfBuf),
  504. &gNfcDev.rxLen,
  505. flags,
  506. fwt);
  507. if(flags == RFAL_TXRX_FLAGS_RAW) {
  508. ctx.txBufLen = txDataLen;
  509. }
  510. *rxData = (uint8_t*)gNfcDev.rxBuf.rfBuf;
  511. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  512. err = rfalStartTransceive(&ctx);
  513. break;
  514. #if RFAL_FEATURE_ISO_DEP
  515. /*******************************************************************************/
  516. case RFAL_NFC_INTERFACE_ISODEP: {
  517. rfalIsoDepApduTxRxParam isoDepTxRx;
  518. if(txDataLen > sizeof(gNfcDev.txBuf.isoDepBuf.apdu)) {
  519. return ERR_NOMEM;
  520. }
  521. if(txDataLen > 0U) {
  522. ST_MEMCPY((uint8_t*)gNfcDev.txBuf.isoDepBuf.apdu, txData, txDataLen);
  523. }
  524. isoDepTxRx.DID = RFAL_ISODEP_NO_DID;
  525. isoDepTxRx.ourFSx = RFAL_ISODEP_FSX_KEEP;
  526. isoDepTxRx.FSx = gNfcDev.activeDev->proto.isoDep.info.FSx;
  527. isoDepTxRx.dFWT = gNfcDev.activeDev->proto.isoDep.info.dFWT;
  528. isoDepTxRx.FWT = gNfcDev.activeDev->proto.isoDep.info.FWT;
  529. isoDepTxRx.txBuf = &gNfcDev.txBuf.isoDepBuf;
  530. isoDepTxRx.txBufLen = txDataLen;
  531. isoDepTxRx.rxBuf = &gNfcDev.rxBuf.isoDepBuf;
  532. isoDepTxRx.rxLen = &gNfcDev.rxLen;
  533. isoDepTxRx.tmpBuf = &gNfcDev.tmpBuf.isoDepBuf;
  534. *rxData = (uint8_t*)gNfcDev.rxBuf.isoDepBuf.apdu;
  535. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  536. /*******************************************************************************/
  537. /* Trigger a RFAL ISO-DEP Transceive */
  538. err = rfalIsoDepStartApduTransceive(isoDepTxRx);
  539. break;
  540. }
  541. #endif /* RFAL_FEATURE_ISO_DEP */
  542. #if RFAL_FEATURE_NFC_DEP
  543. /*******************************************************************************/
  544. case RFAL_NFC_INTERFACE_NFCDEP: {
  545. rfalNfcDepPduTxRxParam nfcDepTxRx;
  546. if(txDataLen > sizeof(gNfcDev.txBuf.nfcDepBuf.pdu)) {
  547. return ERR_NOMEM;
  548. }
  549. if(txDataLen > 0U) {
  550. ST_MEMCPY((uint8_t*)gNfcDev.txBuf.nfcDepBuf.pdu, txData, txDataLen);
  551. }
  552. nfcDepTxRx.DID = RFAL_NFCDEP_DID_KEEP;
  553. nfcDepTxRx.FSx =
  554. rfalNfcIsRemDevListener(gNfcDev.activeDev->type) ?
  555. rfalNfcDepLR2FS((uint8_t)rfalNfcDepPP2LR(
  556. gNfcDev.activeDev->proto.nfcDep.activation.Target.ATR_RES.PPt)) :
  557. rfalNfcDepLR2FS((uint8_t)rfalNfcDepPP2LR(
  558. gNfcDev.activeDev->proto.nfcDep.activation.Initiator.ATR_REQ.PPi));
  559. nfcDepTxRx.dFWT = gNfcDev.activeDev->proto.nfcDep.info.dFWT;
  560. nfcDepTxRx.FWT = gNfcDev.activeDev->proto.nfcDep.info.FWT;
  561. nfcDepTxRx.txBuf = &gNfcDev.txBuf.nfcDepBuf;
  562. nfcDepTxRx.txBufLen = txDataLen;
  563. nfcDepTxRx.rxBuf = &gNfcDev.rxBuf.nfcDepBuf;
  564. nfcDepTxRx.rxLen = &gNfcDev.rxLen;
  565. nfcDepTxRx.tmpBuf = &gNfcDev.tmpBuf.nfcDepBuf;
  566. *rxData = (uint8_t*)gNfcDev.rxBuf.nfcDepBuf.pdu;
  567. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  568. /*******************************************************************************/
  569. /* Trigger a RFAL NFC-DEP Transceive */
  570. err = rfalNfcDepStartPduTransceive(nfcDepTxRx);
  571. break;
  572. }
  573. #endif /* RFAL_FEATURE_NFC_DEP */
  574. /*******************************************************************************/
  575. default:
  576. err = ERR_PARAM;
  577. break;
  578. }
  579. /* If a transceive has succesfully started flag Data Exchange as ongoing */
  580. if(err == ERR_NONE) {
  581. gNfcDev.dataExErr = ERR_BUSY;
  582. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE;
  583. }
  584. return err;
  585. }
  586. return ERR_WRONG_STATE;
  587. }
  588. ReturnCode rfalNfcDataExchangeCustomStart(
  589. uint8_t* txData,
  590. uint16_t txDataLen,
  591. uint8_t** rxData,
  592. uint16_t** rvdLen,
  593. uint32_t fwt,
  594. uint32_t flags) {
  595. ReturnCode err;
  596. rfalTransceiveContext ctx;
  597. /*******************************************************************************/
  598. /* The Data Exchange is divided in two different moments, the trigger/Start of *
  599. * the transfer followed by the check until its completion */
  600. if((gNfcDev.state >= RFAL_NFC_STATE_ACTIVATED) && (gNfcDev.activeDev != NULL)) {
  601. /*******************************************************************************/
  602. /* In Listen mode is the Poller that initiates the communicatation */
  603. /* Assign output parameters and rfalNfcDataExchangeGetStatus will return */
  604. /* incoming data from Poller/Initiator */
  605. if((gNfcDev.state == RFAL_NFC_STATE_ACTIVATED) &&
  606. rfalNfcIsRemDevPoller(gNfcDev.activeDev->type)) {
  607. if(txDataLen > 0U) {
  608. return ERR_WRONG_STATE;
  609. }
  610. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  611. *rxData = (uint8_t*)( (gNfcDev.activeDev->rfInterface == RFAL_NFC_INTERFACE_ISODEP) ? gNfcDev.rxBuf.isoDepBuf.apdu :
  612. ((gNfcDev.activeDev->rfInterface == RFAL_NFC_INTERFACE_NFCDEP) ? gNfcDev.rxBuf.nfcDepBuf.pdu : gNfcDev.rxBuf.rfBuf));
  613. if(gNfcDev.disc.activate_after_sak) {
  614. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE_DONE;
  615. }
  616. return ERR_NONE;
  617. }
  618. /*******************************************************************************/
  619. switch(gNfcDev.activeDev
  620. ->rfInterface) /* Check which RF interface shall be used/has been activated */
  621. {
  622. /*******************************************************************************/
  623. case RFAL_NFC_INTERFACE_RF:
  624. ctx.rxBuf = gNfcDev.rxBuf.rfBuf;
  625. ctx.rxBufLen = 8 * sizeof(gNfcDev.rxBuf.rfBuf);
  626. ctx.rxRcvdLen = &gNfcDev.rxLen;
  627. ctx.txBuf = txData;
  628. ctx.txBufLen = txDataLen;
  629. ctx.flags = flags;
  630. ctx.fwt = fwt;
  631. *rxData = (uint8_t*)gNfcDev.rxBuf.rfBuf;
  632. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  633. err = rfalStartTransceive(&ctx);
  634. break;
  635. #if RFAL_FEATURE_ISO_DEP
  636. /*******************************************************************************/
  637. case RFAL_NFC_INTERFACE_ISODEP: {
  638. rfalIsoDepApduTxRxParam isoDepTxRx;
  639. uint16_t tx_bytes = txDataLen / 8;
  640. if(tx_bytes > sizeof(gNfcDev.txBuf.isoDepBuf.apdu)) {
  641. return ERR_NOMEM;
  642. }
  643. if(tx_bytes > 0U) {
  644. ST_MEMCPY((uint8_t*)gNfcDev.txBuf.isoDepBuf.apdu, txData, tx_bytes);
  645. }
  646. isoDepTxRx.DID = RFAL_ISODEP_NO_DID;
  647. isoDepTxRx.ourFSx = RFAL_ISODEP_FSX_KEEP;
  648. isoDepTxRx.FSx = gNfcDev.activeDev->proto.isoDep.info.FSx;
  649. isoDepTxRx.dFWT = gNfcDev.activeDev->proto.isoDep.info.dFWT;
  650. isoDepTxRx.FWT = gNfcDev.activeDev->proto.isoDep.info.FWT;
  651. isoDepTxRx.txBuf = &gNfcDev.txBuf.isoDepBuf;
  652. isoDepTxRx.txBufLen = tx_bytes;
  653. isoDepTxRx.rxBuf = &gNfcDev.rxBuf.isoDepBuf;
  654. isoDepTxRx.rxLen = &gNfcDev.rxLen;
  655. isoDepTxRx.tmpBuf = &gNfcDev.tmpBuf.isoDepBuf;
  656. *rxData = (uint8_t*)gNfcDev.rxBuf.isoDepBuf.apdu;
  657. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  658. /*******************************************************************************/
  659. /* Trigger a RFAL ISO-DEP Transceive */
  660. err = rfalIsoDepStartApduTransceive(isoDepTxRx);
  661. break;
  662. }
  663. #endif /* RFAL_FEATURE_ISO_DEP */
  664. #if RFAL_FEATURE_NFC_DEP
  665. /*******************************************************************************/
  666. case RFAL_NFC_INTERFACE_NFCDEP: {
  667. rfalNfcDepPduTxRxParam nfcDepTxRx;
  668. if(txDataLen > sizeof(gNfcDev.txBuf.nfcDepBuf.pdu)) {
  669. return ERR_NOMEM;
  670. }
  671. if(txDataLen > 0U) {
  672. ST_MEMCPY((uint8_t*)gNfcDev.txBuf.nfcDepBuf.pdu, txData, txDataLen);
  673. }
  674. nfcDepTxRx.DID = RFAL_NFCDEP_DID_KEEP;
  675. nfcDepTxRx.FSx =
  676. rfalNfcIsRemDevListener(gNfcDev.activeDev->type) ?
  677. rfalNfcDepLR2FS((uint8_t)rfalNfcDepPP2LR(
  678. gNfcDev.activeDev->proto.nfcDep.activation.Target.ATR_RES.PPt)) :
  679. rfalNfcDepLR2FS((uint8_t)rfalNfcDepPP2LR(
  680. gNfcDev.activeDev->proto.nfcDep.activation.Initiator.ATR_REQ.PPi));
  681. nfcDepTxRx.dFWT = gNfcDev.activeDev->proto.nfcDep.info.dFWT;
  682. nfcDepTxRx.FWT = gNfcDev.activeDev->proto.nfcDep.info.FWT;
  683. nfcDepTxRx.txBuf = &gNfcDev.txBuf.nfcDepBuf;
  684. nfcDepTxRx.txBufLen = txDataLen;
  685. nfcDepTxRx.rxBuf = &gNfcDev.rxBuf.nfcDepBuf;
  686. nfcDepTxRx.rxLen = &gNfcDev.rxLen;
  687. nfcDepTxRx.tmpBuf = &gNfcDev.tmpBuf.nfcDepBuf;
  688. *rxData = (uint8_t*)gNfcDev.rxBuf.nfcDepBuf.pdu;
  689. *rvdLen = (uint16_t*)&gNfcDev.rxLen;
  690. /*******************************************************************************/
  691. /* Trigger a RFAL NFC-DEP Transceive */
  692. err = rfalNfcDepStartPduTransceive(nfcDepTxRx);
  693. break;
  694. }
  695. #endif /* RFAL_FEATURE_NFC_DEP */
  696. /*******************************************************************************/
  697. default:
  698. err = ERR_PARAM;
  699. break;
  700. }
  701. /* If a transceive has succesfully started flag Data Exchange as ongoing */
  702. if(err == ERR_NONE) {
  703. gNfcDev.dataExErr = ERR_BUSY;
  704. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE;
  705. }
  706. return err;
  707. }
  708. return ERR_WRONG_STATE;
  709. }
  710. /*******************************************************************************/
  711. ReturnCode rfalNfcDataExchangeGetStatus(void) {
  712. /*******************************************************************************/
  713. /* Check if it's the first frame received in Listen mode */
  714. if(gNfcDev.state == RFAL_NFC_STATE_ACTIVATED) {
  715. /* Continue data exchange as normal */
  716. gNfcDev.dataExErr = ERR_BUSY;
  717. gNfcDev.state = RFAL_NFC_STATE_DATAEXCHANGE;
  718. /* Check if we performing in T3T CE */
  719. if((gNfcDev.activeDev->type == RFAL_NFC_POLL_TYPE_NFCF) &&
  720. (gNfcDev.activeDev->rfInterface == RFAL_NFC_INTERFACE_RF)) {
  721. /* The first frame has been retrieved by rfalListenMode, flag data immediately */
  722. /* Can only call rfalGetTransceiveStatus() after starting a transceive with rfalStartTransceive */
  723. gNfcDev.dataExErr = ERR_NONE;
  724. }
  725. }
  726. /*******************************************************************************/
  727. /* Check if we are in we have been placed to sleep, and return last error */
  728. if(gNfcDev.state == RFAL_NFC_STATE_LISTEN_SLEEP) {
  729. return gNfcDev.dataExErr; /* ERR_SLEEP_REQ */
  730. }
  731. /*******************************************************************************/
  732. /* Check if Data exchange has been started */
  733. if((gNfcDev.state != RFAL_NFC_STATE_DATAEXCHANGE) &&
  734. (gNfcDev.state != RFAL_NFC_STATE_DATAEXCHANGE_DONE)) {
  735. return ERR_WRONG_STATE;
  736. }
  737. /* Check if Data exchange is still ongoing */
  738. if(gNfcDev.dataExErr == ERR_BUSY) {
  739. switch(gNfcDev.activeDev->rfInterface) {
  740. /*******************************************************************************/
  741. case RFAL_NFC_INTERFACE_RF:
  742. gNfcDev.dataExErr = rfalGetTransceiveStatus();
  743. break;
  744. #if RFAL_FEATURE_ISO_DEP
  745. /*******************************************************************************/
  746. case RFAL_NFC_INTERFACE_ISODEP:
  747. gNfcDev.dataExErr = rfalIsoDepGetApduTransceiveStatus();
  748. break;
  749. #endif /* RFAL_FEATURE_ISO_DEP */
  750. /*******************************************************************************/
  751. #if RFAL_FEATURE_NFC_DEP
  752. case RFAL_NFC_INTERFACE_NFCDEP:
  753. gNfcDev.dataExErr = rfalNfcDepGetPduTransceiveStatus();
  754. break;
  755. #endif /* RFAL_FEATURE_NFC_DEP */
  756. /*******************************************************************************/
  757. default:
  758. gNfcDev.dataExErr = ERR_PARAM;
  759. break;
  760. }
  761. #if RFAL_FEATURE_LISTEN_MODE
  762. /*******************************************************************************/
  763. /* If a Sleep request has been received (Listen Mode) go to sleep immediately */
  764. if(gNfcDev.dataExErr == ERR_SLEEP_REQ) {
  765. EXIT_ON_ERR(
  766. gNfcDev.dataExErr,
  767. rfalListenSleepStart(
  768. RFAL_LM_STATE_SLEEP_A,
  769. gNfcDev.rxBuf.rfBuf,
  770. sizeof(gNfcDev.rxBuf.rfBuf),
  771. &gNfcDev.rxLen));
  772. /* If set Sleep was succesfull keep restore the Sleep request signal */
  773. gNfcDev.dataExErr = ERR_SLEEP_REQ;
  774. }
  775. #endif /* RFAL_FEATURE_LISTEN_MODE */
  776. }
  777. return gNfcDev.dataExErr;
  778. }
  779. /*!
  780. ******************************************************************************
  781. * \brief Poller Technology Detection
  782. *
  783. * This method implements the Technology Detection / Poll for different
  784. * device technologies.
  785. *
  786. * \return ERR_NONE : Operation completed with no error
  787. * \return ERR_BUSY : Operation ongoing
  788. * \return ERR_XXXX : Error occurred
  789. *
  790. ******************************************************************************
  791. */
  792. static ReturnCode rfalNfcPollTechDetetection(void) {
  793. ReturnCode err;
  794. err = ERR_NONE;
  795. /* Supress warning when specific RFAL features have been disabled */
  796. NO_WARNING(err);
  797. /*******************************************************************************/
  798. /* AP2P Technology Detection */
  799. /*******************************************************************************/
  800. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_AP2P) != 0U) &&
  801. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_AP2P) != 0U)) {
  802. #if RFAL_FEATURE_NFC_DEP
  803. if(!gNfcDev.isTechInit) {
  804. EXIT_ON_ERR(
  805. err,
  806. rfalSetMode(RFAL_MODE_POLL_ACTIVE_P2P, gNfcDev.disc.ap2pBR, gNfcDev.disc.ap2pBR));
  807. rfalSetErrorHandling(RFAL_ERRORHANDLING_NFC);
  808. rfalSetFDTListen(RFAL_FDT_LISTEN_AP2P_POLLER);
  809. rfalSetFDTPoll(RFAL_TIMING_NONE);
  810. rfalSetGT(RFAL_GT_AP2P_ADJUSTED);
  811. EXIT_ON_ERR(err, rfalFieldOnAndStartGT()); /* Turns the Field On and starts GT timer */
  812. gNfcDev.isTechInit = true;
  813. }
  814. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  815. {
  816. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_AP2P;
  817. err = rfalNfcNfcDepActivate(
  818. gNfcDev.devList, RFAL_NFCDEP_COMM_ACTIVE, NULL, 0); /* Poll for NFC-A devices */
  819. if(err == ERR_NONE) {
  820. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_AP2P;
  821. gNfcDev.devList->type = RFAL_NFC_LISTEN_TYPE_AP2P;
  822. gNfcDev.devList->rfInterface = RFAL_NFC_INTERFACE_NFCDEP;
  823. gNfcDev.devCnt++;
  824. return ERR_NONE;
  825. }
  826. gNfcDev.isTechInit = false;
  827. rfalFieldOff();
  828. }
  829. return ERR_BUSY;
  830. #endif /* RFAL_FEATURE_NFC_DEP */
  831. }
  832. /*******************************************************************************/
  833. /* Passive NFC-A Technology Detection */
  834. /*******************************************************************************/
  835. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_A) != 0U) &&
  836. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_A) != 0U)) {
  837. #if RFAL_FEATURE_NFCA
  838. rfalNfcaSensRes sensRes;
  839. if(!gNfcDev.isTechInit) {
  840. EXIT_ON_ERR(err, rfalNfcaPollerInitialize()); /* Initialize RFAL for NFC-A */
  841. EXIT_ON_ERR(err, rfalFieldOnAndStartGT()); /* Turns the Field On and starts GT timer */
  842. gNfcDev.isTechInit = true;
  843. }
  844. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  845. {
  846. err = rfalNfcaPollerTechnologyDetection(
  847. gNfcDev.disc.compMode, &sensRes); /* Poll for NFC-A devices */
  848. if(err == ERR_NONE) {
  849. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_A;
  850. }
  851. gNfcDev.isTechInit = false;
  852. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_A;
  853. }
  854. return ERR_BUSY;
  855. #endif /* RFAL_FEATURE_NFCA */
  856. }
  857. /*******************************************************************************/
  858. /* Passive NFC-B Technology Detection */
  859. /*******************************************************************************/
  860. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_B) != 0U) &&
  861. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_B) != 0U)) {
  862. #if RFAL_FEATURE_NFCB
  863. rfalNfcbSensbRes sensbRes;
  864. uint8_t sensbResLen;
  865. if(!gNfcDev.isTechInit) {
  866. EXIT_ON_ERR(err, rfalNfcbPollerInitialize()); /* Initialize RFAL for NFC-B */
  867. EXIT_ON_ERR(
  868. err, rfalFieldOnAndStartGT()); /* As field is already On only starts GT timer */
  869. gNfcDev.isTechInit = true;
  870. }
  871. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  872. {
  873. err = rfalNfcbPollerTechnologyDetection(
  874. gNfcDev.disc.compMode, &sensbRes, &sensbResLen); /* Poll for NFC-B devices */
  875. if(err == ERR_NONE) {
  876. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_B;
  877. }
  878. gNfcDev.isTechInit = false;
  879. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_B;
  880. }
  881. return ERR_BUSY;
  882. #endif /* RFAL_FEATURE_NFCB */
  883. }
  884. /*******************************************************************************/
  885. /* Passive NFC-F Technology Detection */
  886. /*******************************************************************************/
  887. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_F) != 0U) &&
  888. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_F) != 0U)) {
  889. #if RFAL_FEATURE_NFCF
  890. if(!gNfcDev.isTechInit) {
  891. EXIT_ON_ERR(
  892. err,
  893. rfalNfcfPollerInitialize(gNfcDev.disc.nfcfBR)); /* Initialize RFAL for NFC-F */
  894. EXIT_ON_ERR(
  895. err, rfalFieldOnAndStartGT()); /* As field is already On only starts GT timer */
  896. gNfcDev.isTechInit = true;
  897. }
  898. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  899. {
  900. err = rfalNfcfPollerCheckPresence(); /* Poll for NFC-F devices */
  901. if(err == ERR_NONE) {
  902. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_F;
  903. }
  904. gNfcDev.isTechInit = false;
  905. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_F;
  906. }
  907. return ERR_BUSY;
  908. #endif /* RFAL_FEATURE_NFCF */
  909. }
  910. /*******************************************************************************/
  911. /* Passive NFC-V Technology Detection */
  912. /*******************************************************************************/
  913. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_V) != 0U) &&
  914. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_V) != 0U)) {
  915. #if RFAL_FEATURE_NFCV
  916. rfalNfcvInventoryRes invRes;
  917. if(!gNfcDev.isTechInit) {
  918. EXIT_ON_ERR(err, rfalNfcvPollerInitialize()); /* Initialize RFAL for NFC-V */
  919. EXIT_ON_ERR(
  920. err, rfalFieldOnAndStartGT()); /* As field is already On only starts GT timer */
  921. gNfcDev.isTechInit = true;
  922. }
  923. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  924. {
  925. err = rfalNfcvPollerCheckPresence(&invRes); /* Poll for NFC-V devices */
  926. if(err == ERR_NONE) {
  927. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_V;
  928. }
  929. gNfcDev.isTechInit = false;
  930. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_V;
  931. }
  932. return ERR_BUSY;
  933. #endif /* RFAL_FEATURE_NFCV */
  934. }
  935. /*******************************************************************************/
  936. /* Passive Proprietary Technology ST25TB */
  937. /*******************************************************************************/
  938. if(((gNfcDev.disc.techs2Find & RFAL_NFC_POLL_TECH_ST25TB) != 0U) &&
  939. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_ST25TB) != 0U)) {
  940. #if RFAL_FEATURE_ST25TB
  941. if(!gNfcDev.isTechInit) {
  942. EXIT_ON_ERR(err, rfalSt25tbPollerInitialize()); /* Initialize RFAL for NFC-V */
  943. EXIT_ON_ERR(
  944. err, rfalFieldOnAndStartGT()); /* As field is already On only starts GT timer */
  945. gNfcDev.isTechInit = true;
  946. }
  947. if(rfalIsGTExpired()) /* Wait until Guard Time is fulfilled */
  948. {
  949. err = rfalSt25tbPollerCheckPresence(NULL); /* Poll for ST25TB devices */
  950. if(err == ERR_NONE) {
  951. gNfcDev.techsFound |= RFAL_NFC_POLL_TECH_ST25TB;
  952. }
  953. gNfcDev.isTechInit = false;
  954. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_ST25TB;
  955. }
  956. return ERR_BUSY;
  957. #endif /* RFAL_FEATURE_ST25TB */
  958. }
  959. return ERR_NONE;
  960. }
  961. /*!
  962. ******************************************************************************
  963. * \brief Poller Collision Resolution
  964. *
  965. * This method implements the Collision Resolution on all technologies that
  966. * have been detected before.
  967. *
  968. * \return ERR_NONE : Operation completed with no error
  969. * \return ERR_BUSY : Operation ongoing
  970. * \return ERR_XXXX : Error occurred
  971. *
  972. ******************************************************************************
  973. */
  974. static ReturnCode rfalNfcPollCollResolution(void) {
  975. uint8_t i;
  976. static uint8_t devCnt;
  977. ReturnCode err;
  978. err = ERR_NONE;
  979. i = 0;
  980. /* Supress warning when specific RFAL features have been disabled */
  981. NO_WARNING(err);
  982. NO_WARNING(devCnt);
  983. NO_WARNING(i);
  984. /* Check if device limit has been reached */
  985. if(gNfcDev.devCnt >= gNfcDev.disc.devLimit) {
  986. return ERR_NONE;
  987. }
  988. /*******************************************************************************/
  989. /* NFC-A Collision Resolution */
  990. /*******************************************************************************/
  991. #if RFAL_FEATURE_NFCA
  992. if(((gNfcDev.techsFound & RFAL_NFC_POLL_TECH_A) != 0U) &&
  993. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_A) !=
  994. 0U)) /* If a NFC-A device was found/detected, perform Collision Resolution */
  995. {
  996. static rfalNfcaListenDevice nfcaDevList[RFAL_NFC_MAX_DEVICES];
  997. if(!gNfcDev.isTechInit) {
  998. EXIT_ON_ERR(err, rfalNfcaPollerInitialize()); /* Initialize RFAL for NFC-A */
  999. EXIT_ON_ERR(err, rfalFieldOnAndStartGT()); /* Turns the Field On and starts GT timer */
  1000. gNfcDev.isTechInit = true; /* Technology has been initialized */
  1001. gNfcDev.isOperOngoing = false; /* No operation currently ongoing */
  1002. }
  1003. if(!rfalIsGTExpired()) {
  1004. return ERR_BUSY;
  1005. }
  1006. if(!gNfcDev.isOperOngoing) {
  1007. EXIT_ON_ERR(
  1008. err,
  1009. rfalNfcaPollerStartFullCollisionResolution(
  1010. gNfcDev.disc.compMode,
  1011. (gNfcDev.disc.devLimit - gNfcDev.devCnt),
  1012. nfcaDevList,
  1013. &devCnt));
  1014. gNfcDev.isOperOngoing = true;
  1015. return ERR_BUSY;
  1016. }
  1017. err = rfalNfcaPollerGetFullCollisionResolutionStatus();
  1018. if(err != ERR_BUSY) {
  1019. gNfcDev.isTechInit = false;
  1020. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_A;
  1021. if((err == ERR_NONE) && (devCnt != 0U)) {
  1022. for(i = 0; i < devCnt;
  1023. i++) /* Copy devices found form local Nfca list into global device list */
  1024. {
  1025. gNfcDev.devList[gNfcDev.devCnt].type = RFAL_NFC_LISTEN_TYPE_NFCA;
  1026. gNfcDev.devList[gNfcDev.devCnt].dev.nfca = nfcaDevList[i];
  1027. gNfcDev.devCnt++;
  1028. }
  1029. }
  1030. }
  1031. return ERR_BUSY;
  1032. }
  1033. #endif /* RFAL_FEATURE_NFCA */
  1034. /*******************************************************************************/
  1035. /* NFC-B Collision Resolution */
  1036. /*******************************************************************************/
  1037. #if RFAL_FEATURE_NFCB
  1038. if(((gNfcDev.techsFound & RFAL_NFC_POLL_TECH_B) != 0U) &&
  1039. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_B) !=
  1040. 0U)) /* If a NFC-B device was found/detected, perform Collision Resolution */
  1041. {
  1042. rfalNfcbListenDevice nfcbDevList[RFAL_NFC_MAX_DEVICES];
  1043. if(!gNfcDev.isTechInit) {
  1044. EXIT_ON_ERR(err, rfalNfcbPollerInitialize()); /* Initialize RFAL for NFC-B */
  1045. EXIT_ON_ERR(
  1046. err,
  1047. rfalFieldOnAndStartGT()); /* Ensure GT again as other technologies have also been polled */
  1048. gNfcDev.isTechInit = true;
  1049. }
  1050. if(!rfalIsGTExpired()) {
  1051. return ERR_BUSY;
  1052. }
  1053. devCnt = 0;
  1054. gNfcDev.isTechInit = false;
  1055. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_B;
  1056. err = rfalNfcbPollerCollisionResolution(
  1057. gNfcDev.disc.compMode, (gNfcDev.disc.devLimit - gNfcDev.devCnt), nfcbDevList, &devCnt);
  1058. if((err == ERR_NONE) && (devCnt != 0U)) {
  1059. for(i = 0; i < devCnt;
  1060. i++) /* Copy devices found form local Nfcb list into global device list */
  1061. {
  1062. gNfcDev.devList[gNfcDev.devCnt].type = RFAL_NFC_LISTEN_TYPE_NFCB;
  1063. gNfcDev.devList[gNfcDev.devCnt].dev.nfcb = nfcbDevList[i];
  1064. gNfcDev.devCnt++;
  1065. }
  1066. }
  1067. return ERR_BUSY;
  1068. }
  1069. #endif /* RFAL_FEATURE_NFCB*/
  1070. /*******************************************************************************/
  1071. /* NFC-F Collision Resolution */
  1072. /*******************************************************************************/
  1073. #if RFAL_FEATURE_NFCF
  1074. if(((gNfcDev.techsFound & RFAL_NFC_POLL_TECH_F) != 0U) &&
  1075. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_F) !=
  1076. 0U)) /* If a NFC-F device was found/detected, perform Collision Resolution */
  1077. {
  1078. rfalNfcfListenDevice nfcfDevList[RFAL_NFC_MAX_DEVICES];
  1079. if(!gNfcDev.isTechInit) {
  1080. EXIT_ON_ERR(
  1081. err,
  1082. rfalNfcfPollerInitialize(gNfcDev.disc.nfcfBR)); /* Initialize RFAL for NFC-F */
  1083. EXIT_ON_ERR(
  1084. err,
  1085. rfalFieldOnAndStartGT()); /* Ensure GT again as other technologies have also been polled */
  1086. gNfcDev.isTechInit = true;
  1087. }
  1088. if(!rfalIsGTExpired()) {
  1089. return ERR_BUSY;
  1090. }
  1091. devCnt = 0;
  1092. gNfcDev.isTechInit = false;
  1093. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_F;
  1094. err = rfalNfcfPollerCollisionResolution(
  1095. gNfcDev.disc.compMode, (gNfcDev.disc.devLimit - gNfcDev.devCnt), nfcfDevList, &devCnt);
  1096. if((err == ERR_NONE) && (devCnt != 0U)) {
  1097. for(i = 0; i < devCnt;
  1098. i++) /* Copy devices found form local Nfcf list into global device list */
  1099. {
  1100. gNfcDev.devList[gNfcDev.devCnt].type = RFAL_NFC_LISTEN_TYPE_NFCF;
  1101. gNfcDev.devList[gNfcDev.devCnt].dev.nfcf = nfcfDevList[i];
  1102. gNfcDev.devCnt++;
  1103. }
  1104. }
  1105. return ERR_BUSY;
  1106. }
  1107. #endif /* RFAL_FEATURE_NFCF */
  1108. /*******************************************************************************/
  1109. /* NFC-V Collision Resolution */
  1110. /*******************************************************************************/
  1111. #if RFAL_FEATURE_NFCV
  1112. if(((gNfcDev.techsFound & RFAL_NFC_POLL_TECH_V) != 0U) &&
  1113. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_V) !=
  1114. 0U)) /* If a NFC-V device was found/detected, perform Collision Resolution */
  1115. {
  1116. rfalNfcvListenDevice nfcvDevList[RFAL_NFC_MAX_DEVICES];
  1117. if(!gNfcDev.isTechInit) {
  1118. EXIT_ON_ERR(err, rfalNfcvPollerInitialize()); /* Initialize RFAL for NFC-V */
  1119. EXIT_ON_ERR(
  1120. err,
  1121. rfalFieldOnAndStartGT()); /* Ensure GT again as other technologies have also been polled */
  1122. gNfcDev.isTechInit = true;
  1123. }
  1124. if(!rfalIsGTExpired()) {
  1125. return ERR_BUSY;
  1126. }
  1127. devCnt = 0;
  1128. gNfcDev.isTechInit = false;
  1129. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_V;
  1130. err = rfalNfcvPollerCollisionResolution(
  1131. RFAL_COMPLIANCE_MODE_NFC,
  1132. (gNfcDev.disc.devLimit - gNfcDev.devCnt),
  1133. nfcvDevList,
  1134. &devCnt);
  1135. if((err == ERR_NONE) && (devCnt != 0U)) {
  1136. for(i = 0; i < devCnt;
  1137. i++) /* Copy devices found form local Nfcf list into global device list */
  1138. {
  1139. gNfcDev.devList[gNfcDev.devCnt].type = RFAL_NFC_LISTEN_TYPE_NFCV;
  1140. gNfcDev.devList[gNfcDev.devCnt].dev.nfcv = nfcvDevList[i];
  1141. gNfcDev.devCnt++;
  1142. }
  1143. }
  1144. return ERR_BUSY;
  1145. }
  1146. #endif /* RFAL_FEATURE_NFCV */
  1147. /*******************************************************************************/
  1148. /* ST25TB Collision Resolution */
  1149. /*******************************************************************************/
  1150. #if RFAL_FEATURE_ST25TB
  1151. if(((gNfcDev.techsFound & RFAL_NFC_POLL_TECH_ST25TB) != 0U) &&
  1152. ((gNfcDev.techs2do & RFAL_NFC_POLL_TECH_ST25TB) !=
  1153. 0U)) /* If a ST25TB device was found/detected, perform Collision Resolution */
  1154. {
  1155. rfalSt25tbListenDevice st25tbDevList[RFAL_NFC_MAX_DEVICES];
  1156. if(!gNfcDev.isTechInit) {
  1157. EXIT_ON_ERR(err, rfalSt25tbPollerInitialize()); /* Initialize RFAL for ST25TB */
  1158. EXIT_ON_ERR(
  1159. err,
  1160. rfalFieldOnAndStartGT()); /* Ensure GT again as other technologies have also been polled */
  1161. gNfcDev.isTechInit = true;
  1162. }
  1163. if(!rfalIsGTExpired()) {
  1164. return ERR_BUSY;
  1165. }
  1166. devCnt = 0;
  1167. gNfcDev.isTechInit = false;
  1168. gNfcDev.techs2do &= ~RFAL_NFC_POLL_TECH_ST25TB;
  1169. err = rfalSt25tbPollerCollisionResolution(
  1170. (gNfcDev.disc.devLimit - gNfcDev.devCnt), st25tbDevList, &devCnt);
  1171. if((err == ERR_NONE) && (devCnt != 0U)) {
  1172. for(i = 0; i < devCnt;
  1173. i++) /* Copy devices found form local Nfcf list into global device list */
  1174. {
  1175. gNfcDev.devList[gNfcDev.devCnt].type = RFAL_NFC_LISTEN_TYPE_ST25TB;
  1176. gNfcDev.devList[gNfcDev.devCnt].dev.st25tb = st25tbDevList[i];
  1177. gNfcDev.devCnt++;
  1178. }
  1179. }
  1180. return ERR_BUSY;
  1181. }
  1182. #endif /* RFAL_FEATURE_ST25TB */
  1183. return ERR_NONE; /* All technologies have been performed */
  1184. }
  1185. /*!
  1186. ******************************************************************************
  1187. * \brief Poller Activation
  1188. *
  1189. * This method Activates a given device according to it's type and
  1190. * protocols supported
  1191. *
  1192. * \param[in] devIt : device's position on the list to be activated
  1193. *
  1194. * \return ERR_NONE : Operation completed with no error
  1195. * \return ERR_BUSY : Operation ongoing
  1196. * \return ERR_XXXX : Error occurred
  1197. *
  1198. ******************************************************************************
  1199. */
  1200. static ReturnCode rfalNfcPollActivation(uint8_t devIt) {
  1201. ReturnCode err;
  1202. err = ERR_NONE;
  1203. /* Supress warning when specific RFAL features have been disabled */
  1204. NO_WARNING(err);
  1205. if(devIt > gNfcDev.devCnt) {
  1206. return ERR_WRONG_STATE;
  1207. }
  1208. switch(gNfcDev.devList[devIt].type) {
  1209. /*******************************************************************************/
  1210. /* AP2P Activation */
  1211. /*******************************************************************************/
  1212. #if RFAL_FEATURE_NFC_DEP
  1213. case RFAL_NFC_LISTEN_TYPE_AP2P:
  1214. /* Activation has already been perfomed (ATR_REQ) */
  1215. gNfcDev.devList[devIt].nfcid =
  1216. gNfcDev.devList[devIt].proto.nfcDep.activation.Target.ATR_RES.NFCID3;
  1217. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCDEP_NFCID3_LEN;
  1218. break;
  1219. #endif /* RFAL_FEATURE_NFC_DEP */
  1220. /*******************************************************************************/
  1221. /* Passive NFC-A Activation */
  1222. /*******************************************************************************/
  1223. #if RFAL_FEATURE_NFCA
  1224. case RFAL_NFC_LISTEN_TYPE_NFCA:
  1225. if(!gNfcDev.isTechInit) {
  1226. rfalNfcaPollerInitialize();
  1227. gNfcDev.isTechInit = true;
  1228. gNfcDev.isOperOngoing = false;
  1229. return ERR_BUSY;
  1230. }
  1231. if(gNfcDev.devList[devIt].dev.nfca.isSleep) /* Check if desired device is in Sleep */
  1232. {
  1233. rfalNfcaSensRes sensRes;
  1234. rfalNfcaSelRes selRes;
  1235. if(!gNfcDev.isOperOngoing) {
  1236. /* Wake up all cards */
  1237. EXIT_ON_ERR(
  1238. err, rfalNfcaPollerCheckPresence(RFAL_14443A_SHORTFRAME_CMD_WUPA, &sensRes));
  1239. gNfcDev.isOperOngoing = true;
  1240. } else {
  1241. /* Select specific device */
  1242. EXIT_ON_ERR(
  1243. err,
  1244. rfalNfcaPollerSelect(
  1245. gNfcDev.devList[devIt].dev.nfca.nfcId1,
  1246. gNfcDev.devList[devIt].dev.nfca.nfcId1Len,
  1247. &selRes));
  1248. gNfcDev.devList[devIt].dev.nfca.isSleep = false;
  1249. gNfcDev.isOperOngoing = false;
  1250. }
  1251. return ERR_BUSY;
  1252. }
  1253. /* Set NFCID */
  1254. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.nfca.nfcId1;
  1255. gNfcDev.devList[devIt].nfcidLen = gNfcDev.devList[devIt].dev.nfca.nfcId1Len;
  1256. /*******************************************************************************/
  1257. /* Perform protocol specific activation */
  1258. switch(gNfcDev.devList[devIt].dev.nfca.type) {
  1259. /*******************************************************************************/
  1260. case RFAL_NFCA_T1T:
  1261. /* No further activation needed for T1T (RID already performed) */
  1262. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.nfca.ridRes.uid;
  1263. gNfcDev.devList[devIt].nfcidLen = RFAL_T1T_UID_LEN;
  1264. gNfcDev.devList[devIt].rfInterface = RFAL_NFC_INTERFACE_RF;
  1265. break;
  1266. case RFAL_NFCA_T2T:
  1267. /* No further activation needed for a T2T */
  1268. gNfcDev.devList[devIt].rfInterface = RFAL_NFC_INTERFACE_RF;
  1269. break;
  1270. /*******************************************************************************/
  1271. case RFAL_NFCA_T4T: /* Device supports ISO-DEP */
  1272. #if RFAL_FEATURE_ISO_DEP && RFAL_FEATURE_ISO_DEP_POLL
  1273. if(!gNfcDev.isOperOngoing) {
  1274. /* Perform ISO-DEP (ISO14443-4) activation: RATS and PPS if supported */
  1275. rfalIsoDepInitialize();
  1276. EXIT_ON_ERR(
  1277. err,
  1278. rfalIsoDepPollAStartActivation(
  1279. (rfalIsoDepFSxI)RFAL_ISODEP_FSDI_DEFAULT,
  1280. RFAL_ISODEP_NO_DID,
  1281. gNfcDev.disc.maxBR,
  1282. &gNfcDev.devList[devIt].proto.isoDep));
  1283. gNfcDev.isOperOngoing = true;
  1284. return ERR_BUSY;
  1285. }
  1286. err = rfalIsoDepPollAGetActivationStatus();
  1287. if(err != ERR_NONE) {
  1288. return err;
  1289. }
  1290. gNfcDev.devList[devIt].rfInterface =
  1291. RFAL_NFC_INTERFACE_ISODEP; /* NFC-A T4T device activated */
  1292. #else
  1293. gNfcDev.devList[devIt].rfInterface =
  1294. RFAL_NFC_INTERFACE_RF; /* No ISO-DEP supported activate using RF interface */
  1295. #endif /* RFAL_FEATURE_ISO_DEP_POLL */
  1296. break;
  1297. /*******************************************************************************/
  1298. case RFAL_NFCA_T4T_NFCDEP: /* Device supports both T4T and NFC-DEP */
  1299. case RFAL_NFCA_NFCDEP: /* Device supports NFC-DEP */
  1300. #if RFAL_FEATURE_NFC_DEP
  1301. /* Perform NFC-DEP (P2P) activation: ATR and PSL if supported */
  1302. EXIT_ON_ERR(
  1303. err,
  1304. rfalNfcNfcDepActivate(&gNfcDev.devList[devIt], RFAL_NFCDEP_COMM_PASSIVE, NULL, 0));
  1305. gNfcDev.devList[devIt].nfcid =
  1306. gNfcDev.devList[devIt].proto.nfcDep.activation.Target.ATR_RES.NFCID3;
  1307. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCDEP_NFCID3_LEN;
  1308. gNfcDev.devList[devIt].rfInterface =
  1309. RFAL_NFC_INTERFACE_NFCDEP; /* NFC-A P2P device activated */
  1310. #else
  1311. gNfcDev.devList[devIt].rfInterface =
  1312. RFAL_NFC_INTERFACE_RF; /* No NFC-DEP supported activate using RF interface */
  1313. #endif /* RFAL_FEATURE_NFC_DEP */
  1314. break;
  1315. /*******************************************************************************/
  1316. default:
  1317. return ERR_WRONG_STATE;
  1318. }
  1319. break;
  1320. #endif /* RFAL_FEATURE_NFCA */
  1321. /*******************************************************************************/
  1322. /* Passive NFC-B Activation */
  1323. /*******************************************************************************/
  1324. #if RFAL_FEATURE_NFCB
  1325. case RFAL_NFC_LISTEN_TYPE_NFCB:
  1326. if(!gNfcDev.isTechInit) {
  1327. rfalNfcbPollerInitialize();
  1328. gNfcDev.isTechInit = true;
  1329. gNfcDev.isOperOngoing = false;
  1330. return ERR_BUSY;
  1331. }
  1332. if(gNfcDev.devList[devIt].dev.nfcb.isSleep) /* Check if desired device is in Sleep */
  1333. {
  1334. rfalNfcbSensbRes sensbRes;
  1335. uint8_t sensbResLen;
  1336. /* Wake up all cards. SENSB_RES may return collision but the NFCID0 is available to explicitly select NFC-B card via ATTRIB; so error will be ignored here */
  1337. rfalNfcbPollerCheckPresence(
  1338. RFAL_NFCB_SENS_CMD_ALLB_REQ, RFAL_NFCB_SLOT_NUM_1, &sensbRes, &sensbResLen);
  1339. }
  1340. /* Set NFCID */
  1341. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.nfcb.sensbRes.nfcid0;
  1342. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCB_NFCID0_LEN;
  1343. #if RFAL_FEATURE_ISO_DEP && RFAL_FEATURE_ISO_DEP_POLL
  1344. /* Check if device supports ISO-DEP (ISO14443-4) */
  1345. if((gNfcDev.devList[devIt].dev.nfcb.sensbRes.protInfo.FsciProType &
  1346. RFAL_NFCB_SENSB_RES_PROTO_ISO_MASK) != 0U) {
  1347. if(!gNfcDev.isOperOngoing) {
  1348. rfalIsoDepInitialize();
  1349. /* Perform ISO-DEP (ISO14443-4) activation: ATTRIB */
  1350. EXIT_ON_ERR(
  1351. err,
  1352. rfalIsoDepPollBStartActivation(
  1353. (rfalIsoDepFSxI)RFAL_ISODEP_FSDI_DEFAULT,
  1354. RFAL_ISODEP_NO_DID,
  1355. gNfcDev.disc.maxBR,
  1356. 0x00,
  1357. &gNfcDev.devList[devIt].dev.nfcb,
  1358. NULL,
  1359. 0,
  1360. &gNfcDev.devList[devIt].proto.isoDep));
  1361. gNfcDev.isOperOngoing = true;
  1362. return ERR_BUSY;
  1363. }
  1364. err = rfalIsoDepPollBGetActivationStatus();
  1365. if(err != ERR_NONE) {
  1366. return err;
  1367. }
  1368. gNfcDev.devList[devIt].rfInterface =
  1369. RFAL_NFC_INTERFACE_ISODEP; /* NFC-B T4T device activated */
  1370. break;
  1371. }
  1372. #endif /* RFAL_FEATURE_ISO_DEP_POLL */
  1373. gNfcDev.devList[devIt].rfInterface =
  1374. RFAL_NFC_INTERFACE_RF; /* NFC-B device activated */
  1375. break;
  1376. #endif /* RFAL_FEATURE_NFCB */
  1377. /*******************************************************************************/
  1378. /* Passive NFC-F Activation */
  1379. /*******************************************************************************/
  1380. #if RFAL_FEATURE_NFCF
  1381. case RFAL_NFC_LISTEN_TYPE_NFCF:
  1382. rfalNfcfPollerInitialize(gNfcDev.disc.nfcfBR);
  1383. #if RFAL_FEATURE_NFC_DEP
  1384. if(rfalNfcfIsNfcDepSupported(&gNfcDev.devList[devIt].dev.nfcf)) {
  1385. /* Perform NFC-DEP (P2P) activation: ATR and PSL if supported */
  1386. EXIT_ON_ERR(
  1387. err,
  1388. rfalNfcNfcDepActivate(&gNfcDev.devList[devIt], RFAL_NFCDEP_COMM_PASSIVE, NULL, 0));
  1389. /* Set NFCID */
  1390. gNfcDev.devList[devIt].nfcid =
  1391. gNfcDev.devList[devIt].proto.nfcDep.activation.Target.ATR_RES.NFCID3;
  1392. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCDEP_NFCID3_LEN;
  1393. gNfcDev.devList[devIt].rfInterface =
  1394. RFAL_NFC_INTERFACE_NFCDEP; /* NFC-F P2P device activated */
  1395. break;
  1396. }
  1397. #endif /* RFAL_FEATURE_NFC_DEP */
  1398. /* Set NFCID */
  1399. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.nfcf.sensfRes.NFCID2;
  1400. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCF_NFCID2_LEN;
  1401. gNfcDev.devList[devIt].rfInterface =
  1402. RFAL_NFC_INTERFACE_RF; /* NFC-F T3T device activated */
  1403. break;
  1404. #endif /* RFAL_FEATURE_NFCF */
  1405. /*******************************************************************************/
  1406. /* Passive NFC-V Activation */
  1407. /*******************************************************************************/
  1408. #if RFAL_FEATURE_NFCV
  1409. case RFAL_NFC_LISTEN_TYPE_NFCV:
  1410. rfalNfcvPollerInitialize();
  1411. /* No specific activation needed for a T5T */
  1412. /* Set NFCID */
  1413. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.nfcv.InvRes.UID;
  1414. gNfcDev.devList[devIt].nfcidLen = RFAL_NFCV_UID_LEN;
  1415. gNfcDev.devList[devIt].rfInterface =
  1416. RFAL_NFC_INTERFACE_RF; /* NFC-V T5T device activated */
  1417. break;
  1418. #endif /* RFAL_FEATURE_NFCV */
  1419. /*******************************************************************************/
  1420. /* Passive ST25TB Activation */
  1421. /*******************************************************************************/
  1422. #if RFAL_FEATURE_ST25TB
  1423. case RFAL_NFC_LISTEN_TYPE_ST25TB:
  1424. rfalSt25tbPollerInitialize();
  1425. /* No specific activation needed for a ST25TB */
  1426. /* Set NFCID */
  1427. gNfcDev.devList[devIt].nfcid = gNfcDev.devList[devIt].dev.st25tb.UID;
  1428. gNfcDev.devList[devIt].nfcidLen = RFAL_ST25TB_UID_LEN;
  1429. gNfcDev.devList[devIt].rfInterface = RFAL_NFC_INTERFACE_RF; /* ST25TB device activated */
  1430. break;
  1431. #endif /* RFAL_FEATURE_ST25TB */
  1432. /*******************************************************************************/
  1433. default:
  1434. return ERR_WRONG_STATE;
  1435. }
  1436. gNfcDev.activeDev = &gNfcDev.devList[devIt]; /* Assign active device to be used further on */
  1437. return ERR_NONE;
  1438. }
  1439. /*!
  1440. ******************************************************************************
  1441. * \brief Listener Activation
  1442. *
  1443. * This method handles the listen mode Activation according to the different
  1444. * protocols the Reader/Initiator performs
  1445. *
  1446. * \return ERR_NONE : Operation completed with no error
  1447. * \return ERR_BUSY : Operation ongoing
  1448. * \return ERR_PROTO : Unexpected frame received
  1449. * \return ERR_XXXX : Error occurred
  1450. *
  1451. ******************************************************************************
  1452. */
  1453. #if RFAL_FEATURE_LISTEN_MODE
  1454. static ReturnCode rfalNfcListenActivation(void) {
  1455. bool isDataRcvd;
  1456. ReturnCode ret;
  1457. rfalLmState lmSt;
  1458. rfalBitRate bitRate;
  1459. #if RFAL_FEATURE_NFC_DEP
  1460. uint8_t hdrLen;
  1461. /* Set the header length in NFC-A */
  1462. hdrLen = (RFAL_NFCDEP_SB_LEN + RFAL_NFCDEP_LEN_LEN);
  1463. #endif /* RFAL_FEATURE_NFC_DEP */
  1464. lmSt = rfalListenGetState(&isDataRcvd, &bitRate);
  1465. switch(lmSt) {
  1466. #if RFAL_FEATURE_NFCA
  1467. /*******************************************************************************/
  1468. case RFAL_LM_STATE_ACTIVE_A: /* NFC-A CE activation */
  1469. case RFAL_LM_STATE_ACTIVE_Ax:
  1470. if(isDataRcvd) /* Check if Reader/Initator has sent some data */
  1471. {
  1472. /* Check if received data is a Sleep request */
  1473. if(rfalNfcaListenerIsSleepReq(
  1474. gNfcDev.rxBuf.rfBuf,
  1475. rfalConvBitsToBytes(gNfcDev.rxLen))) /* Check if received data is a SLP_REQ */
  1476. {
  1477. /* Set the Listen Mode in Sleep state */
  1478. EXIT_ON_ERR(
  1479. ret,
  1480. rfalListenSleepStart(
  1481. RFAL_LM_STATE_SLEEP_A,
  1482. gNfcDev.rxBuf.rfBuf,
  1483. sizeof(gNfcDev.rxBuf.rfBuf),
  1484. &gNfcDev.rxLen));
  1485. }
  1486. else if(gNfcDev.disc.activate_after_sak) {
  1487. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_NFCA;
  1488. rfalListenSetState(RFAL_LM_STATE_ACTIVE_A);
  1489. return ERR_NONE;
  1490. }
  1491. #if RFAL_FEATURE_ISO_DEP && RFAL_FEATURE_ISO_DEP_LISTEN
  1492. /* Check if received data is a valid RATS */
  1493. else if(rfalIsoDepIsRats(
  1494. gNfcDev.rxBuf.rfBuf, (uint8_t)rfalConvBitsToBytes(gNfcDev.rxLen))) {
  1495. rfalIsoDepAtsParam atsParam;
  1496. rfalIsoDepListenActvParam rxParam;
  1497. /* Set ATS parameters */
  1498. atsParam.fsci = (uint8_t)RFAL_ISODEP_DEFAULT_FSCI;
  1499. atsParam.fwi = RFAL_ISODEP_DEFAULT_FWI;
  1500. atsParam.sfgi = RFAL_ISODEP_DEFAULT_SFGI;
  1501. atsParam.didSupport = false;
  1502. atsParam.ta = RFAL_ISODEP_ATS_TA_SAME_D;
  1503. atsParam.hb = NULL;
  1504. atsParam.hbLen = 0;
  1505. /* Set Rx parameters */
  1506. rxParam.rxBuf =
  1507. (rfalIsoDepBufFormat*)&gNfcDev.rxBuf
  1508. .isoDepBuf; /* PRQA S 0310 # MISRA 11.3 - Intentional safe cast to avoiding large buffer duplication */
  1509. rxParam.rxLen = &gNfcDev.rxLen;
  1510. rxParam.isoDepDev = &gNfcDev.devList->proto.isoDep;
  1511. rxParam.isRxChaining = &gNfcDev.isRxChaining;
  1512. rfalListenSetState(RFAL_LM_STATE_CARDEMU_4A); /* Set next state CE T4T */
  1513. rfalIsoDepInitialize(); /* Initialize ISO-DEP layer to handle ISO14443-a activation / RATS */
  1514. /* Set ISO-DEP layer to digest RATS and handle activation */
  1515. EXIT_ON_ERR(
  1516. ret,
  1517. rfalIsoDepListenStartActivation(
  1518. &atsParam, NULL, gNfcDev.rxBuf.rfBuf, gNfcDev.rxLen, rxParam));
  1519. }
  1520. #endif /* RFAL_FEATURE_ISO_DEP_LISTEN */
  1521. #if RFAL_FEATURE_NFC_DEP
  1522. /* Check if received data is a valid ATR_REQ */
  1523. else if(rfalNfcDepIsAtrReq(
  1524. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1525. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen),
  1526. gNfcDev.devList->nfcid)) {
  1527. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_NFCA;
  1528. EXIT_ON_ERR(
  1529. ret,
  1530. rfalNfcNfcDepActivate(
  1531. gNfcDev.devList,
  1532. RFAL_NFCDEP_COMM_PASSIVE,
  1533. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1534. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen)));
  1535. }
  1536. #endif /* RFAL_FEATURE_NFC_DEP */
  1537. else {
  1538. return ERR_PROTO;
  1539. }
  1540. }
  1541. return ERR_BUSY;
  1542. #endif /* RFAL_FEATURE_NFCA */
  1543. #if RFAL_FEATURE_ISO_DEP && RFAL_FEATURE_ISO_DEP_LISTEN
  1544. /*******************************************************************************/
  1545. case RFAL_LM_STATE_CARDEMU_4A: /* T4T ISO-DEP activation */
  1546. ret = rfalIsoDepListenGetActivationStatus();
  1547. if(ret == ERR_NONE) {
  1548. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_NFCA;
  1549. gNfcDev.devList->rfInterface = RFAL_NFC_INTERFACE_ISODEP;
  1550. gNfcDev.devList->nfcid = NULL;
  1551. gNfcDev.devList->nfcidLen = 0;
  1552. }
  1553. return ret;
  1554. #endif /* RFAL_FEATURE_ISO_DEP_LISTEN */
  1555. /*******************************************************************************/
  1556. case RFAL_LM_STATE_READY_F: /* NFC-F CE activation */
  1557. if(isDataRcvd) /* Wait for the first received data */
  1558. {
  1559. #if RFAL_FEATURE_NFC_DEP
  1560. /* Set the header length in NFC-F */
  1561. hdrLen = RFAL_NFCDEP_LEN_LEN;
  1562. if(rfalNfcDepIsAtrReq(
  1563. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1564. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen),
  1565. gNfcDev.devList->nfcid)) {
  1566. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_NFCF;
  1567. EXIT_ON_ERR(
  1568. ret,
  1569. rfalNfcNfcDepActivate(
  1570. gNfcDev.devList,
  1571. RFAL_NFCDEP_COMM_PASSIVE,
  1572. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1573. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen)));
  1574. } else
  1575. #endif /* RFAL_FEATURE_NFC_DEP */
  1576. {
  1577. rfalListenSetState(
  1578. RFAL_LM_STATE_CARDEMU_3); /* First data already received - set T3T CE */
  1579. }
  1580. }
  1581. return ERR_BUSY;
  1582. /*******************************************************************************/
  1583. case RFAL_LM_STATE_CARDEMU_3: /* T3T activated */
  1584. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_NFCF;
  1585. gNfcDev.devList->rfInterface = RFAL_NFC_INTERFACE_RF;
  1586. gNfcDev.devList->nfcid = NULL;
  1587. gNfcDev.devList->nfcidLen = 0;
  1588. return ERR_NONE;
  1589. #if RFAL_FEATURE_NFC_DEP
  1590. /*******************************************************************************/
  1591. case RFAL_LM_STATE_TARGET_A: /* NFC-DEP activation */
  1592. case RFAL_LM_STATE_TARGET_F:
  1593. ret = rfalNfcDepListenGetActivationStatus();
  1594. if(ret == ERR_NONE) {
  1595. gNfcDev.devList->rfInterface = RFAL_NFC_INTERFACE_NFCDEP;
  1596. gNfcDev.devList->nfcidLen = RFAL_NFCDEP_NFCID3_LEN;
  1597. }
  1598. return ret;
  1599. #endif /* RFAL_FEATURE_NFC_DEP */
  1600. /*******************************************************************************/
  1601. case RFAL_LM_STATE_IDLE: /* AP2P activation */
  1602. if(isDataRcvd) /* Check if Reader/Initator has sent some data */
  1603. {
  1604. if((gNfcDev.lmMask & RFAL_LM_MASK_ACTIVE_P2P) != 0U) /* Check if AP2P is enabled */
  1605. {
  1606. #if RFAL_FEATURE_NFC_DEP
  1607. /* Calculate the header length in NFC-A or NFC-F mode*/
  1608. hdrLen =
  1609. ((bitRate == RFAL_BR_106) ? (RFAL_NFCDEP_SB_LEN + RFAL_NFCDEP_LEN_LEN) :
  1610. RFAL_NFCDEP_LEN_LEN);
  1611. if(rfalNfcDepIsAtrReq(
  1612. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1613. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen),
  1614. NULL)) {
  1615. gNfcDev.devList->type = RFAL_NFC_POLL_TYPE_AP2P;
  1616. rfalSetMode((RFAL_MODE_LISTEN_ACTIVE_P2P), bitRate, bitRate);
  1617. EXIT_ON_ERR(
  1618. ret,
  1619. rfalNfcNfcDepActivate(
  1620. gNfcDev.devList,
  1621. RFAL_NFCDEP_COMM_ACTIVE,
  1622. &gNfcDev.rxBuf.rfBuf[hdrLen],
  1623. (rfalConvBitsToBytes(gNfcDev.rxLen) - hdrLen)));
  1624. } else
  1625. #endif /* RFAL_FEATURE_NFC_DEP */
  1626. {
  1627. return ERR_PROTO;
  1628. }
  1629. }
  1630. }
  1631. return ERR_BUSY;
  1632. /*******************************************************************************/
  1633. case RFAL_LM_STATE_READY_A:
  1634. case RFAL_LM_STATE_READY_Ax:
  1635. case RFAL_LM_STATE_SLEEP_A:
  1636. case RFAL_LM_STATE_SLEEP_AF:
  1637. return ERR_BUSY;
  1638. /*******************************************************************************/
  1639. case RFAL_LM_STATE_POWER_OFF:
  1640. return ERR_LINK_LOSS;
  1641. default: /* Wait for activation */
  1642. break;
  1643. }
  1644. return ERR_INTERNAL;
  1645. }
  1646. #endif /* RFAL_FEATURE_LISTEN_MODE */
  1647. /*!
  1648. ******************************************************************************
  1649. * \brief Poller NFC DEP Activate
  1650. *
  1651. * This method performs NFC-DEP Activation
  1652. *
  1653. * \param[in] device : device info
  1654. * \param[in] commMode : communication mode (Passive/Active)
  1655. * \param[in] atrReq : received ATR_REQ
  1656. * \param[in] atrReqLen : received ATR_REQ size
  1657. *
  1658. * \return ERR_NONE : Operation completed with no error
  1659. * \return ERR_BUSY : Operation ongoing
  1660. * \return ERR_XXXX : Error occurred
  1661. *
  1662. ******************************************************************************
  1663. */
  1664. #if RFAL_FEATURE_NFC_DEP
  1665. static ReturnCode rfalNfcNfcDepActivate(
  1666. rfalNfcDevice* device,
  1667. rfalNfcDepCommMode commMode,
  1668. const uint8_t* atrReq,
  1669. uint16_t atrReqLen) {
  1670. rfalNfcDepAtrParam initParam;
  1671. /* Supress warnings if Listen mode is disabled */
  1672. NO_WARNING(atrReq);
  1673. NO_WARNING(atrReqLen);
  1674. /* If we are in Poll mode */
  1675. if(rfalNfcIsRemDevListener(device->type)) {
  1676. /*******************************************************************************/
  1677. /* If Passive F use the NFCID2 retrieved from SENSF */
  1678. if(device->type == RFAL_NFC_LISTEN_TYPE_NFCF) {
  1679. initParam.nfcid = device->dev.nfcf.sensfRes.NFCID2;
  1680. initParam.nfcidLen = RFAL_NFCF_NFCID2_LEN;
  1681. } else {
  1682. initParam.nfcid = gNfcDev.disc.nfcid3;
  1683. initParam.nfcidLen = RFAL_NFCDEP_NFCID3_LEN;
  1684. }
  1685. initParam.BS = RFAL_NFCDEP_Bx_NO_HIGH_BR;
  1686. initParam.BR = RFAL_NFCDEP_Bx_NO_HIGH_BR;
  1687. initParam.DID = RFAL_NFCDEP_DID_NO;
  1688. initParam.NAD = RFAL_NFCDEP_NAD_NO;
  1689. initParam.LR = RFAL_NFCDEP_LR_254;
  1690. initParam.GB = gNfcDev.disc.GB;
  1691. initParam.GBLen = gNfcDev.disc.GBLen;
  1692. initParam.commMode = commMode;
  1693. initParam.operParam =
  1694. (RFAL_NFCDEP_OPER_FULL_MI_EN | RFAL_NFCDEP_OPER_EMPTY_DEP_DIS |
  1695. RFAL_NFCDEP_OPER_ATN_EN | RFAL_NFCDEP_OPER_RTOX_REQ_EN);
  1696. rfalNfcDepInitialize();
  1697. /* Perform NFC-DEP (P2P) activation: ATR and PSL if supported */
  1698. return rfalNfcDepInitiatorHandleActivation(
  1699. &initParam, gNfcDev.disc.maxBR, &device->proto.nfcDep);
  1700. }
  1701. /* If we are in Listen mode */
  1702. #if RFAL_FEATURE_LISTEN_MODE
  1703. else if(rfalNfcIsRemDevPoller(device->type)) {
  1704. rfalNfcDepListenActvParam actvParams;
  1705. rfalNfcDepTargetParam targetParam;
  1706. ST_MEMCPY(targetParam.nfcid3, (uint8_t*)gNfcDev.disc.nfcid3, RFAL_NFCDEP_NFCID3_LEN);
  1707. targetParam.bst = RFAL_NFCDEP_Bx_NO_HIGH_BR;
  1708. targetParam.brt = RFAL_NFCDEP_Bx_NO_HIGH_BR;
  1709. targetParam.to = RFAL_NFCDEP_WT_TRG_MAX_L13; /* [LLCP] 1.3 6.2.1 */
  1710. targetParam.ppt = rfalNfcDepLR2PP(RFAL_NFCDEP_LR_254);
  1711. if(gNfcDev.disc.GBLen >= RFAL_NFCDEP_GB_MAX_LEN) {
  1712. return ERR_PARAM;
  1713. }
  1714. targetParam.GBtLen = gNfcDev.disc.GBLen;
  1715. if(gNfcDev.disc.GBLen > 0U) {
  1716. ST_MEMCPY(targetParam.GBt, gNfcDev.disc.GB, gNfcDev.disc.GBLen);
  1717. }
  1718. targetParam.operParam =
  1719. (RFAL_NFCDEP_OPER_FULL_MI_EN | RFAL_NFCDEP_OPER_EMPTY_DEP_DIS |
  1720. RFAL_NFCDEP_OPER_ATN_EN | RFAL_NFCDEP_OPER_RTOX_REQ_EN);
  1721. targetParam.commMode = commMode;
  1722. /* Set activation buffer (including header) for NFC-DEP */
  1723. actvParams.rxBuf =
  1724. (rfalNfcDepBufFormat*)&gNfcDev.rxBuf
  1725. .nfcDepBuf; /* PRQA S 0310 # MISRA 11.3 - Intentional safe cast to avoiding large buffer duplication */
  1726. actvParams.rxLen = &gNfcDev.rxLen;
  1727. actvParams.isRxChaining = &gNfcDev.isRxChaining;
  1728. actvParams.nfcDepDev = &gNfcDev.devList->proto.nfcDep;
  1729. rfalListenSetState(
  1730. ((device->type == RFAL_NFC_POLL_TYPE_NFCA) ? RFAL_LM_STATE_TARGET_A :
  1731. RFAL_LM_STATE_TARGET_F));
  1732. rfalNfcDepInitialize();
  1733. /* Perform NFC-DEP (P2P) activation: send ATR_RES and handle activation */
  1734. return rfalNfcDepListenStartActivation(&targetParam, atrReq, atrReqLen, actvParams);
  1735. }
  1736. #endif /* RFAL_FEATURE_LISTEN_MODE */
  1737. else {
  1738. return ERR_INTERNAL;
  1739. }
  1740. }
  1741. #endif /* RFAL_FEATURE_NFC_DEP */
  1742. /*!
  1743. ******************************************************************************
  1744. * \brief Poller NFC Deactivate
  1745. *
  1746. * This method Deactivates the device if a deactivation procedure exists
  1747. *
  1748. * \return ERR_NONE : Operation completed with no error
  1749. * \return ERR_BUSY : Operation ongoing
  1750. * \return ERR_XXXX : Error occurred
  1751. *
  1752. ******************************************************************************
  1753. */
  1754. static ReturnCode rfalNfcDeactivation(void) {
  1755. /* Check if a device has been activated */
  1756. if(gNfcDev.activeDev != NULL) {
  1757. if(rfalNfcIsRemDevListener(
  1758. gNfcDev.activeDev->type)) /* Listen mode no additional deactivation to be performed*/
  1759. {
  1760. #ifndef RFAL_NFC_SKIP_DEACT
  1761. switch(gNfcDev.activeDev->rfInterface) {
  1762. /*******************************************************************************/
  1763. case RFAL_NFC_INTERFACE_RF:
  1764. break; /* No specific deactivation to be performed */
  1765. /*******************************************************************************/
  1766. #if RFAL_FEATURE_ISO_DEP && RFAL_FEATURE_ISO_DEP_POLL
  1767. case RFAL_NFC_INTERFACE_ISODEP:
  1768. rfalIsoDepDeselect(); /* Send a Deselect to device */
  1769. break;
  1770. #endif /* RFAL_FEATURE_ISO_DEP_POLL */
  1771. /*******************************************************************************/
  1772. #if RFAL_FEATURE_NFC_DEP
  1773. case RFAL_NFC_INTERFACE_NFCDEP:
  1774. switch(gNfcDev.activeDev->type) {
  1775. case RFAL_NFC_LISTEN_TYPE_AP2P:
  1776. rfalNfcDepRLS(); /* Send a Release to device */
  1777. break;
  1778. default:
  1779. rfalNfcDepDSL(); /* Send a Deselect to device */
  1780. break;
  1781. }
  1782. break;
  1783. #endif /* RFAL_FEATURE_NFC_DEP */
  1784. default:
  1785. return ERR_REQUEST;
  1786. }
  1787. #endif /* RFAL_NFC_SKIP_DEACT */
  1788. }
  1789. }
  1790. #if RFAL_FEATURE_WAKEUP_MODE
  1791. rfalWakeUpModeStop();
  1792. #endif /* RFAL_FEATURE_WAKEUP_MODE */
  1793. #if RFAL_FEATURE_LISTEN_MODE
  1794. rfalListenStop();
  1795. #else
  1796. rfalFieldOff();
  1797. #endif
  1798. gNfcDev.activeDev = NULL;
  1799. return ERR_NONE;
  1800. }