mifare_ultralight.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. #pragma once
  2. #include <furi_hal_nfc.h>
  3. // Largest tag is NTAG I2C Plus 2K, both data sectors plus SRAM
  4. #define MF_UL_MAX_DUMP_SIZE ((238 + 256 + 16) * 4)
  5. #define MF_UL_TEARING_FLAG_DEFAULT (0xBD)
  6. #define MF_UL_HALT_START (0x50)
  7. #define MF_UL_GET_VERSION_CMD (0x60)
  8. #define MF_UL_READ_CMD (0x30)
  9. #define MF_UL_FAST_READ_CMD (0x3A)
  10. #define MF_UL_WRITE (0xA2)
  11. #define MF_UL_FAST_WRITE (0xA6)
  12. #define MF_UL_COMP_WRITE (0xA0)
  13. #define MF_UL_READ_CNT (0x39)
  14. #define MF_UL_INC_CNT (0xA5)
  15. #define MF_UL_AUTH (0x1B)
  16. #define MF_UL_READ_SIG (0x3C)
  17. #define MF_UL_CHECK_TEARING (0x3E)
  18. #define MF_UL_READ_VCSL (0x4B)
  19. #define MF_UL_SECTOR_SELECT (0xC2)
  20. #define MF_UL_ACK (0xa)
  21. #define MF_UL_NAK_INVALID_ARGUMENT (0x0)
  22. #define MF_UL_NAK_AUTHLIM_REACHED (0x4)
  23. typedef enum {
  24. MfUltralightTypeUnknown,
  25. MfUltralightTypeUL11,
  26. MfUltralightTypeUL21,
  27. MfUltralightTypeNTAG213,
  28. MfUltralightTypeNTAG215,
  29. MfUltralightTypeNTAG216,
  30. MfUltralightTypeNTAGI2C1K,
  31. MfUltralightTypeNTAGI2C2K,
  32. MfUltralightTypeNTAGI2CPlus1K,
  33. MfUltralightTypeNTAGI2CPlus2K,
  34. // Keep last for number of types calculation
  35. MfUltralightTypeNum,
  36. } MfUltralightType;
  37. typedef enum {
  38. MfUltralightSupportNone = 0,
  39. MfUltralightSupportFastRead = 1 << 0,
  40. MfUltralightSupportTearingFlags = 1 << 1,
  41. MfUltralightSupportReadCounter = 1 << 2,
  42. MfUltralightSupportIncrCounter = 1 << 3,
  43. MfUltralightSupportSignature = 1 << 4,
  44. MfUltralightSupportFastWrite = 1 << 5,
  45. MfUltralightSupportCompatWrite = 1 << 6,
  46. MfUltralightSupportAuth = 1 << 7,
  47. MfUltralightSupportVcsl = 1 << 8,
  48. MfUltralightSupportSectorSelect = 1 << 9,
  49. // NTAG21x only has counter 2
  50. MfUltralightSupportSingleCounter = 1 << 10,
  51. // ASCII mirror is not a command, but handy to have as a flag
  52. MfUltralightSupportAsciiMirror = 1 << 11,
  53. } MfUltralightFeatures;
  54. typedef enum {
  55. MfUltralightMirrorNone,
  56. MfUltralightMirrorUid,
  57. MfUltralightMirrorCounter,
  58. MfUltralightMirrorUidCounter,
  59. } MfUltralightMirrorConf;
  60. typedef struct {
  61. uint8_t header;
  62. uint8_t vendor_id;
  63. uint8_t prod_type;
  64. uint8_t prod_subtype;
  65. uint8_t prod_ver_major;
  66. uint8_t prod_ver_minor;
  67. uint8_t storage_size;
  68. uint8_t protocol_type;
  69. } MfUltralightVersion;
  70. typedef struct {
  71. uint8_t sn0[3];
  72. uint8_t btBCC0;
  73. uint8_t sn1[4];
  74. uint8_t btBCC1;
  75. uint8_t internal;
  76. uint8_t lock[2];
  77. uint8_t otp[4];
  78. } MfUltralightManufacturerBlock;
  79. typedef struct {
  80. MfUltralightType type;
  81. MfUltralightVersion version;
  82. uint8_t signature[32];
  83. uint32_t counter[3];
  84. uint8_t tearing[3];
  85. uint16_t curr_authlim;
  86. uint16_t data_size;
  87. uint8_t data[MF_UL_MAX_DUMP_SIZE];
  88. } MfUltralightData;
  89. typedef struct __attribute__((packed)) {
  90. union {
  91. uint8_t raw[4];
  92. uint32_t value;
  93. } pwd;
  94. union {
  95. uint8_t raw[2];
  96. uint16_t value;
  97. } pack;
  98. } MfUltralightAuth;
  99. // Common configuration pages for MFUL EV1, NTAG21x, and NTAG I2C Plus
  100. typedef struct __attribute__((packed)) {
  101. union {
  102. uint8_t value;
  103. struct {
  104. uint8_t rfui1 : 2;
  105. bool strg_mod_en : 1;
  106. bool rfui2 : 1;
  107. uint8_t mirror_byte : 2;
  108. MfUltralightMirrorConf mirror_conf : 2;
  109. };
  110. } mirror;
  111. uint8_t rfui1;
  112. uint8_t mirror_page;
  113. uint8_t auth0;
  114. union {
  115. uint8_t value;
  116. struct {
  117. uint8_t authlim : 3;
  118. bool nfc_cnt_pwd_prot : 1;
  119. bool nfc_cnt_en : 1;
  120. bool nfc_dis_sec1 : 1; // NTAG I2C Plus only
  121. bool cfglck : 1;
  122. bool prot : 1;
  123. };
  124. } access;
  125. uint8_t vctid;
  126. uint8_t rfui2[2];
  127. MfUltralightAuth auth_data;
  128. uint8_t rfui3[2];
  129. } MfUltralightConfigPages;
  130. typedef struct {
  131. uint16_t pages_to_read;
  132. int16_t pages_read;
  133. MfUltralightFeatures supported_features;
  134. } MfUltralightReader;
  135. typedef struct {
  136. MfUltralightData data;
  137. MfUltralightConfigPages* config;
  138. // Most config values don't apply until power cycle, so cache config pages
  139. // for correct behavior
  140. MfUltralightConfigPages config_cache;
  141. MfUltralightFeatures supported_features;
  142. uint16_t page_num;
  143. bool data_changed;
  144. bool comp_write_cmd_started;
  145. uint8_t comp_write_page_addr;
  146. bool auth_success;
  147. uint8_t curr_sector;
  148. bool sector_select_cmd_started;
  149. bool ntag_i2c_plus_sector3_lockout;
  150. bool read_counter_incremented;
  151. } MfUltralightEmulator;
  152. bool mf_ul_check_card_type(uint8_t ATQA0, uint8_t ATQA1, uint8_t SAK);
  153. bool mf_ultralight_read_version(
  154. FuriHalNfcTxRxContext* tx_rx,
  155. MfUltralightReader* reader,
  156. MfUltralightData* data);
  157. bool mf_ultralight_read_pages(
  158. FuriHalNfcTxRxContext* tx_rx,
  159. MfUltralightReader* reader,
  160. MfUltralightData* data);
  161. bool mf_ultralight_fast_read_pages(
  162. FuriHalNfcTxRxContext* tx_rx,
  163. MfUltralightReader* reader,
  164. MfUltralightData* data);
  165. bool mf_ultralight_read_signature(FuriHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  166. bool mf_ultralight_read_counters(FuriHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  167. bool mf_ultralight_read_tearing_flags(FuriHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  168. bool mf_ul_read_card(
  169. FuriHalNfcTxRxContext* tx_rx,
  170. MfUltralightReader* reader,
  171. MfUltralightData* data);
  172. void mf_ul_reset_emulation(MfUltralightEmulator* emulator, bool is_power_cycle);
  173. void mf_ul_prepare_emulation(MfUltralightEmulator* emulator, MfUltralightData* data);
  174. bool mf_ul_prepare_emulation_response(
  175. uint8_t* buff_rx,
  176. uint16_t buff_rx_len,
  177. uint8_t* buff_tx,
  178. uint16_t* buff_tx_len,
  179. uint32_t* data_type,
  180. void* context);