uhf_data.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. #include "uhf_data.h"
  2. UHFData* uhf_data_alloc() {
  3. UHFData* uhf_data = (UHFData*)malloc(sizeof(UHFData));
  4. uhf_data->word_length = 0;
  5. uhf_data->length = 0;
  6. uhf_data->start = false;
  7. uhf_data->end = false;
  8. uhf_data->next = NULL;
  9. return uhf_data;
  10. }
  11. int uhf_data_append(UHFData* uhf_data, uint8_t data) {
  12. if(data == 0xBB) {
  13. uhf_data->start = true;
  14. }
  15. if(!uhf_data->start) return 0;
  16. if(uhf_data->end) return 0;
  17. if(uhf_data->length >= MAX_DATA_SIZE) return 0;
  18. if(data == 0x7E) {
  19. uhf_data->end = true;
  20. }
  21. uhf_data->data[uhf_data->length++] = data;
  22. return 1;
  23. }
  24. void uhf_data_reset(UHFData* uhf_data) {
  25. for(size_t i = 0; i < uhf_data->length; i++) {
  26. uhf_data->data[i] = 0x00;
  27. }
  28. uhf_data->start = false;
  29. uhf_data->end = false;
  30. uhf_data->length = 0;
  31. uhf_data->next = NULL;
  32. }
  33. uint8_t uhf_data_calculate_checksum(UHFData* uhf_data) {
  34. // CheckSum8 Modulo 256
  35. // Sum of Bytes % 256
  36. uint8_t sum_val = 0x00;
  37. size_t length = uhf_data->length - 2;
  38. for(size_t i = 1; i < length; i++) {
  39. sum_val += uhf_data->data[i];
  40. }
  41. return sum_val % 256;
  42. }
  43. bool uhf_data_verfiy_checksum(UHFData* uhf_data) {
  44. uint8_t data_checksum = uhf_data->data[uhf_data->length - 2];
  45. uint8_t actual_checksum = uhf_data_calculate_checksum(uhf_data);
  46. return data_checksum == actual_checksum;
  47. }
  48. void uhf_data_free(UHFData* uhf_data) {
  49. if(uhf_data == NULL) return;
  50. while(uhf_data != NULL) {
  51. UHFData* next = uhf_data->next;
  52. free(uhf_data);
  53. uhf_data = next;
  54. }
  55. }
  56. UHFResponseData* uhf_response_data_alloc() {
  57. UHFResponseData* uhf_response_data = (UHFResponseData*)malloc(sizeof(UHFResponseData));
  58. uhf_response_data->head = uhf_data_alloc();
  59. uhf_response_data->tail = uhf_response_data->head;
  60. uhf_response_data->size = 1;
  61. return uhf_response_data;
  62. }
  63. UHFData* uhf_response_data_add_new_uhf_data(UHFResponseData* uhf_response_data) {
  64. UHFData* temp = uhf_response_data->head;
  65. while(temp->next != NULL) {
  66. temp = temp->next;
  67. }
  68. temp->next = uhf_data_alloc();
  69. uhf_response_data->size++;
  70. uhf_response_data->tail = temp->next;
  71. return temp->next;
  72. }
  73. UHFData* uhf_response_data_get_uhf_data(UHFResponseData* uhf_response_data, uint index) {
  74. if(uhf_response_data == NULL || uhf_response_data->size <= index) return NULL;
  75. UHFData* uhf_data = uhf_response_data->head;
  76. if(index == 0) return uhf_data;
  77. while(uhf_data != NULL && index >= 1) {
  78. uhf_data = uhf_data->next;
  79. index--;
  80. }
  81. return uhf_data;
  82. }
  83. void uhf_response_data_reset(UHFResponseData* uhf_response_data) {
  84. uhf_data_reset(uhf_response_data->head);
  85. if(uhf_response_data->size == 1) {
  86. return;
  87. }
  88. uhf_data_free(uhf_response_data->head->next);
  89. uhf_response_data->size = 1;
  90. }
  91. void uhf_response_data_free(UHFResponseData* uhf_response_data) {
  92. uhf_data_free(uhf_response_data->head);
  93. free(uhf_response_data);
  94. }
  95. UHFTag* uhf_tag_alloc() {
  96. UHFTag* uhf_tag = (UHFTag*)malloc(sizeof(UHFTag));
  97. return uhf_tag;
  98. }
  99. void uhf_tag_set_epc(UHFTag* uhf_tag, uint8_t* data, size_t length) {
  100. memcpy(uhf_tag->crc, data, 2);
  101. data += 2;
  102. memcpy(uhf_tag->pc, data, 2);
  103. memcpy(uhf_tag->epc, data, length);
  104. uhf_tag->epc_length = length;
  105. }
  106. void uhf_tag_reset(UHFTag* uhf_tag) {
  107. for(int i = 0; i < 2; i++) {
  108. uhf_tag->crc[i] = 0;
  109. uhf_tag->pc[i] = 0;
  110. uhf_tag->xpc[i] = 0;
  111. }
  112. for(int i = 0; i < MAX_BANK_SIZE; i++) {
  113. uhf_tag->epc[i] = 0;
  114. uhf_tag->tid[i] = 0;
  115. uhf_tag->user[i] = 0;
  116. }
  117. uhf_tag->epc_length = 0;
  118. uhf_tag->tid_length = 0;
  119. uhf_tag->user_length = 0;
  120. }
  121. void uhf_tag_set_tid(UHFTag* uhf_tag, uint8_t* data, size_t length) {
  122. memcpy(uhf_tag->tid, data, length);
  123. uhf_tag->tid_length = length;
  124. }
  125. void uhf_tag_set_user(UHFTag* uhf_tag, uint8_t* data, size_t length) {
  126. memcpy(uhf_tag->user, data, length);
  127. uhf_tag->user_length = length;
  128. }
  129. void uhf_tag_free(UHFTag* uhf_tag) {
  130. free(uhf_tag);
  131. }