nfc_generators.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480
  1. #include <furi_hal_random.h>
  2. #include "nfc_generators.h"
  3. #define NXP_MANUFACTURER_ID (0x04)
  4. static const uint8_t version_bytes_mf0ulx1[] = {0x00, 0x04, 0x03, 0x00, 0x01, 0x00, 0x00, 0x03};
  5. static const uint8_t version_bytes_ntag21x[] = {0x00, 0x04, 0x04, 0x02, 0x01, 0x00, 0x00, 0x03};
  6. static const uint8_t version_bytes_ntag_i2c[] = {0x00, 0x04, 0x04, 0x05, 0x02, 0x00, 0x00, 0x03};
  7. static const uint8_t default_data_ntag203[] =
  8. {0xE1, 0x10, 0x12, 0x00, 0x01, 0x03, 0xA0, 0x10, 0x44, 0x03, 0x00, 0xFE};
  9. static const uint8_t default_data_ntag213[] = {0x01, 0x03, 0xA0, 0x0C, 0x34, 0x03, 0x00, 0xFE};
  10. static const uint8_t default_data_ntag215_216[] = {0x03, 0x00, 0xFE};
  11. static const uint8_t default_data_ntag_i2c[] = {0xE1, 0x10, 0x00, 0x00, 0x03, 0x00, 0xFE};
  12. static const uint8_t default_config_ntag_i2c[] = {0x01, 0x00, 0xF8, 0x48, 0x08, 0x01, 0x00, 0x00};
  13. static void nfc_generate_common_start(NfcDeviceData* data) {
  14. nfc_device_data_clear(data);
  15. }
  16. static void nfc_generate_mf_ul_uid(uint8_t* uid) {
  17. uid[0] = NXP_MANUFACTURER_ID;
  18. furi_hal_random_fill_buf(&uid[1], 6);
  19. // I'm not sure how this is generated, but the upper nybble always seems to be 8
  20. uid[6] &= 0x0F;
  21. uid[6] |= 0x80;
  22. }
  23. static void nfc_generate_mf_classic_uid(uint8_t* uid, uint8_t length) {
  24. uid[0] = NXP_MANUFACTURER_ID;
  25. furi_hal_random_fill_buf(&uid[1], length - 1);
  26. }
  27. static void nfc_generate_mf_classic_block_0(uint8_t* block, uint8_t uid_len) {
  28. // Block length is always 16 bytes, and the UID can be either 4 or 7 bytes
  29. furi_assert(uid_len == 4 || uid_len == 7);
  30. furi_assert(block);
  31. nfc_generate_mf_classic_uid(block, uid_len);
  32. for(int i = uid_len; i < 16; i++) {
  33. block[i] = 0xFF;
  34. }
  35. }
  36. static void nfc_generate_mf_classic_sector_trailer(MfClassicData* data, uint8_t block) {
  37. // All keys are set to FFFF FFFF FFFFh at chip delivery and the bytes 6, 7 and 8 are set to FF0780h.
  38. MfClassicSectorTrailer* sec_tr = (MfClassicSectorTrailer*)data->block[block].value;
  39. sec_tr->access_bits[0] = 0xFF;
  40. sec_tr->access_bits[1] = 0x07;
  41. sec_tr->access_bits[2] = 0x80;
  42. sec_tr->access_bits[3] = 0x69; // Nice
  43. memset(sec_tr->key_a, 0xff, sizeof(sec_tr->key_a));
  44. memset(sec_tr->key_b, 0xff, sizeof(sec_tr->key_b));
  45. mf_classic_set_block_read(data, block, &data->block[block]);
  46. mf_classic_set_key_found(
  47. data, mf_classic_get_sector_by_block(block), MfClassicKeyA, 0xFFFFFFFFFFFF);
  48. mf_classic_set_key_found(
  49. data, mf_classic_get_sector_by_block(block), MfClassicKeyB, 0xFFFFFFFFFFFF);
  50. }
  51. static void nfc_generate_mf_ul_common(NfcDeviceData* data) {
  52. data->nfc_data.type = FuriHalNfcTypeA;
  53. data->nfc_data.interface = FuriHalNfcInterfaceRf;
  54. data->nfc_data.uid_len = 7;
  55. nfc_generate_mf_ul_uid(data->nfc_data.uid);
  56. data->nfc_data.atqa[0] = 0x44;
  57. data->nfc_data.atqa[1] = 0x00;
  58. data->nfc_data.sak = 0x00;
  59. data->protocol = NfcDeviceProtocolMifareUl;
  60. }
  61. static void
  62. nfc_generate_mf_classic_common(NfcDeviceData* data, uint8_t uid_len, MfClassicType type) {
  63. data->nfc_data.type = FuriHalNfcTypeA;
  64. data->nfc_data.interface = FuriHalNfcInterfaceRf;
  65. data->nfc_data.uid_len = uid_len;
  66. nfc_generate_mf_classic_block_0(data->mf_classic_data.block[0].value, uid_len);
  67. data->nfc_data.atqa[0] = 0x44;
  68. data->nfc_data.atqa[1] = 0x00;
  69. data->nfc_data.sak = 0x08;
  70. data->protocol = NfcDeviceProtocolMifareClassic;
  71. data->mf_classic_data.type = type;
  72. }
  73. static void nfc_generate_calc_bcc(uint8_t* uid, uint8_t* bcc0, uint8_t* bcc1) {
  74. *bcc0 = 0x88 ^ uid[0] ^ uid[1] ^ uid[2];
  75. *bcc1 = uid[3] ^ uid[4] ^ uid[5] ^ uid[6];
  76. }
  77. static void nfc_generate_mf_ul_copy_uid_with_bcc(NfcDeviceData* data) {
  78. MfUltralightData* mful = &data->mf_ul_data;
  79. memcpy(mful->data, data->nfc_data.uid, 3);
  80. memcpy(&mful->data[4], &data->nfc_data.uid[3], 4);
  81. nfc_generate_calc_bcc(data->nfc_data.uid, &mful->data[3], &mful->data[8]);
  82. }
  83. static void nfc_generate_mf_ul_orig(NfcDeviceData* data) {
  84. nfc_generate_common_start(data);
  85. nfc_generate_mf_ul_common(data);
  86. MfUltralightData* mful = &data->mf_ul_data;
  87. mful->type = MfUltralightTypeUnknown;
  88. mful->data_size = 16 * 4;
  89. mful->data_read = mful->data_size;
  90. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  91. // TODO: what's internal byte on page 2?
  92. memset(&mful->data[4 * 4], 0xFF, 4);
  93. }
  94. static void nfc_generate_mf_ul_ntag203(NfcDeviceData* data) {
  95. nfc_generate_common_start(data);
  96. nfc_generate_mf_ul_common(data);
  97. MfUltralightData* mful = &data->mf_ul_data;
  98. mful->type = MfUltralightTypeNTAG203;
  99. mful->data_size = 42 * 4;
  100. mful->data_read = mful->data_size;
  101. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  102. mful->data[9] = 0x48; // Internal byte
  103. memcpy(&mful->data[3 * 4], default_data_ntag203, sizeof(default_data_ntag203));
  104. }
  105. static void nfc_generate_mf_ul_with_config_common(NfcDeviceData* data, uint8_t num_pages) {
  106. nfc_generate_common_start(data);
  107. nfc_generate_mf_ul_common(data);
  108. MfUltralightData* mful = &data->mf_ul_data;
  109. mful->data_size = num_pages * 4;
  110. mful->data_read = mful->data_size;
  111. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  112. uint16_t config_index = (num_pages - 4) * 4;
  113. mful->data[config_index] = 0x04; // STRG_MOD_EN
  114. mful->data[config_index + 3] = 0xFF; // AUTH0
  115. mful->data[config_index + 5] = 0x05; // VCTID
  116. memset(&mful->data[config_index + 8], 0xFF, 4); // Default PWD
  117. if(num_pages > 20) mful->data[config_index - 1] = MF_UL_TEARING_FLAG_DEFAULT;
  118. }
  119. static void nfc_generate_mf_ul_ev1_common(NfcDeviceData* data, uint8_t num_pages) {
  120. nfc_generate_mf_ul_with_config_common(data, num_pages);
  121. MfUltralightData* mful = &data->mf_ul_data;
  122. memcpy(&mful->version, version_bytes_mf0ulx1, sizeof(version_bytes_mf0ulx1));
  123. for(size_t i = 0; i < 3; ++i) {
  124. mful->tearing[i] = MF_UL_TEARING_FLAG_DEFAULT;
  125. }
  126. // TODO: what's internal byte on page 2?
  127. }
  128. static void nfc_generate_mf_ul_11(NfcDeviceData* data) {
  129. nfc_generate_mf_ul_ev1_common(data, 20);
  130. MfUltralightData* mful = &data->mf_ul_data;
  131. mful->type = MfUltralightTypeUL11;
  132. mful->version.prod_subtype = 0x01;
  133. mful->version.storage_size = 0x0B;
  134. mful->data[16 * 4] = 0x00; // Low capacitance version does not have STRG_MOD_EN
  135. }
  136. static void nfc_generate_mf_ul_h11(NfcDeviceData* data) {
  137. nfc_generate_mf_ul_ev1_common(data, 20);
  138. MfUltralightData* mful = &data->mf_ul_data;
  139. mful->type = MfUltralightTypeUL11;
  140. mful->version.prod_subtype = 0x02;
  141. mful->version.storage_size = 0x0B;
  142. }
  143. static void nfc_generate_mf_ul_21(NfcDeviceData* data) {
  144. nfc_generate_mf_ul_ev1_common(data, 41);
  145. MfUltralightData* mful = &data->mf_ul_data;
  146. mful->type = MfUltralightTypeUL21;
  147. mful->version.prod_subtype = 0x01;
  148. mful->version.storage_size = 0x0E;
  149. mful->data[37 * 4] = 0x00; // Low capacitance version does not have STRG_MOD_EN
  150. }
  151. static void nfc_generate_mf_ul_h21(NfcDeviceData* data) {
  152. nfc_generate_mf_ul_ev1_common(data, 41);
  153. MfUltralightData* mful = &data->mf_ul_data;
  154. mful->type = MfUltralightTypeUL21;
  155. mful->version.prod_subtype = 0x02;
  156. mful->version.storage_size = 0x0E;
  157. }
  158. static void nfc_generate_ntag21x_common(NfcDeviceData* data, uint8_t num_pages) {
  159. nfc_generate_mf_ul_with_config_common(data, num_pages);
  160. MfUltralightData* mful = &data->mf_ul_data;
  161. memcpy(&mful->version, version_bytes_ntag21x, sizeof(version_bytes_mf0ulx1));
  162. mful->data[9] = 0x48; // Internal byte
  163. // Capability container
  164. mful->data[12] = 0xE1;
  165. mful->data[13] = 0x10;
  166. }
  167. static void nfc_generate_ntag213(NfcDeviceData* data) {
  168. nfc_generate_ntag21x_common(data, 45);
  169. MfUltralightData* mful = &data->mf_ul_data;
  170. mful->type = MfUltralightTypeNTAG213;
  171. mful->version.storage_size = 0x0F;
  172. mful->data[14] = 0x12;
  173. // Default contents
  174. memcpy(&mful->data[16], default_data_ntag213, sizeof(default_data_ntag213));
  175. }
  176. static void nfc_generate_ntag215(NfcDeviceData* data) {
  177. nfc_generate_ntag21x_common(data, 135);
  178. MfUltralightData* mful = &data->mf_ul_data;
  179. mful->type = MfUltralightTypeNTAG215;
  180. mful->version.storage_size = 0x11;
  181. mful->data[14] = 0x3E;
  182. // Default contents
  183. memcpy(&mful->data[16], default_data_ntag215_216, sizeof(default_data_ntag215_216));
  184. }
  185. static void nfc_generate_ntag216(NfcDeviceData* data) {
  186. nfc_generate_ntag21x_common(data, 231);
  187. MfUltralightData* mful = &data->mf_ul_data;
  188. mful->type = MfUltralightTypeNTAG216;
  189. mful->version.storage_size = 0x13;
  190. mful->data[14] = 0x6D;
  191. // Default contents
  192. memcpy(&mful->data[16], default_data_ntag215_216, sizeof(default_data_ntag215_216));
  193. }
  194. static void
  195. nfc_generate_ntag_i2c_common(NfcDeviceData* data, MfUltralightType type, uint16_t num_pages) {
  196. nfc_generate_common_start(data);
  197. nfc_generate_mf_ul_common(data);
  198. MfUltralightData* mful = &data->mf_ul_data;
  199. mful->type = type;
  200. memcpy(&mful->version, version_bytes_ntag_i2c, sizeof(version_bytes_ntag_i2c));
  201. mful->data_size = num_pages * 4;
  202. mful->data_read = mful->data_size;
  203. memcpy(mful->data, data->nfc_data.uid, data->nfc_data.uid_len);
  204. mful->data[7] = data->nfc_data.sak;
  205. mful->data[8] = data->nfc_data.atqa[0];
  206. mful->data[9] = data->nfc_data.atqa[1];
  207. uint16_t config_register_page;
  208. uint16_t session_register_page;
  209. // Sync with mifare_ultralight.c
  210. switch(type) {
  211. case MfUltralightTypeNTAGI2C1K:
  212. config_register_page = 227;
  213. session_register_page = 229;
  214. break;
  215. case MfUltralightTypeNTAGI2C2K:
  216. config_register_page = 481;
  217. session_register_page = 483;
  218. break;
  219. case MfUltralightTypeNTAGI2CPlus1K:
  220. case MfUltralightTypeNTAGI2CPlus2K:
  221. config_register_page = 232;
  222. session_register_page = 234;
  223. break;
  224. default:
  225. furi_crash("Unknown MFUL");
  226. break;
  227. }
  228. memcpy(
  229. &mful->data[config_register_page * 4],
  230. default_config_ntag_i2c,
  231. sizeof(default_config_ntag_i2c));
  232. memcpy(
  233. &mful->data[session_register_page * 4],
  234. default_config_ntag_i2c,
  235. sizeof(default_config_ntag_i2c));
  236. }
  237. static void nfc_generate_ntag_i2c_1k(NfcDeviceData* data) {
  238. nfc_generate_ntag_i2c_common(data, MfUltralightTypeNTAGI2C1K, 231);
  239. MfUltralightData* mful = &data->mf_ul_data;
  240. mful->version.prod_ver_minor = 0x01;
  241. mful->version.storage_size = 0x13;
  242. memcpy(&mful->data[12], default_data_ntag_i2c, sizeof(default_data_ntag_i2c));
  243. mful->data[14] = 0x6D; // Size of tag in CC
  244. }
  245. static void nfc_generate_ntag_i2c_2k(NfcDeviceData* data) {
  246. nfc_generate_ntag_i2c_common(data, MfUltralightTypeNTAGI2C2K, 485);
  247. MfUltralightData* mful = &data->mf_ul_data;
  248. mful->version.prod_ver_minor = 0x01;
  249. mful->version.storage_size = 0x15;
  250. memcpy(&mful->data[12], default_data_ntag_i2c, sizeof(default_data_ntag_i2c));
  251. mful->data[14] = 0xEA; // Size of tag in CC
  252. }
  253. static void nfc_generate_ntag_i2c_plus_common(
  254. NfcDeviceData* data,
  255. MfUltralightType type,
  256. uint16_t num_pages) {
  257. nfc_generate_ntag_i2c_common(data, type, num_pages);
  258. MfUltralightData* mful = &data->mf_ul_data;
  259. uint16_t config_index = 227 * 4;
  260. mful->data[config_index + 3] = 0xFF; // AUTH0
  261. memset(&mful->data[config_index + 8], 0xFF, 4); // Default PWD
  262. }
  263. static void nfc_generate_ntag_i2c_plus_1k(NfcDeviceData* data) {
  264. nfc_generate_ntag_i2c_plus_common(data, MfUltralightTypeNTAGI2CPlus1K, 236);
  265. MfUltralightData* mful = &data->mf_ul_data;
  266. mful->version.prod_ver_minor = 0x02;
  267. mful->version.storage_size = 0x13;
  268. }
  269. static void nfc_generate_ntag_i2c_plus_2k(NfcDeviceData* data) {
  270. nfc_generate_ntag_i2c_plus_common(data, MfUltralightTypeNTAGI2CPlus2K, 492);
  271. MfUltralightData* mful = &data->mf_ul_data;
  272. mful->version.prod_ver_minor = 0x02;
  273. mful->version.storage_size = 0x15;
  274. }
  275. void nfc_generate_mf_classic(NfcDeviceData* data, uint8_t uid_len, MfClassicType type) {
  276. nfc_generate_common_start(data);
  277. nfc_generate_mf_classic_common(data, uid_len, type);
  278. // Set the UID
  279. data->nfc_data.uid[0] = NXP_MANUFACTURER_ID;
  280. for(int i = 1; i < uid_len; i++) {
  281. data->nfc_data.uid[i] = data->mf_classic_data.block[0].value[i];
  282. }
  283. MfClassicData* mfc = &data->mf_classic_data;
  284. mf_classic_set_block_read(mfc, 0, &mfc->block[0]);
  285. if(type == MfClassicType4k) {
  286. // Set every block to 0xFF
  287. for(uint16_t i = 1; i < 256; i += 1) {
  288. if(mf_classic_is_sector_trailer(i)) {
  289. nfc_generate_mf_classic_sector_trailer(mfc, i);
  290. } else {
  291. memset(&mfc->block[i].value, 0xFF, 16);
  292. }
  293. mf_classic_set_block_read(mfc, i, &mfc->block[i]);
  294. }
  295. // Set SAK to 18
  296. data->nfc_data.sak = 0x18;
  297. } else if(type == MfClassicType1k) {
  298. // Set every block to 0xFF
  299. for(uint16_t i = 1; i < MF_CLASSIC_1K_TOTAL_SECTORS_NUM * 4; i += 1) {
  300. if(mf_classic_is_sector_trailer(i)) {
  301. nfc_generate_mf_classic_sector_trailer(mfc, i);
  302. } else {
  303. memset(&mfc->block[i].value, 0xFF, 16);
  304. }
  305. mf_classic_set_block_read(mfc, i, &mfc->block[i]);
  306. }
  307. // Set SAK to 08
  308. data->nfc_data.sak = 0x08;
  309. }
  310. mfc->type = type;
  311. }
  312. static void nfc_generate_mf_classic_1k_4b_uid(NfcDeviceData* data) {
  313. nfc_generate_mf_classic(data, 4, MfClassicType1k);
  314. }
  315. static void nfc_generate_mf_classic_1k_7b_uid(NfcDeviceData* data) {
  316. nfc_generate_mf_classic(data, 7, MfClassicType1k);
  317. }
  318. static void nfc_generate_mf_classic_4k_4b_uid(NfcDeviceData* data) {
  319. nfc_generate_mf_classic(data, 4, MfClassicType4k);
  320. }
  321. static void nfc_generate_mf_classic_4k_7b_uid(NfcDeviceData* data) {
  322. nfc_generate_mf_classic(data, 7, MfClassicType4k);
  323. }
  324. static const NfcGenerator mf_ul_generator = {
  325. .name = "Mifare Ultralight",
  326. .generator_func = nfc_generate_mf_ul_orig,
  327. };
  328. static const NfcGenerator mf_ul_11_generator = {
  329. .name = "Mifare Ultralight EV1 11",
  330. .generator_func = nfc_generate_mf_ul_11,
  331. };
  332. static const NfcGenerator mf_ul_h11_generator = {
  333. .name = "Mifare Ultralight EV1 H11",
  334. .generator_func = nfc_generate_mf_ul_h11,
  335. };
  336. static const NfcGenerator mf_ul_21_generator = {
  337. .name = "Mifare Ultralight EV1 21",
  338. .generator_func = nfc_generate_mf_ul_21,
  339. };
  340. static const NfcGenerator mf_ul_h21_generator = {
  341. .name = "Mifare Ultralight EV1 H21",
  342. .generator_func = nfc_generate_mf_ul_h21,
  343. };
  344. static const NfcGenerator ntag203_generator = {
  345. .name = "NTAG203",
  346. .generator_func = nfc_generate_mf_ul_ntag203,
  347. };
  348. static const NfcGenerator ntag213_generator = {
  349. .name = "NTAG213",
  350. .generator_func = nfc_generate_ntag213,
  351. };
  352. static const NfcGenerator ntag215_generator = {
  353. .name = "NTAG215",
  354. .generator_func = nfc_generate_ntag215,
  355. };
  356. static const NfcGenerator ntag216_generator = {
  357. .name = "NTAG216",
  358. .generator_func = nfc_generate_ntag216,
  359. };
  360. static const NfcGenerator ntag_i2c_1k_generator = {
  361. .name = "NTAG I2C 1k",
  362. .generator_func = nfc_generate_ntag_i2c_1k,
  363. };
  364. static const NfcGenerator ntag_i2c_2k_generator = {
  365. .name = "NTAG I2C 2k",
  366. .generator_func = nfc_generate_ntag_i2c_2k,
  367. };
  368. static const NfcGenerator ntag_i2c_plus_1k_generator = {
  369. .name = "NTAG I2C Plus 1k",
  370. .generator_func = nfc_generate_ntag_i2c_plus_1k,
  371. };
  372. static const NfcGenerator ntag_i2c_plus_2k_generator = {
  373. .name = "NTAG I2C Plus 2k",
  374. .generator_func = nfc_generate_ntag_i2c_plus_2k,
  375. };
  376. static const NfcGenerator mifare_classic_1k_4b_uid_generator = {
  377. .name = "Mifare Classic 1k 4byte UID",
  378. .generator_func = nfc_generate_mf_classic_1k_4b_uid,
  379. };
  380. static const NfcGenerator mifare_classic_1k_7b_uid_generator = {
  381. .name = "Mifare Classic 1k 7byte UID",
  382. .generator_func = nfc_generate_mf_classic_1k_7b_uid,
  383. };
  384. static const NfcGenerator mifare_classic_4k_4b_uid_generator = {
  385. .name = "Mifare Classic 4k 4byte UID",
  386. .generator_func = nfc_generate_mf_classic_4k_4b_uid,
  387. };
  388. static const NfcGenerator mifare_classic_4k_7b_uid_generator = {
  389. .name = "Mifare Classic 4k 7byte UID",
  390. .generator_func = nfc_generate_mf_classic_4k_7b_uid,
  391. };
  392. const NfcGenerator* const nfc_generators[] = {
  393. &mf_ul_generator,
  394. &mf_ul_11_generator,
  395. &mf_ul_h11_generator,
  396. &mf_ul_21_generator,
  397. &mf_ul_h21_generator,
  398. &ntag203_generator,
  399. &ntag213_generator,
  400. &ntag215_generator,
  401. &ntag216_generator,
  402. &ntag_i2c_1k_generator,
  403. &ntag_i2c_2k_generator,
  404. &ntag_i2c_plus_1k_generator,
  405. &ntag_i2c_plus_2k_generator,
  406. &mifare_classic_1k_4b_uid_generator,
  407. &mifare_classic_1k_7b_uid_generator,
  408. &mifare_classic_4k_4b_uid_generator,
  409. &mifare_classic_4k_7b_uid_generator,
  410. NULL,
  411. };