mifare_ultralight.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #include "mifare_ultralight.h"
  2. bool mf_ul_check_card_type(uint8_t ATQA0, uint8_t ATQA1, uint8_t SAK) {
  3. if((ATQA0 == 0x44) && (ATQA1 == 0x00) && (SAK == 0x00)) {
  4. return true;
  5. }
  6. return false;
  7. }
  8. uint16_t mf_ul_prepare_get_version(uint8_t* dest) {
  9. dest[0] = MF_UL_GET_VERSION_CMD;
  10. return 1;
  11. }
  12. void mf_ul_parse_get_version_response(uint8_t* buff, MifareUlDevice* mf_ul_read) {
  13. MfUltralightVersion* version = (MfUltralightVersion*) buff;
  14. memcpy(&mf_ul_read->data.version, version, sizeof(MfUltralightVersion));
  15. if(version->storage_size == 0x0B || version->storage_size == 0x00) {
  16. mf_ul_read->type = MfUltralightTypeUL11;
  17. mf_ul_read->pages_to_read = 20;
  18. mf_ul_read->support_fast_read = true;
  19. } else if(version->storage_size == 0x0E) {
  20. mf_ul_read->type = MfUltralightTypeUL21;
  21. mf_ul_read->pages_to_read = 41;
  22. mf_ul_read->support_fast_read = true;
  23. } else if(version->storage_size == 0x0F) {
  24. mf_ul_read->type = MfUltralightTypeNTAG213;
  25. mf_ul_read->pages_to_read = 45;
  26. mf_ul_read->support_fast_read = false;
  27. } else if(version->storage_size == 0x11) {
  28. mf_ul_read->type = MfUltralightTypeNTAG215;
  29. mf_ul_read->pages_to_read = 135;
  30. mf_ul_read->support_fast_read = false;
  31. } else if(version->storage_size == 0x13) {
  32. mf_ul_read->type = MfUltralightTypeNTAG216;
  33. mf_ul_read->pages_to_read = 231;
  34. mf_ul_read->support_fast_read = false;
  35. } else {
  36. mf_ul_set_default_version(mf_ul_read);
  37. }
  38. }
  39. void mf_ul_set_default_version(MifareUlDevice* mf_ul_read) {
  40. mf_ul_read->type = MfUltralightTypeUnknown;
  41. mf_ul_read->pages_to_read = 16;
  42. mf_ul_read->support_fast_read = false;
  43. }
  44. uint16_t mf_ul_prepare_read(uint8_t* dest, uint8_t start_page) {
  45. dest[0] = MF_UL_READ_CMD;
  46. dest[1] = start_page;
  47. return 2;
  48. }
  49. void mf_ul_parse_read_response(uint8_t* buff, uint16_t page_addr, MifareUlDevice* mf_ul_read) {
  50. mf_ul_read->pages_readed += 4;
  51. mf_ul_read->data.data_size = mf_ul_read->pages_readed * 4;
  52. memcpy(&mf_ul_read->data.data[page_addr * 4], buff, 16);
  53. }
  54. uint16_t mf_ul_prepare_fast_read(uint8_t* dest, uint8_t start_page, uint8_t end_page) {
  55. dest[0] = MF_UL_FAST_READ_CMD;
  56. dest[1] = start_page;
  57. dest[2] = end_page;
  58. return 3;
  59. }
  60. void mf_ul_parse_fast_read_response(uint8_t* buff, uint8_t start_page, uint8_t end_page, MifareUlDevice* mf_ul_read) {
  61. mf_ul_read->pages_readed = end_page - start_page + 1;
  62. mf_ul_read->data.data_size = mf_ul_read->pages_readed * 4;
  63. memcpy(mf_ul_read->data.data, buff, mf_ul_read->data.data_size);
  64. }
  65. uint16_t mf_ul_prepare_read_signature(uint8_t* dest) {
  66. dest[0] = MF_UL_CHECK_TEARING;
  67. dest[1] = 0;
  68. return 2;
  69. }
  70. void mf_ul_parse_read_signature_response(uint8_t* buff, MifareUlDevice* mf_ul_read) {
  71. memcpy(mf_ul_read->data.signature, buff, sizeof(mf_ul_read->data.signature));
  72. }
  73. uint16_t mf_ul_prepare_read_cnt(uint8_t* dest, uint8_t cnt_index) {
  74. if(cnt_index > 2) {
  75. return 0;
  76. }
  77. dest[0] = MF_UL_READ_CNT;
  78. dest[1] = cnt_index;
  79. return 2;
  80. }
  81. void mf_ul_parse_read_cnt_response(uint8_t* buff, uint8_t cnt_index, MifareUlDevice* mf_ul_read) {
  82. // Reverse LSB sequence
  83. if(cnt_index < 3) {
  84. mf_ul_read->data.counter[cnt_index] = (buff[2] << 16) | (buff[1] << 8) | (buff[0]);
  85. }
  86. }
  87. uint16_t mf_ul_prepare_inc_cnt(uint8_t* dest, uint8_t cnt_index, uint32_t value) {
  88. if(cnt_index > 2) {
  89. return 0;
  90. }
  91. dest[0] = MF_UL_INC_CNT;
  92. dest[1] = cnt_index;
  93. dest[2] = (uint8_t) value;
  94. dest[3] = (uint8_t) (value >> 8);
  95. dest[4] = (uint8_t) (value >> 16);
  96. dest[5] = 0;
  97. return 6;
  98. }
  99. uint16_t mf_ul_prepare_check_tearing(uint8_t* dest, uint8_t cnt_index) {
  100. if(cnt_index > 2) {
  101. return 0;
  102. }
  103. dest[0] = MF_UL_CHECK_TEARING;
  104. dest[1] = cnt_index;
  105. return 2;
  106. }
  107. void mf_ul_parse_check_tearing_response(uint8_t* buff, uint8_t cnt_index, MifareUlDevice* mf_ul_read) {
  108. if(cnt_index < 2) {
  109. mf_ul_read->data.tearing[cnt_index] = buff[0];
  110. }
  111. }
  112. uint16_t mf_ul_prepare_write(uint8_t* dest, uint16_t page_addr, uint32_t data) {
  113. if(page_addr < 2) {
  114. return 0;
  115. }
  116. dest[0] = MF_UL_WRITE;
  117. dest[1] = page_addr;
  118. dest[2] = (uint8_t) (data >> 24);
  119. dest[3] = (uint8_t) (data >> 16);
  120. dest[4] = (uint8_t) (data >> 8);
  121. dest[5] = (uint8_t) data;
  122. return 6;
  123. }