mifare_ultralight.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. #pragma once
  2. #include "../furi_hal_nfc.h"
  3. #ifdef __cplusplus
  4. extern "C" {
  5. #endif
  6. // Largest tag is NTAG I2C Plus 2K, both data sectors plus SRAM
  7. #define MF_UL_MAX_DUMP_SIZE ((238 + 256 + 16) * 4)
  8. #define MF_UL_TEARING_FLAG_DEFAULT (0xBD)
  9. #define MF_UL_HALT_START (0x50)
  10. #define MF_UL_GET_VERSION_CMD (0x60)
  11. #define MF_UL_READ_CMD (0x30)
  12. #define MF_UL_FAST_READ_CMD (0x3A)
  13. #define MF_UL_WRITE (0xA2)
  14. #define MF_UL_FAST_WRITE (0xA6)
  15. #define MF_UL_COMP_WRITE (0xA0)
  16. #define MF_UL_READ_CNT (0x39)
  17. #define MF_UL_INC_CNT (0xA5)
  18. #define MF_UL_AUTHENTICATE_1 (0x1A)
  19. #define MF_UL_PWD_AUTH (0x1B)
  20. #define MF_UL_READ_SIG (0x3C)
  21. #define MF_UL_CHECK_TEARING (0x3E)
  22. #define MF_UL_READ_VCSL (0x4B)
  23. #define MF_UL_SECTOR_SELECT (0xC2)
  24. #define MF_UL_ACK (0xa)
  25. #define MF_UL_NAK_INVALID_ARGUMENT (0x0)
  26. #define MF_UL_NAK_AUTHLIM_REACHED (0x4)
  27. #define MF_UL_NTAG203_COUNTER_PAGE (41)
  28. #define MF_UL_DEFAULT_PWD (0xFFFFFFFF)
  29. typedef enum {
  30. MfUltralightAuthMethodManual,
  31. MfUltralightAuthMethodAmeebo,
  32. MfUltralightAuthMethodXiaomi,
  33. MfUltralightAuthMethodAuto,
  34. } MfUltralightAuthMethod;
  35. // Important: order matters; some features are based on positioning in this enum
  36. typedef enum {
  37. MfUltralightTypeUnknown,
  38. MfUltralightTypeNTAG203,
  39. MfUltralightTypeULC,
  40. // Below have config pages and GET_VERSION support
  41. MfUltralightTypeUL11,
  42. MfUltralightTypeUL21,
  43. MfUltralightTypeNTAG213,
  44. MfUltralightTypeNTAG215,
  45. MfUltralightTypeNTAG216,
  46. // Below also have sector select
  47. // NTAG I2C's *does not* have regular config pages, so it's a bit of an odd duck
  48. MfUltralightTypeNTAGI2C1K,
  49. MfUltralightTypeNTAGI2C2K,
  50. // NTAG I2C Plus has stucture expected from NTAG21x
  51. MfUltralightTypeNTAGI2CPlus1K,
  52. MfUltralightTypeNTAGI2CPlus2K,
  53. // Keep last for number of types calculation
  54. MfUltralightTypeNum,
  55. } MfUltralightType;
  56. typedef enum {
  57. MfUltralightSupportNone = 0,
  58. MfUltralightSupportFastRead = 1 << 0,
  59. MfUltralightSupportTearingFlags = 1 << 1,
  60. MfUltralightSupportReadCounter = 1 << 2,
  61. MfUltralightSupportIncrCounter = 1 << 3,
  62. MfUltralightSupportSignature = 1 << 4,
  63. MfUltralightSupportFastWrite = 1 << 5,
  64. MfUltralightSupportCompatWrite = 1 << 6,
  65. MfUltralightSupportAuth = 1 << 7,
  66. MfUltralightSupportVcsl = 1 << 8,
  67. MfUltralightSupportSectorSelect = 1 << 9,
  68. // NTAG21x only has counter 2
  69. MfUltralightSupportSingleCounter = 1 << 10,
  70. // ASCII mirror is not a command, but handy to have as a flag
  71. MfUltralightSupportAsciiMirror = 1 << 11,
  72. // NTAG203 counter that's in memory rather than through a command
  73. MfUltralightSupportCounterInMemory = 1 << 12,
  74. MfUltralightSupport3DesAuth = 1 << 13,
  75. } MfUltralightFeatures;
  76. typedef enum {
  77. MfUltralightMirrorNone,
  78. MfUltralightMirrorUid,
  79. MfUltralightMirrorCounter,
  80. MfUltralightMirrorUidCounter,
  81. } MfUltralightMirrorConf;
  82. typedef struct {
  83. uint8_t header;
  84. uint8_t vendor_id;
  85. uint8_t prod_type;
  86. uint8_t prod_subtype;
  87. uint8_t prod_ver_major;
  88. uint8_t prod_ver_minor;
  89. uint8_t storage_size;
  90. uint8_t protocol_type;
  91. } MfUltralightVersion;
  92. typedef struct {
  93. uint8_t sn0[3];
  94. uint8_t btBCC0;
  95. uint8_t sn1[4];
  96. uint8_t btBCC1;
  97. uint8_t internal;
  98. uint8_t lock[2];
  99. uint8_t otp[4];
  100. } MfUltralightManufacturerBlock;
  101. typedef struct {
  102. MfUltralightType type;
  103. MfUltralightVersion version;
  104. uint8_t signature[32];
  105. uint32_t counter[3];
  106. uint8_t tearing[3];
  107. MfUltralightAuthMethod auth_method;
  108. uint8_t auth_key[4];
  109. bool auth_success;
  110. uint16_t curr_authlim;
  111. uint16_t data_size;
  112. uint8_t data[MF_UL_MAX_DUMP_SIZE];
  113. uint16_t data_read;
  114. } MfUltralightData;
  115. typedef struct __attribute__((packed)) {
  116. union {
  117. uint8_t raw[4];
  118. uint32_t value;
  119. } pwd;
  120. union {
  121. uint8_t raw[2];
  122. uint16_t value;
  123. } pack;
  124. } MfUltralightAuth;
  125. // Common configuration pages for MFUL EV1, NTAG21x, and NTAG I2C Plus
  126. typedef struct __attribute__((packed)) {
  127. union {
  128. uint8_t value;
  129. struct {
  130. uint8_t rfui1 : 2;
  131. bool strg_mod_en : 1;
  132. bool rfui2 : 1;
  133. uint8_t mirror_byte : 2;
  134. MfUltralightMirrorConf mirror_conf : 2;
  135. };
  136. } mirror;
  137. uint8_t rfui1;
  138. uint8_t mirror_page;
  139. uint8_t auth0;
  140. union {
  141. uint8_t value;
  142. struct {
  143. uint8_t authlim : 3;
  144. bool nfc_cnt_pwd_prot : 1;
  145. bool nfc_cnt_en : 1;
  146. bool nfc_dis_sec1 : 1; // NTAG I2C Plus only
  147. bool cfglck : 1;
  148. bool prot : 1;
  149. };
  150. } access;
  151. uint8_t vctid;
  152. uint8_t rfui2[2];
  153. MfUltralightAuth auth_data;
  154. uint8_t rfui3[2];
  155. } MfUltralightConfigPages;
  156. typedef struct {
  157. uint16_t pages_to_read;
  158. int16_t pages_read;
  159. MfUltralightFeatures supported_features;
  160. } MfUltralightReader;
  161. // TODO rework with reader analyzer
  162. typedef void (*MfUltralightAuthReceivedCallback)(MfUltralightAuth auth, void* context);
  163. typedef struct {
  164. MfUltralightData data;
  165. MfUltralightConfigPages* config;
  166. // Most config values don't apply until power cycle, so cache config pages
  167. // for correct behavior
  168. MfUltralightConfigPages config_cache;
  169. MfUltralightFeatures supported_features;
  170. uint16_t page_num;
  171. bool data_changed;
  172. bool comp_write_cmd_started;
  173. uint8_t comp_write_page_addr;
  174. bool auth_success;
  175. uint8_t curr_sector;
  176. bool sector_select_cmd_started;
  177. bool ntag_i2c_plus_sector3_lockout;
  178. bool read_counter_incremented;
  179. bool auth_attempted;
  180. MfUltralightAuth auth_attempt;
  181. // TODO rework with reader analyzer
  182. MfUltralightAuthReceivedCallback auth_received_callback;
  183. void* context;
  184. } MfUltralightEmulator;
  185. void mf_ul_reset(MfUltralightData* data);
  186. bool mf_ul_check_card_type(uint8_t ATQA0, uint8_t ATQA1, uint8_t SAK);
  187. bool mf_ultralight_read_version(
  188. FurryHalNfcTxRxContext* tx_rx,
  189. MfUltralightReader* reader,
  190. MfUltralightData* data);
  191. bool mf_ultralight_read_pages_direct(
  192. FurryHalNfcTxRxContext* tx_rx,
  193. uint8_t start_index,
  194. uint8_t* data);
  195. bool mf_ultralight_read_pages(
  196. FurryHalNfcTxRxContext* tx_rx,
  197. MfUltralightReader* reader,
  198. MfUltralightData* data);
  199. bool mf_ultralight_fast_read_pages(
  200. FurryHalNfcTxRxContext* tx_rx,
  201. MfUltralightReader* reader,
  202. MfUltralightData* data);
  203. bool mf_ultralight_read_signature(FurryHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  204. bool mf_ultralight_read_counters(FurryHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  205. bool mf_ultralight_read_tearing_flags(FurryHalNfcTxRxContext* tx_rx, MfUltralightData* data);
  206. bool mf_ultralight_authenticate(FurryHalNfcTxRxContext* tx_rx, uint32_t key, uint16_t* pack);
  207. MfUltralightConfigPages* mf_ultralight_get_config_pages(MfUltralightData* data);
  208. bool mf_ul_read_card(
  209. FurryHalNfcTxRxContext* tx_rx,
  210. MfUltralightReader* reader,
  211. MfUltralightData* data);
  212. bool mf_ul_emulation_supported(MfUltralightData* data);
  213. void mf_ul_reset_emulation(MfUltralightEmulator* emulator, bool is_power_cycle);
  214. void mf_ul_prepare_emulation(MfUltralightEmulator* emulator, MfUltralightData* data);
  215. bool mf_ul_prepare_emulation_response(
  216. uint8_t* buff_rx,
  217. uint16_t buff_rx_len,
  218. uint8_t* buff_tx,
  219. uint16_t* buff_tx_len,
  220. uint32_t* data_type,
  221. void* context);
  222. uint32_t mf_ul_pwdgen_amiibo(FurryHalNfcDevData* data);
  223. uint32_t mf_ul_pwdgen_xiaomi(FurryHalNfcDevData* data);
  224. bool mf_ul_is_full_capture(MfUltralightData* data);
  225. #ifdef __cplusplus
  226. }
  227. #endif