Module_RFID.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050
  1. /*
  2. * Module_RFID.c
  3. *
  4. * Created on: 2019-10-24
  5. * Update: 2020-10-19
  6. * Author: Eason Yang
  7. * Version: V0.03
  8. *
  9. * History
  10. * 1. Added : Reyax code.
  11. *
  12. *
  13. *
  14. *
  15. *
  16. */
  17. #include "Module_RFID.h"
  18. //==================================
  19. // PRINT OUT LOG FORMAT
  20. //==================================
  21. #define SystemLogMessage
  22. #define DEBUG_INFO_1(format, args...) StoreLogMessage("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  23. #define DEBUG_WARN_1(format, args...) StoreLogMessage("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  24. #define DEBUG_ERROR_1(format, args...) StoreLogMessage("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  25. //==================================
  26. // SYSTEM CONSTANT
  27. //==================================
  28. #define Debug
  29. #define ARRAY_SIZE(A) (sizeof(A) / sizeof(A[0]))
  30. #define PASS 1
  31. #define FAIL -1
  32. //==================================
  33. // RFID CMD CONSTANT
  34. //==================================
  35. unsigned int RFID_CMD_ISO1443A_REQUEST = 0x20;
  36. unsigned int RFID_CMD_ISO1443B_REQUEST = 0x60;
  37. unsigned int RFID_CMD_FELICA_POLLING_REQUEST = 0x2F;
  38. unsigned int RFID_CMD_HALT_14443A = 0x28;
  39. unsigned int RFID_CMD_BLOCK_READ = 0x21;
  40. unsigned int RFID_CMD_BLOCK_WRITE = 0x22;
  41. unsigned int RFID_CMD_BUZZER_SET = 0x14;
  42. unsigned int RFID_CMD_RF_OUTPUT_LEVEL_SET = 0x02;
  43. unsigned int RFID_CMD_DEFAULT_AUTO_DETECTING_CARD = 0x1D;
  44. //==================================
  45. // RFID MODE CONSTANT
  46. //==================================
  47. unsigned char WUPA = 0;
  48. unsigned char REQA = 1;
  49. unsigned char AFI = 0;
  50. //==================================
  51. // MIFARE CARD LENGTH
  52. //==================================
  53. unsigned int LENGTH_0 = 0;
  54. unsigned int LENGTH_4 = 4;
  55. unsigned int LENGTH_6 = 6;
  56. unsigned int LENGTH_7 = 7;
  57. unsigned int LENGTH_10 = 10;
  58. //==================================
  59. // RF output Level constant
  60. //==================================
  61. unsigned int RF_STRONGEST = 0x00;
  62. unsigned int RF_STRONGER = 0x01;
  63. unsigned int RF_WEAK = 0x02;
  64. unsigned int RF_WEAKEST = 0x03;
  65. //==================================
  66. // Default of Automatic Detecting constant
  67. //==================================
  68. unsigned int TURN_OFF = 0x00;
  69. unsigned int TURN_ON = 0X01;
  70. unsigned int TURN_TEMPORARILY = 0x11;
  71. //==================================
  72. // MIFARE SECTOR SPACE
  73. //==================================
  74. #define ROW 6
  75. #define COLUMN 16
  76. unsigned char sectorKeyA[COLUMN][ROW] = { {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  77. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  78. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  79. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  80. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  81. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  82. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  83. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  84. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  85. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  86. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  87. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  88. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  89. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  90. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
  91. {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}
  92. };
  93. unsigned char serialNumber[32];
  94. unsigned int cardLength;
  95. //==================================
  96. // SystemLog message
  97. //==================================
  98. #ifdef SystemLogMessage
  99. int StoreLogMessage(const char *fmt, ...)
  100. {
  101. char Buf[4096 + 256];
  102. char buffer[4096];
  103. time_t CurrentTime;
  104. struct tm *tm;
  105. va_list args;
  106. va_start(args, fmt);
  107. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  108. va_end(args);
  109. memset(Buf, 0, sizeof(Buf));
  110. CurrentTime = time(NULL);
  111. tm = localtime(&CurrentTime);
  112. sprintf(Buf,
  113. "echo \"[%04d.%02d.%02d %02d:%02d:%02d] - %s\" >> /Storage/SystemLog/[%04d.%02d]RFID_SystemLog",
  114. tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday, tm->tm_hour,
  115. tm->tm_min, tm->tm_sec, buffer, tm->tm_year + 1900, tm->tm_mon + 1);
  116. system(Buf);
  117. #ifdef Debug
  118. printf("[%04d.%02d.%02d %02d:%02d:%02d] - %s", tm->tm_year + 1900,
  119. tm->tm_mon + 1, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec,
  120. buffer);
  121. #endif
  122. return rc;
  123. }
  124. #endif
  125. //==========================================
  126. // Module's command send/receive
  127. //==========================================
  128. int system_command(int uart, unsigned char* cmd,int length, unsigned char* rx)
  129. {
  130. int len;
  131. //sleep(2); //required to make flush work, for some reason
  132. tcflush(uart,TCIOFLUSH);
  133. if(write(uart, cmd, length) >= 0)
  134. {
  135. usleep(100000);
  136. len = read(uart, rx, 256);
  137. }
  138. else
  139. {
  140. DEBUG_ERROR_1("system command %s response fail.\n", cmd);
  141. }
  142. return len;
  143. }
  144. //==========================================
  145. // Module's AT command send/receive (REYAX)
  146. //==========================================
  147. int at_command(int uart, unsigned char* cmd,int length, unsigned char* rx)
  148. {
  149. int len;
  150. //sleep(2); //required to make flush work, for some reason
  151. tcflush(uart,TCIOFLUSH);
  152. if(write(uart, cmd, length) >= ARRAY_SIZE(cmd))
  153. {
  154. usleep(100000);
  155. len = read(uart, rx, 512);
  156. }
  157. else
  158. {
  159. DEBUG_ERROR_1("AT command %s response fail.\n", cmd);
  160. }
  161. return len;
  162. }
  163. //==========================================
  164. // Calculation checksum function
  165. //==========================================
  166. char ClaCheckSum(unsigned char *buffer, int len)
  167. {
  168. int idx;
  169. char chksum = 0;
  170. for(idx = 0 ; idx < len-1 ; idx++)
  171. {
  172. chksum ^= *(buffer+idx);
  173. }
  174. return chksum;
  175. }
  176. int chksumValid(unsigned char * buffer)
  177. {
  178. int result = FAIL;
  179. int chksum = 0;
  180. if(buffer[0] > 2)
  181. {
  182. for(int idx=0;idx<(buffer[0]);idx++)
  183. {
  184. chksum ^= buffer[idx];
  185. }
  186. if(chksum == buffer[buffer[0]])
  187. result = PASS;
  188. }
  189. return result;
  190. }
  191. bool getRequestCardSN(int Fd, int moduleType, RFID* rfid)
  192. {
  193. bool isSuccess = false;
  194. if(ISO14443A_REQUEST_SN(Fd,moduleType,serialNumber) == true)
  195. {
  196. rfid->cardType = ISO14443A;
  197. if(cardLength == LENGTH_4)
  198. {
  199. rfid->snType = RFID_SN_TYPE_4BYTE;
  200. memcpy(rfid->currentCard, &serialNumber, 32);
  201. }
  202. else if(cardLength == LENGTH_7)
  203. {
  204. rfid->snType = RFID_SN_TYPE_7BYTE;
  205. memcpy(rfid->currentCard, &serialNumber, 32);
  206. }
  207. isSuccess = true;
  208. }
  209. else if(ISO14443B_REQUEST_SN(Fd,moduleType,serialNumber) == true)
  210. {
  211. rfid->cardType = IS014443B;
  212. rfid->snType = RFID_SN_TYPE_4BYTE;
  213. memcpy(rfid->currentCard, &serialNumber, 32);
  214. sleep(2);
  215. isSuccess = true;
  216. }
  217. else if(FELICA_REQUEST_SN(Fd,moduleType,serialNumber) == true)
  218. {
  219. rfid->cardType = FELICA;
  220. rfid->snType = RFID_SN_TYPE_6BYTE;
  221. memcpy(rfid->currentCard, &serialNumber, 32);
  222. sleep(2);
  223. isSuccess = true;
  224. }
  225. else
  226. {}
  227. return isSuccess;
  228. }
  229. //==========================================
  230. // ISO14443A Request SN function
  231. //==========================================
  232. bool ISO14443A_REQUEST_SN(int Fd, int moduleType, unsigned char *data)
  233. {
  234. bool isSuccess = false;
  235. int tx_len = 4;
  236. unsigned char txByte[4] = {0};
  237. unsigned char rxByte[254] = {0};
  238. unsigned char TX_MESSAGE[254] = {0};
  239. unsigned char RX_MESSAGE[254] = {0};
  240. unsigned char TMP_MESSAGE[254] = {0};
  241. unsigned char TX_LENGTH = 0;
  242. unsigned char RX_LENGTH = 0;
  243. switch(moduleType)
  244. {
  245. case MODULE_EWT:
  246. default:
  247. //===============================
  248. // Command
  249. //===============================
  250. txByte[0] = tx_len-1;
  251. txByte[1] = RFID_CMD_ISO1443A_REQUEST;
  252. txByte[2] = REQA;
  253. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  254. if(Fd > 0)
  255. {
  256. if(system_command(Fd, txByte, tx_len, rxByte) > 0)
  257. {
  258. if(chksumValid(rxByte) == PASS)
  259. {
  260. if((rxByte[1] == RFID_CMD_ISO1443A_REQUEST))
  261. {
  262. if(rxByte[0] == 0x09)
  263. {
  264. cardLength = LENGTH_4;
  265. memcpy(data, rxByte+2, cardLength);
  266. DEBUG_INFO_1("MIFARE CLASSIC SN: %02X-%02X-%02X-%02X\n", data[0], data[1], data[2], data[3]);
  267. isSuccess = true;
  268. }
  269. else if(rxByte[0] == 0x0C)
  270. {
  271. cardLength = LENGTH_7;
  272. memcpy(data, rxByte+2, cardLength);
  273. DEBUG_INFO_1("MIFARE PLUS SN: %02X-%02X-%02X-%02X-%02X-%02X-%02X\n", data[0], data[1], data[2], data[3], data[4], data[5], data[6]);
  274. isSuccess = true;
  275. }
  276. else
  277. {}
  278. }
  279. else if (rxByte[1] == 0xDF)
  280. {
  281. cardLength = LENGTH_0;
  282. isSuccess = false;
  283. }
  284. else
  285. {}
  286. }
  287. else
  288. {
  289. //DEBUG_ERROR_1("Response check sum mismatch.\n");
  290. }
  291. }
  292. else
  293. {}
  294. }
  295. else
  296. {}
  297. break;
  298. case MODULE_REYAX:
  299. if(Fd > 0)
  300. {
  301. memset(TX_MESSAGE, 0, sizeof(TX_MESSAGE));
  302. memset(RX_MESSAGE, 0, sizeof(RX_MESSAGE));
  303. strcpy((char*)TX_MESSAGE, "AT+SCAN=1\r\n");
  304. TX_LENGTH = strlen((char*)TX_MESSAGE);
  305. //DEBUG_INFO_1("ISO14443A TX_LENGTH : %d.\n", TX_LENGTH);
  306. //DEBUG_INFO_1("ISO14443A TX_MESSAGE : %s.\n", TX_MESSAGE);
  307. if((RX_LENGTH = at_command(Fd, TX_MESSAGE, TX_LENGTH, RX_MESSAGE)) > 0)
  308. {
  309. //DEBUG_INFO_1("ISO14443A RX_LENGTH : %d.\n", RX_LENGTH);
  310. //DEBUG_INFO_1("ISO14443A RX_MESSAGE : %s.\n", RX_MESSAGE);
  311. memset(TMP_MESSAGE, 0, sizeof(TMP_MESSAGE));
  312. if(strstr((char*)RX_MESSAGE, "+SCAN=ISO14443A:"))
  313. {
  314. if(RX_LENGTH == 26)
  315. {
  316. cardLength = LENGTH_4;
  317. memcpy(TMP_MESSAGE, RX_MESSAGE+16, (LENGTH_4*2));
  318. DEBUG_INFO_1("Mifare Classic tmp message : %s.\n", TMP_MESSAGE);
  319. sscanf((char*)TMP_MESSAGE, "%2X%2X%2X%2X", (unsigned int *)&data[0],
  320. (unsigned int *)&data[1],
  321. (unsigned int *)&data[2],
  322. (unsigned int *)&data[3]);
  323. isSuccess = true;
  324. }
  325. else if(RX_LENGTH == 32)
  326. {
  327. cardLength = LENGTH_7;
  328. memcpy(TMP_MESSAGE, RX_MESSAGE+16, (RFID_SN_TYPE_7BYTE*2));
  329. DEBUG_INFO_1("Mifare Plus tmp message : %s.\n", TMP_MESSAGE);
  330. sscanf((char*)TMP_MESSAGE, "%2X%2X%2X%2X%2X%2X%2X", (unsigned int *)&data[0],
  331. (unsigned int *)&data[1],
  332. (unsigned int *)&data[2],
  333. (unsigned int *)&data[3],
  334. (unsigned int *)&data[4],
  335. (unsigned int *)&data[5],
  336. (unsigned int *)&data[6]);
  337. isSuccess = true;
  338. }
  339. else
  340. {
  341. cardLength = LENGTH_0;
  342. isSuccess = false;
  343. }
  344. }
  345. else
  346. {}
  347. }
  348. else
  349. {}
  350. }
  351. else
  352. {}
  353. break;
  354. }
  355. return isSuccess;
  356. }
  357. //==========================================
  358. // ISO14443B Request SN function
  359. //==========================================
  360. bool ISO14443B_REQUEST_SN(int Fd, int moduleType, unsigned char *data)
  361. {
  362. bool isSuccess = false;
  363. int cardLength;
  364. int tx_len = 5;
  365. unsigned char txByte[5] = {0};
  366. unsigned char rxByte[254] = {0};
  367. /*
  368. unsigned char TX_MESSAGE[254];
  369. unsigned char RX_MESSAGE[254];
  370. unsigned char TMP_MESSAGE[254];
  371. unsigned char TX_LENGTH;
  372. unsigned char RX_LENGTH;
  373. */
  374. switch(moduleType)
  375. {
  376. case MODULE_EWT:
  377. default:
  378. //===============================
  379. // Command
  380. //===============================
  381. txByte[0] = tx_len-1;
  382. txByte[1] = RFID_CMD_ISO1443B_REQUEST;
  383. txByte[2] = WUPA;
  384. txByte[3] = AFI;
  385. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  386. if(Fd > 0)
  387. {
  388. if(system_command(Fd, txByte, tx_len, rxByte) > 0)
  389. {
  390. if(chksumValid(rxByte) == PASS)
  391. {
  392. if((rxByte[1] == RFID_CMD_ISO1443B_REQUEST) && (rxByte[0] >= 12))
  393. {
  394. cardLength = LENGTH_4;
  395. memcpy(data, rxByte+3, cardLength);
  396. DEBUG_INFO_1("ISO14443-B SN: %02X-%02X-%02X-%02X\n", data[0], data[1], data[2], data[3]);
  397. isSuccess = true;
  398. }
  399. else if(rxByte[1] == 0x9F)
  400. {
  401. cardLength = LENGTH_0;
  402. isSuccess = false;
  403. }
  404. else
  405. {}
  406. }
  407. else
  408. {
  409. //DEBUG_ERROR_1("Response check sum mismatch.\n");
  410. }
  411. }
  412. else
  413. {}
  414. }
  415. else
  416. {}
  417. break;
  418. case MODULE_REYAX:
  419. /*
  420. if(Fd > 0)
  421. {
  422. memset(TX_MESSAGE, 0, sizeof(TX_MESSAGE));
  423. memset(RX_MESSAGE, 0, sizeof(RX_MESSAGE));
  424. strcpy((char*)TX_MESSAGE, "AT+SCAN=2\r\n");
  425. TX_LENGTH = strlen((char*)TX_MESSAGE);
  426. //DEBUG_INFO_1("IS014443B TX_LENGTH : %d.\n", TX_LENGTH);
  427. //DEBUG_INFO_1("IS014443B TX_MESSAGE : %s.\n", TX_MESSAGE);
  428. if((RX_LENGTH = at_command(Fd, TX_MESSAGE, TX_LENGTH, RX_MESSAGE);) > 0)
  429. {
  430. //DEBUG_INFO_1("IS014443B RX_LENGTH : %d.\n", RX_LENGTH);
  431. //DEBUG_INFO_1("IS014443B RX MESSAGE : %s.\n", RX_MESSAGE);
  432. memset(TMP_MESSAGE, 0, sizeof TMP_MESSAGE);
  433. if(strstr((char*)RX_MESSAGE,"+SCAN=Felica:"))
  434. {
  435. if(RX_MESSAGE_LENGTH == 31)
  436. {
  437. cardLength = LENGTH_6;
  438. memcpy(TMP_MESSAGE, RX_MESSAGE+17, (LENGTH_6*2));
  439. DEBUG_INFO_1("IS014443B tmp message : %s...\n", TMP_MESSAGE);
  440. sscanf((char*)TMP_MESSAGE, "%2X%2X%2X%2X%2X%2X", (unsigned int *)&data[0],
  441. (unsigned int *)&data[1],
  442. (unsigned int *)&data[2],
  443. (unsigned int *)&data[3],
  444. (unsigned int *)&data[4],
  445. (unsigned int *)&data[5]);
  446. isSuccess = true;
  447. }
  448. else
  449. {
  450. cardLength = LENGTH_0;
  451. isSuccess = false;
  452. }
  453. }
  454. else
  455. {}
  456. }
  457. else
  458. {}
  459. }
  460. else
  461. {}
  462. */
  463. break;
  464. }
  465. return isSuccess;
  466. }
  467. //==========================================
  468. // FELICA Request SN function
  469. //==========================================
  470. bool FELICA_REQUEST_SN(int Fd, int moduleType, unsigned char *data)
  471. {
  472. bool isSuccess = false;
  473. int cardLength;
  474. int tx_len = 9;
  475. unsigned char txByte[9] = {0};
  476. unsigned char rxByte[254] = {0};
  477. unsigned char TX_MESSAGE[254] = {0};
  478. unsigned char RX_MESSAGE[254] = {0};
  479. unsigned char TMP_MESSAGE[254] = {0};
  480. unsigned char TX_LENGTH = 0;
  481. unsigned char RX_LENGTH = 0;
  482. switch(moduleType)
  483. {
  484. case MODULE_EWT:
  485. default:
  486. //===============================
  487. // Command
  488. //===============================
  489. txByte[0] = tx_len-1;
  490. txByte[1] = RFID_CMD_FELICA_POLLING_REQUEST;
  491. txByte[2] = 0x06;
  492. txByte[3] = 0x00;
  493. txByte[4] = 0xFF;
  494. txByte[5] = 0xFF;
  495. txByte[6] = 0x01;
  496. txByte[7] = 0x00;
  497. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  498. if(Fd > 0)
  499. {
  500. memset(rxByte, 0, sizeof (rxByte));
  501. if(system_command(Fd, txByte, tx_len, rxByte) > 0)
  502. {
  503. if(chksumValid(rxByte) == PASS)
  504. {
  505. if((rxByte[1] == RFID_CMD_FELICA_POLLING_REQUEST) && (rxByte[0] >= 22))
  506. {
  507. cardLength = LENGTH_6;
  508. memcpy(data, rxByte+6, cardLength);
  509. DEBUG_INFO_1("FELICA SN: %02X-%02X-%02X-%02X-%02X-%02X\n", data[0], data[1], data[2], data[3], data[4], data[5]);
  510. isSuccess = true;
  511. }
  512. else if(rxByte[1] == 0xD0)
  513. {
  514. cardLength = LENGTH_0;
  515. isSuccess = false;
  516. }
  517. else
  518. {}
  519. }
  520. else
  521. {
  522. //DEBUG_ERROR_1("Response check sum mismatch.\n");
  523. }
  524. }
  525. else
  526. {}
  527. }
  528. else
  529. {}
  530. break;
  531. case MODULE_REYAX:
  532. if(Fd > 0)
  533. {
  534. memset(TX_MESSAGE, 0, sizeof(TX_MESSAGE));
  535. memset(RX_MESSAGE, 0, sizeof(RX_MESSAGE));
  536. strcpy((char*)TX_MESSAGE, "AT+SCAN=4\r\n");
  537. TX_LENGTH = strlen((char*)TX_MESSAGE);
  538. //DEBUG_INFO_1("FELICA TX_LENGTH : %d.\n", TX_LENGTH);
  539. //DEBUG_INFO_1("FELICA TX_MESSAGE : %s.\n", TX_MESSAGE);
  540. if((RX_LENGTH = at_command(Fd, TX_MESSAGE, TX_LENGTH, RX_MESSAGE)) > 0)
  541. {
  542. //DEBUG_INFO_1("FELICA RX_LENGTH : %d.\n", RX_LENGTH);
  543. //DEBUG_INFO_1("FELICA RX_MESSAGE : %s.\n", RX_MESSAGE);
  544. memset(TMP_MESSAGE, 0, sizeof(TMP_MESSAGE));
  545. if(strstr((char*)RX_MESSAGE,"+SCAN=Felica:"))
  546. {
  547. if(RX_LENGTH == 31)
  548. {
  549. cardLength = LENGTH_6;
  550. memcpy(TMP_MESSAGE, RX_MESSAGE+17, (LENGTH_6*2));
  551. DEBUG_INFO_1("Felica tmp message : %s.\n", TMP_MESSAGE);
  552. sscanf((char*)TMP_MESSAGE, "%2X%2X%2X%2X%2X%2X", (unsigned int *)&data[0],
  553. (unsigned int *)&data[1],
  554. (unsigned int *)&data[2],
  555. (unsigned int *)&data[3],
  556. (unsigned int *)&data[4],
  557. (unsigned int *)&data[5]);
  558. isSuccess = true;
  559. }
  560. else
  561. {
  562. cardLength = LENGTH_0;
  563. isSuccess = false;
  564. }
  565. }
  566. else
  567. {}
  568. }
  569. else
  570. {}
  571. }
  572. else
  573. {}
  574. break;
  575. }
  576. return isSuccess;
  577. }
  578. //==========================================
  579. // Read block data from RFID card
  580. //==========================================
  581. bool getBlockRead(int Fd, int moduleType, int block, unsigned char keyId, unsigned char *data)
  582. {
  583. bool isSuccess = false;
  584. int i;
  585. int j = 0;
  586. int len = 11;
  587. unsigned char txByte[len];
  588. unsigned char rxByte[254];
  589. unsigned char tmp[254];
  590. switch(moduleType)
  591. {
  592. case MODULE_EWT:
  593. default:
  594. //===============================
  595. // Command
  596. //===============================
  597. txByte[0] = 0x0A;
  598. txByte[1] = RFID_CMD_BLOCK_READ;
  599. txByte[2] = keyId;
  600. txByte[3] = block;
  601. for(i = 4; i < 10; i++)
  602. {
  603. if( j < sizeof (sectorKeyA[0]))
  604. {
  605. txByte[i] = sectorKeyA[(int)(block/4)][j];
  606. j++;
  607. }
  608. }
  609. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  610. if(Fd > 0)
  611. {
  612. memset(rxByte, 0, sizeof(rxByte));
  613. if(system_command(Fd, txByte, len, rxByte) > 0)
  614. {
  615. memset(tmp, 0, sizeof tmp);
  616. memcpy(tmp, rxByte, sizeof (rxByte));
  617. if((tmp[1] == RFID_CMD_BLOCK_READ))
  618. {
  619. DEBUG_INFO_1("Read block successfully.\n");
  620. memcpy(data, rxByte+2, 16);
  621. isSuccess = true;
  622. }
  623. else if (tmp[1] == 0xDE)
  624. {
  625. DEBUG_INFO_1("Read block unsuccessfully.\n");
  626. }
  627. else
  628. {}
  629. }
  630. else
  631. {}
  632. }
  633. else
  634. {}
  635. break;
  636. }
  637. return isSuccess;
  638. }
  639. //==========================================
  640. // Write data into RFID card block
  641. //==========================================
  642. bool setBlockWrite(int Fd, int moduleType, int block, unsigned char keyid, unsigned char *data)
  643. {
  644. bool isSuccess = false;
  645. int i;
  646. int j = 0;
  647. int len = 27;
  648. unsigned char txByte[len];
  649. unsigned char rxByte[254];
  650. unsigned char tmp[254];
  651. switch(moduleType)
  652. {
  653. case MODULE_EWT:
  654. default:
  655. //===============================
  656. // Command
  657. //===============================
  658. txByte[0] = 0x1A;
  659. txByte[1] = RFID_CMD_BLOCK_WRITE;
  660. txByte[2] = keyid;
  661. txByte[3] = block;
  662. for(i = 4; i < 10; i++)
  663. {
  664. if( j < sizeof (sectorKeyA[0]))
  665. {
  666. txByte[i] = sectorKeyA[(int)(block/4)][j];
  667. j++;
  668. }
  669. }
  670. memcpy(txByte+10, data, 16);
  671. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,(ARRAY_SIZE(txByte)));
  672. if(Fd > 0)
  673. {
  674. memset(rxByte, 0, sizeof(rxByte));
  675. if(system_command(Fd, txByte, len, rxByte) > 0)
  676. {
  677. memset(tmp, 0, sizeof tmp);
  678. memcpy(tmp, rxByte, sizeof (rxByte));
  679. if(tmp[1] == RFID_CMD_BLOCK_WRITE)
  680. {
  681. DEBUG_INFO_1("Write block successfully.\n");
  682. isSuccess = true;
  683. }
  684. else if(tmp[1] == 0xDD)
  685. {
  686. DEBUG_INFO_1("Write block unsuccessfully.\n");
  687. isSuccess = false;
  688. }
  689. else
  690. {}
  691. }
  692. else
  693. {}
  694. }
  695. else
  696. {}
  697. break;
  698. }
  699. return isSuccess;
  700. }
  701. //==========================================
  702. // Buzzer set (EWT Module)
  703. //==========================================
  704. void setBuzzer(int Fd, int moduleType, unsigned char time)
  705. {
  706. int len = 4;
  707. unsigned char txByte[len];
  708. unsigned char rxByte[254];
  709. unsigned char tmp[254];
  710. switch(moduleType)
  711. {
  712. case MODULE_EWT:
  713. default:
  714. //===============================
  715. // Command
  716. //===============================
  717. txByte[0] = 0x03;
  718. txByte[1] = RFID_CMD_BUZZER_SET;
  719. if(time > 0x0A)
  720. {
  721. time = 0x05;
  722. txByte[2] = time;
  723. DEBUG_WARN_1("Value is out of range.\n");
  724. }
  725. else
  726. {
  727. txByte[2] = time;
  728. }
  729. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  730. if(Fd > 0)
  731. {
  732. memset(rxByte, 0, sizeof(rxByte));
  733. if(system_command(Fd, txByte, len, rxByte) > 0)
  734. {
  735. memset(tmp, 0, sizeof tmp);
  736. memcpy(tmp, rxByte, sizeof (rxByte));
  737. if(tmp[1] == 0x14)
  738. {
  739. DEBUG_INFO_1("Set Buzzer ok.\n");
  740. DEBUG_INFO_1("Set Buzzer %d ms.\n",time);
  741. }
  742. else if(tmp[1] == 0xEC)
  743. {
  744. DEBUG_INFO_1("Set Buzzer fail.\n");
  745. }
  746. else
  747. {}
  748. }
  749. else
  750. {}
  751. }
  752. else
  753. {}
  754. break;
  755. }
  756. }
  757. //==========================================
  758. // Halt RFID card (EWT)
  759. //==========================================
  760. void sethaltCard(int Fd, int moduleType)
  761. {
  762. int len = 3;
  763. unsigned char txByte[len];
  764. unsigned char rxByte[254];
  765. unsigned char tmp[254];
  766. switch(moduleType)
  767. {
  768. case MODULE_EWT:
  769. default:
  770. //===============================
  771. // Command
  772. //===============================
  773. txByte[0] = 0x02;
  774. txByte[1] = RFID_CMD_HALT_14443A;
  775. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  776. if(Fd > 0)
  777. {
  778. memset(rxByte, 0, sizeof(rxByte));
  779. if(system_command(Fd, txByte, len, rxByte) > 0)
  780. {
  781. memset(tmp, 0, sizeof tmp);
  782. memcpy(tmp, rxByte, sizeof (rxByte));
  783. if(tmp[1] == 0x28)
  784. {
  785. DEBUG_INFO_1("Halt card pass.\n");
  786. }
  787. else if(tmp[1] == 0xD7)
  788. {
  789. DEBUG_INFO_1("Halt card fail.\n");
  790. }
  791. else
  792. {}
  793. }
  794. else
  795. {}
  796. }
  797. else
  798. {}
  799. break;
  800. }
  801. }
  802. //==========================================
  803. // Set the RF Output Level
  804. //==========================================
  805. bool setRfOutputLevel(int Fd, int moduleType, int Value)
  806. {
  807. bool isSuccess = false;
  808. int len = 4;
  809. unsigned char txByte[len];
  810. unsigned char rxByte[254];
  811. unsigned char tmp[254];
  812. switch(moduleType)
  813. {
  814. case MODULE_EWT:
  815. default:
  816. //===============================
  817. // Command
  818. //===============================
  819. txByte[0] = 0x03;
  820. txByte[1] = RFID_CMD_RF_OUTPUT_LEVEL_SET;
  821. txByte[2] = Value;
  822. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  823. if(Fd > 0)
  824. {
  825. memset(rxByte, 0, sizeof(rxByte));
  826. if(system_command(Fd, txByte, len, rxByte) > 0)
  827. {
  828. memset(tmp, 0, sizeof tmp);
  829. memcpy(tmp, rxByte, sizeof (rxByte));
  830. if(tmp[1] == RFID_CMD_RF_OUTPUT_LEVEL_SET)
  831. {
  832. DEBUG_INFO_1("Set the RF Output Level : Pass...\n");
  833. if(Value == RF_STRONGEST)
  834. {
  835. DEBUG_INFO_1("Strongest...\n");
  836. }
  837. else if(Value == RF_STRONGER)
  838. {
  839. DEBUG_INFO_1("Strong...\n");
  840. }
  841. else if(Value == RF_WEAK)
  842. {
  843. DEBUG_INFO_1("Weak...\n");
  844. }
  845. else if(Value == RF_WEAKEST)
  846. {
  847. DEBUG_INFO_1("Weakest...\n");
  848. }
  849. isSuccess = true;
  850. }
  851. else if(tmp[1] == 0xFD)
  852. {
  853. DEBUG_INFO_1("Set the RF Output Level : Fail...\n");
  854. DEBUG_INFO_1("Unknow value !!! \n");
  855. DEBUG_INFO_1("Strongest : SET_RF_STRONGEST...\n");
  856. DEBUG_INFO_1("Strong : SET_RF_STRONGER...\n");
  857. DEBUG_INFO_1("Weak : SET_RF_WEAK...\n");
  858. DEBUG_INFO_1("Weakest : SET_RF_WEAKEST...\n");
  859. isSuccess = false;
  860. }
  861. else
  862. {}
  863. }
  864. else
  865. {}
  866. }
  867. else
  868. {}
  869. break;
  870. }
  871. return isSuccess;
  872. }
  873. //==========================================
  874. // Set the Default of Automatic Detecting Card
  875. //==========================================
  876. bool setDefaultOfAutomaticDetectingCard(int Fd, int moduleType, int Value)
  877. {
  878. bool isSuccess = false;
  879. int len = 4;
  880. unsigned char txByte[len];
  881. unsigned char rxByte[254];
  882. unsigned char tmp[254];
  883. switch(moduleType)
  884. {
  885. case MODULE_EWT:
  886. default:
  887. //===============================
  888. // Command
  889. //===============================
  890. txByte[0] = 0x03;
  891. txByte[1] = RFID_CMD_DEFAULT_AUTO_DETECTING_CARD;
  892. txByte[2] = Value;
  893. txByte[ARRAY_SIZE(txByte)-1] = ClaCheckSum(txByte,ARRAY_SIZE(txByte));
  894. if(Fd > 0)
  895. {
  896. memset(rxByte, 0, sizeof(rxByte));
  897. if(system_command(Fd, txByte, len, rxByte) > 0)
  898. {
  899. memset(tmp, 0, sizeof tmp);
  900. memcpy(tmp, rxByte, sizeof (rxByte));
  901. if(tmp[1] == RFID_CMD_DEFAULT_AUTO_DETECTING_CARD)
  902. {
  903. if(Value == TURN_OFF)
  904. {
  905. DEBUG_INFO_1("Default of Automatic Detecting Card : OFF...\n");
  906. }
  907. else if (Value == TURN_ON)
  908. {
  909. DEBUG_INFO_1("Default of Automatic Detecting Card : ON...\n");
  910. }
  911. else if (Value == TURN_TEMPORARILY)
  912. {
  913. DEBUG_INFO_1("Default of Automatic Detecting Card : Temporarily open and close automatically detect card...\n");
  914. }
  915. isSuccess = true;
  916. }
  917. else if(tmp[1] == 0xE2)
  918. {
  919. DEBUG_INFO_1("Value : SET_DETECTING_OFF = OFF...\n");
  920. DEBUG_INFO_1("Value : SET_DETECTING_ON = ON...\n");
  921. DEBUG_INFO_1("Value : SET_DETECTING_TEMPORARILY = Temporarily open and close...\n");
  922. isSuccess = false;
  923. }
  924. else
  925. {}
  926. }
  927. else
  928. {}
  929. }
  930. else
  931. {}
  932. break;
  933. }
  934. return isSuccess;
  935. }