nfc_generators.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  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_ul_common(NfcDeviceData* data) {
  24. data->nfc_data.type = FuriHalNfcTypeA;
  25. data->nfc_data.interface = FuriHalNfcInterfaceRf;
  26. data->nfc_data.uid_len = 7;
  27. nfc_generate_mf_ul_uid(data->nfc_data.uid);
  28. data->nfc_data.atqa[0] = 0x44;
  29. data->nfc_data.atqa[1] = 0x00;
  30. data->nfc_data.sak = 0x00;
  31. data->protocol = NfcDeviceProtocolMifareUl;
  32. }
  33. static void nfc_generate_calc_bcc(uint8_t* uid, uint8_t* bcc0, uint8_t* bcc1) {
  34. *bcc0 = 0x88 ^ uid[0] ^ uid[1] ^ uid[2];
  35. *bcc1 = uid[3] ^ uid[4] ^ uid[5] ^ uid[6];
  36. }
  37. static void nfc_generate_mf_ul_copy_uid_with_bcc(NfcDeviceData* data) {
  38. MfUltralightData* mful = &data->mf_ul_data;
  39. memcpy(mful->data, data->nfc_data.uid, 3);
  40. memcpy(&mful->data[4], &data->nfc_data.uid[3], 4);
  41. nfc_generate_calc_bcc(data->nfc_data.uid, &mful->data[3], &mful->data[8]);
  42. }
  43. static void nfc_generate_mf_ul_orig(NfcDeviceData* data) {
  44. nfc_generate_common_start(data);
  45. nfc_generate_mf_ul_common(data);
  46. MfUltralightData* mful = &data->mf_ul_data;
  47. mful->type = MfUltralightTypeUnknown;
  48. mful->data_size = 16 * 4;
  49. mful->data_read = mful->data_size;
  50. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  51. // TODO: what's internal byte on page 2?
  52. memset(&mful->data[4 * 4], 0xFF, 4);
  53. }
  54. static void nfc_generate_mf_ul_ntag203(NfcDeviceData* data) {
  55. nfc_generate_common_start(data);
  56. nfc_generate_mf_ul_common(data);
  57. MfUltralightData* mful = &data->mf_ul_data;
  58. mful->type = MfUltralightTypeNTAG203;
  59. mful->data_size = 42 * 4;
  60. mful->data_read = mful->data_size;
  61. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  62. mful->data[9] = 0x48; // Internal byte
  63. memcpy(&mful->data[3 * 4], default_data_ntag203, sizeof(default_data_ntag203));
  64. }
  65. static void nfc_generate_mf_ul_with_config_common(NfcDeviceData* data, uint8_t num_pages) {
  66. nfc_generate_common_start(data);
  67. nfc_generate_mf_ul_common(data);
  68. MfUltralightData* mful = &data->mf_ul_data;
  69. mful->data_size = num_pages * 4;
  70. mful->data_read = mful->data_size;
  71. nfc_generate_mf_ul_copy_uid_with_bcc(data);
  72. uint16_t config_index = (num_pages - 4) * 4;
  73. mful->data[config_index] = 0x04; // STRG_MOD_EN
  74. mful->data[config_index + 3] = 0xFF; // AUTH0
  75. mful->data[config_index + 5] = 0x05; // VCTID
  76. memset(&mful->data[config_index + 8], 0xFF, 4); // Default PWD
  77. if(num_pages > 20) mful->data[config_index - 1] = MF_UL_TEARING_FLAG_DEFAULT;
  78. }
  79. static void nfc_generate_mf_ul_ev1_common(NfcDeviceData* data, uint8_t num_pages) {
  80. nfc_generate_mf_ul_with_config_common(data, num_pages);
  81. MfUltralightData* mful = &data->mf_ul_data;
  82. memcpy(&mful->version, version_bytes_mf0ulx1, sizeof(version_bytes_mf0ulx1));
  83. for(size_t i = 0; i < 3; ++i) {
  84. mful->tearing[i] = MF_UL_TEARING_FLAG_DEFAULT;
  85. }
  86. // TODO: what's internal byte on page 2?
  87. }
  88. static void nfc_generate_mf_ul_11(NfcDeviceData* data) {
  89. nfc_generate_mf_ul_ev1_common(data, 20);
  90. MfUltralightData* mful = &data->mf_ul_data;
  91. mful->type = MfUltralightTypeUL11;
  92. mful->version.prod_subtype = 0x01;
  93. mful->version.storage_size = 0x0B;
  94. mful->data[16 * 4] = 0x00; // Low capacitance version does not have STRG_MOD_EN
  95. }
  96. static void nfc_generate_mf_ul_h11(NfcDeviceData* data) {
  97. nfc_generate_mf_ul_ev1_common(data, 20);
  98. MfUltralightData* mful = &data->mf_ul_data;
  99. mful->type = MfUltralightTypeUL11;
  100. mful->version.prod_subtype = 0x02;
  101. mful->version.storage_size = 0x0B;
  102. }
  103. static void nfc_generate_mf_ul_21(NfcDeviceData* data) {
  104. nfc_generate_mf_ul_ev1_common(data, 41);
  105. MfUltralightData* mful = &data->mf_ul_data;
  106. mful->type = MfUltralightTypeUL21;
  107. mful->version.prod_subtype = 0x01;
  108. mful->version.storage_size = 0x0E;
  109. mful->data[37 * 4] = 0x00; // Low capacitance version does not have STRG_MOD_EN
  110. }
  111. static void nfc_generate_mf_ul_h21(NfcDeviceData* data) {
  112. nfc_generate_mf_ul_ev1_common(data, 41);
  113. MfUltralightData* mful = &data->mf_ul_data;
  114. mful->type = MfUltralightTypeUL21;
  115. mful->version.prod_subtype = 0x02;
  116. mful->version.storage_size = 0x0E;
  117. }
  118. static void nfc_generate_ntag21x_common(NfcDeviceData* data, uint8_t num_pages) {
  119. nfc_generate_mf_ul_with_config_common(data, num_pages);
  120. MfUltralightData* mful = &data->mf_ul_data;
  121. memcpy(&mful->version, version_bytes_ntag21x, sizeof(version_bytes_mf0ulx1));
  122. mful->data[9] = 0x48; // Internal byte
  123. // Capability container
  124. mful->data[12] = 0xE1;
  125. mful->data[13] = 0x10;
  126. }
  127. static void nfc_generate_ntag213(NfcDeviceData* data) {
  128. nfc_generate_ntag21x_common(data, 45);
  129. MfUltralightData* mful = &data->mf_ul_data;
  130. mful->type = MfUltralightTypeNTAG213;
  131. mful->version.storage_size = 0x0F;
  132. mful->data[14] = 0x12;
  133. // Default contents
  134. memcpy(&mful->data[16], default_data_ntag213, sizeof(default_data_ntag213));
  135. }
  136. static void nfc_generate_ntag215(NfcDeviceData* data) {
  137. nfc_generate_ntag21x_common(data, 135);
  138. MfUltralightData* mful = &data->mf_ul_data;
  139. mful->type = MfUltralightTypeNTAG215;
  140. mful->version.storage_size = 0x11;
  141. mful->data[14] = 0x3E;
  142. // Default contents
  143. memcpy(&mful->data[16], default_data_ntag215_216, sizeof(default_data_ntag215_216));
  144. }
  145. static void nfc_generate_ntag216(NfcDeviceData* data) {
  146. nfc_generate_ntag21x_common(data, 231);
  147. MfUltralightData* mful = &data->mf_ul_data;
  148. mful->type = MfUltralightTypeNTAG216;
  149. mful->version.storage_size = 0x13;
  150. mful->data[14] = 0x6D;
  151. // Default contents
  152. memcpy(&mful->data[16], default_data_ntag215_216, sizeof(default_data_ntag215_216));
  153. }
  154. static void
  155. nfc_generate_ntag_i2c_common(NfcDeviceData* data, MfUltralightType type, uint16_t num_pages) {
  156. nfc_generate_common_start(data);
  157. nfc_generate_mf_ul_common(data);
  158. MfUltralightData* mful = &data->mf_ul_data;
  159. mful->type = type;
  160. memcpy(&mful->version, version_bytes_ntag_i2c, sizeof(version_bytes_ntag_i2c));
  161. mful->data_size = num_pages * 4;
  162. mful->data_read = mful->data_size;
  163. memcpy(mful->data, data->nfc_data.uid, data->nfc_data.uid_len);
  164. mful->data[7] = data->nfc_data.sak;
  165. mful->data[8] = data->nfc_data.atqa[0];
  166. mful->data[9] = data->nfc_data.atqa[1];
  167. uint16_t config_register_page;
  168. uint16_t session_register_page;
  169. // Sync with mifare_ultralight.c
  170. switch(type) {
  171. case MfUltralightTypeNTAGI2C1K:
  172. config_register_page = 227;
  173. session_register_page = 229;
  174. break;
  175. case MfUltralightTypeNTAGI2C2K:
  176. config_register_page = 481;
  177. session_register_page = 483;
  178. break;
  179. case MfUltralightTypeNTAGI2CPlus1K:
  180. case MfUltralightTypeNTAGI2CPlus2K:
  181. config_register_page = 232;
  182. session_register_page = 234;
  183. break;
  184. default:
  185. furi_assert(false);
  186. break;
  187. }
  188. memcpy(
  189. &mful->data[config_register_page * 4],
  190. default_config_ntag_i2c,
  191. sizeof(default_config_ntag_i2c));
  192. memcpy(
  193. &mful->data[session_register_page * 4],
  194. default_config_ntag_i2c,
  195. sizeof(default_config_ntag_i2c));
  196. }
  197. static void nfc_generate_ntag_i2c_1k(NfcDeviceData* data) {
  198. nfc_generate_ntag_i2c_common(data, MfUltralightTypeNTAGI2C1K, 231);
  199. MfUltralightData* mful = &data->mf_ul_data;
  200. mful->version.prod_ver_minor = 0x01;
  201. mful->version.storage_size = 0x13;
  202. memcpy(&mful->data[12], default_data_ntag_i2c, sizeof(default_data_ntag_i2c));
  203. mful->data[14] = 0x6D; // Size of tag in CC
  204. }
  205. static void nfc_generate_ntag_i2c_2k(NfcDeviceData* data) {
  206. nfc_generate_ntag_i2c_common(data, MfUltralightTypeNTAGI2C2K, 485);
  207. MfUltralightData* mful = &data->mf_ul_data;
  208. mful->version.prod_ver_minor = 0x01;
  209. mful->version.storage_size = 0x15;
  210. memcpy(&mful->data[12], default_data_ntag_i2c, sizeof(default_data_ntag_i2c));
  211. mful->data[14] = 0xEA; // Size of tag in CC
  212. }
  213. static void nfc_generate_ntag_i2c_plus_common(
  214. NfcDeviceData* data,
  215. MfUltralightType type,
  216. uint16_t num_pages) {
  217. nfc_generate_ntag_i2c_common(data, type, num_pages);
  218. MfUltralightData* mful = &data->mf_ul_data;
  219. uint16_t config_index = 227 * 4;
  220. mful->data[config_index + 3] = 0xFF; // AUTH0
  221. memset(&mful->data[config_index + 8], 0xFF, 4); // Default PWD
  222. }
  223. static void nfc_generate_ntag_i2c_plus_1k(NfcDeviceData* data) {
  224. nfc_generate_ntag_i2c_plus_common(data, MfUltralightTypeNTAGI2CPlus1K, 236);
  225. MfUltralightData* mful = &data->mf_ul_data;
  226. mful->version.prod_ver_minor = 0x02;
  227. mful->version.storage_size = 0x13;
  228. }
  229. static void nfc_generate_ntag_i2c_plus_2k(NfcDeviceData* data) {
  230. nfc_generate_ntag_i2c_plus_common(data, MfUltralightTypeNTAGI2CPlus2K, 492);
  231. MfUltralightData* mful = &data->mf_ul_data;
  232. mful->version.prod_ver_minor = 0x02;
  233. mful->version.storage_size = 0x15;
  234. }
  235. static const NfcGenerator mf_ul_generator = {
  236. .name = "Mifare Ultralight",
  237. .generator_func = nfc_generate_mf_ul_orig,
  238. .next_scene = NfcSceneMfUltralightMenu};
  239. static const NfcGenerator mf_ul_11_generator = {
  240. .name = "Mifare Ultralight EV1 11",
  241. .generator_func = nfc_generate_mf_ul_11,
  242. .next_scene = NfcSceneMfUltralightMenu};
  243. static const NfcGenerator mf_ul_h11_generator = {
  244. .name = "Mifare Ultralight EV1 H11",
  245. .generator_func = nfc_generate_mf_ul_h11,
  246. .next_scene = NfcSceneMfUltralightMenu};
  247. static const NfcGenerator mf_ul_21_generator = {
  248. .name = "Mifare Ultralight EV1 21",
  249. .generator_func = nfc_generate_mf_ul_21,
  250. .next_scene = NfcSceneMfUltralightMenu};
  251. static const NfcGenerator mf_ul_h21_generator = {
  252. .name = "Mifare Ultralight EV1 H21",
  253. .generator_func = nfc_generate_mf_ul_h21,
  254. .next_scene = NfcSceneMfUltralightMenu};
  255. static const NfcGenerator ntag203_generator = {
  256. .name = "NTAG203",
  257. .generator_func = nfc_generate_mf_ul_ntag203,
  258. .next_scene = NfcSceneMfUltralightMenu};
  259. static const NfcGenerator ntag213_generator = {
  260. .name = "NTAG213",
  261. .generator_func = nfc_generate_ntag213,
  262. .next_scene = NfcSceneMfUltralightMenu};
  263. static const NfcGenerator ntag215_generator = {
  264. .name = "NTAG215",
  265. .generator_func = nfc_generate_ntag215,
  266. .next_scene = NfcSceneMfUltralightMenu};
  267. static const NfcGenerator ntag216_generator = {
  268. .name = "NTAG216",
  269. .generator_func = nfc_generate_ntag216,
  270. .next_scene = NfcSceneMfUltralightMenu};
  271. static const NfcGenerator ntag_i2c_1k_generator = {
  272. .name = "NTAG I2C 1k",
  273. .generator_func = nfc_generate_ntag_i2c_1k,
  274. .next_scene = NfcSceneMfUltralightMenu};
  275. static const NfcGenerator ntag_i2c_2k_generator = {
  276. .name = "NTAG I2C 2k",
  277. .generator_func = nfc_generate_ntag_i2c_2k,
  278. .next_scene = NfcSceneMfUltralightMenu};
  279. static const NfcGenerator ntag_i2c_plus_1k_generator = {
  280. .name = "NTAG I2C Plus 1k",
  281. .generator_func = nfc_generate_ntag_i2c_plus_1k,
  282. .next_scene = NfcSceneMfUltralightMenu};
  283. static const NfcGenerator ntag_i2c_plus_2k_generator = {
  284. .name = "NTAG I2C Plus 2k",
  285. .generator_func = nfc_generate_ntag_i2c_plus_2k,
  286. .next_scene = NfcSceneMfUltralightMenu};
  287. const NfcGenerator* const nfc_generators[] = {
  288. &mf_ul_generator,
  289. &mf_ul_11_generator,
  290. &mf_ul_h11_generator,
  291. &mf_ul_21_generator,
  292. &mf_ul_h21_generator,
  293. &ntag203_generator,
  294. &ntag213_generator,
  295. &ntag215_generator,
  296. &ntag216_generator,
  297. &ntag_i2c_1k_generator,
  298. &ntag_i2c_2k_generator,
  299. &ntag_i2c_plus_1k_generator,
  300. &ntag_i2c_plus_2k_generator,
  301. NULL,
  302. };