nfca.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #include "nfca.h"
  2. #include <string.h>
  3. #include <stdio.h>
  4. #include <furi.h>
  5. #define NFCA_CMD_RATS (0xE0U)
  6. #define NFCA_CRC_INIT (0x6363)
  7. #define NFCA_F_SIG (13560000.0)
  8. #define NFCA_T_SIG (1.0 / NFCA_F_SIG)
  9. #define NFCA_SIGNAL_MAX_EDGES (1350)
  10. typedef struct {
  11. uint8_t cmd;
  12. uint8_t param;
  13. } nfca_cmd_rats;
  14. static uint8_t nfca_default_ats[] = {0x05, 0x78, 0x80, 0x80, 0x00};
  15. static uint8_t nfca_sleep_req[] = {0x50, 0x00};
  16. uint16_t nfca_get_crc16(uint8_t* buff, uint16_t len) {
  17. uint16_t crc = NFCA_CRC_INIT;
  18. uint8_t byte = 0;
  19. for(uint8_t i = 0; i < len; i++) {
  20. byte = buff[i];
  21. byte ^= (uint8_t)(crc & 0xff);
  22. byte ^= byte << 4;
  23. crc = (crc >> 8) ^ (((uint16_t)byte) << 8) ^ (((uint16_t)byte) << 3) ^
  24. (((uint16_t)byte) >> 4);
  25. }
  26. return crc;
  27. }
  28. void nfca_append_crc16(uint8_t* buff, uint16_t len) {
  29. uint16_t crc = nfca_get_crc16(buff, len);
  30. buff[len] = (uint8_t)crc;
  31. buff[len + 1] = (uint8_t)(crc >> 8);
  32. }
  33. bool nfca_emulation_handler(
  34. uint8_t* buff_rx,
  35. uint16_t buff_rx_len,
  36. uint8_t* buff_tx,
  37. uint16_t* buff_tx_len) {
  38. bool sleep = false;
  39. uint8_t rx_bytes = buff_rx_len / 8;
  40. if(rx_bytes == sizeof(nfca_sleep_req) && !memcmp(buff_rx, nfca_sleep_req, rx_bytes)) {
  41. sleep = true;
  42. } else if(rx_bytes == sizeof(nfca_cmd_rats) && buff_rx[0] == NFCA_CMD_RATS) {
  43. memcpy(buff_tx, nfca_default_ats, sizeof(nfca_default_ats));
  44. *buff_tx_len = sizeof(nfca_default_ats) * 8;
  45. }
  46. return sleep;
  47. }
  48. static void nfca_add_bit(DigitalSignal* signal, bool bit) {
  49. if(bit) {
  50. signal->start_level = true;
  51. for(size_t i = 0; i < 7; i++) {
  52. signal->edge_timings[i] = 8 * NFCA_T_SIG;
  53. }
  54. signal->edge_timings[7] = 9 * 8 * NFCA_T_SIG;
  55. signal->edge_cnt = 8;
  56. } else {
  57. signal->start_level = false;
  58. signal->edge_timings[0] = 8 * 8 * NFCA_T_SIG;
  59. for(size_t i = 1; i < 9; i++) {
  60. signal->edge_timings[i] = 8 * NFCA_T_SIG;
  61. }
  62. signal->edge_cnt = 9;
  63. }
  64. }
  65. static void nfca_add_byte(NfcaSignal* nfca_signal, uint8_t byte, bool parity) {
  66. for(uint8_t i = 0; i < 8; i++) {
  67. if(byte & (1 << i)) {
  68. digital_signal_append(nfca_signal->tx_signal, nfca_signal->one);
  69. } else {
  70. digital_signal_append(nfca_signal->tx_signal, nfca_signal->zero);
  71. }
  72. }
  73. if(parity) {
  74. digital_signal_append(nfca_signal->tx_signal, nfca_signal->one);
  75. } else {
  76. digital_signal_append(nfca_signal->tx_signal, nfca_signal->zero);
  77. }
  78. }
  79. NfcaSignal* nfca_signal_alloc() {
  80. NfcaSignal* nfca_signal = malloc(sizeof(NfcaSignal));
  81. nfca_signal->one = digital_signal_alloc(10);
  82. nfca_signal->zero = digital_signal_alloc(10);
  83. nfca_add_bit(nfca_signal->one, true);
  84. nfca_add_bit(nfca_signal->zero, false);
  85. nfca_signal->tx_signal = digital_signal_alloc(NFCA_SIGNAL_MAX_EDGES);
  86. return nfca_signal;
  87. }
  88. void nfca_signal_free(NfcaSignal* nfca_signal) {
  89. furi_assert(nfca_signal);
  90. digital_signal_free(nfca_signal->one);
  91. digital_signal_free(nfca_signal->zero);
  92. digital_signal_free(nfca_signal->tx_signal);
  93. free(nfca_signal);
  94. }
  95. void nfca_signal_encode(NfcaSignal* nfca_signal, uint8_t* data, uint16_t bits, uint8_t* parity) {
  96. furi_assert(nfca_signal);
  97. furi_assert(data);
  98. furi_assert(parity);
  99. nfca_signal->tx_signal->edge_cnt = 0;
  100. nfca_signal->tx_signal->start_level = true;
  101. // Start of frame
  102. digital_signal_append(nfca_signal->tx_signal, nfca_signal->one);
  103. if(bits < 8) {
  104. for(size_t i = 0; i < bits; i++) {
  105. if(FURI_BIT(data[0], i)) {
  106. digital_signal_append(nfca_signal->tx_signal, nfca_signal->one);
  107. } else {
  108. digital_signal_append(nfca_signal->tx_signal, nfca_signal->zero);
  109. }
  110. }
  111. } else {
  112. for(size_t i = 0; i < bits / 8; i++) {
  113. nfca_add_byte(nfca_signal, data[i], parity[i / 8] & (1 << (7 - (i & 0x07))));
  114. }
  115. }
  116. }