lfrfid_raw_file.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #include "lfrfid_raw_file.h"
  2. #include "tools/varint_pair.h"
  3. #include <toolbox/stream/file_stream.h>
  4. #include <toolbox/varint.h>
  5. #define LFRFID_RAW_FILE_MAGIC 0x4C464952
  6. #define LFRFID_RAW_FILE_VERSION 1
  7. #define TAG "RFID RAW File"
  8. typedef struct {
  9. uint32_t magic;
  10. uint32_t version;
  11. float frequency;
  12. float duty_cycle;
  13. uint32_t max_buffer_size;
  14. } LFRFIDRawFileHeader;
  15. struct LFRFIDRawFile {
  16. Stream* stream;
  17. uint32_t max_buffer_size;
  18. uint8_t* buffer;
  19. uint32_t buffer_size;
  20. size_t buffer_counter;
  21. };
  22. LFRFIDRawFile* lfrfid_raw_file_alloc(Storage* storage) {
  23. LFRFIDRawFile* file = malloc(sizeof(LFRFIDRawFile));
  24. file->stream = file_stream_alloc(storage);
  25. file->buffer = NULL;
  26. return file;
  27. }
  28. void lfrfid_raw_file_free(LFRFIDRawFile* file) {
  29. if(file->buffer) free(file->buffer);
  30. stream_free(file->stream);
  31. free(file);
  32. }
  33. bool lfrfid_raw_file_open_write(LFRFIDRawFile* file, const char* file_path) {
  34. return file_stream_open(file->stream, file_path, FSAM_READ_WRITE, FSOM_CREATE_ALWAYS);
  35. }
  36. bool lfrfid_raw_file_open_read(LFRFIDRawFile* file, const char* file_path) {
  37. return file_stream_open(file->stream, file_path, FSAM_READ, FSOM_OPEN_EXISTING);
  38. }
  39. bool lfrfid_raw_file_write_header(
  40. LFRFIDRawFile* file,
  41. float frequency,
  42. float duty_cycle,
  43. uint32_t max_buffer_size) {
  44. LFRFIDRawFileHeader header = {
  45. .magic = LFRFID_RAW_FILE_MAGIC,
  46. .version = LFRFID_RAW_FILE_VERSION,
  47. .frequency = frequency,
  48. .duty_cycle = duty_cycle,
  49. .max_buffer_size = max_buffer_size};
  50. size_t size = stream_write(file->stream, (uint8_t*)&header, sizeof(LFRFIDRawFileHeader));
  51. return (size == sizeof(LFRFIDRawFileHeader));
  52. }
  53. bool lfrfid_raw_file_write_buffer(LFRFIDRawFile* file, uint8_t* buffer_data, size_t buffer_size) {
  54. size_t size;
  55. size = stream_write(file->stream, (uint8_t*)&buffer_size, sizeof(size_t));
  56. if(size != sizeof(size_t)) return false;
  57. size = stream_write(file->stream, buffer_data, buffer_size);
  58. if(size != buffer_size) return false;
  59. return true;
  60. }
  61. bool lfrfid_raw_file_read_header(LFRFIDRawFile* file, float* frequency, float* duty_cycle) {
  62. LFRFIDRawFileHeader header;
  63. size_t size = stream_read(file->stream, (uint8_t*)&header, sizeof(LFRFIDRawFileHeader));
  64. if(size == sizeof(LFRFIDRawFileHeader)) {
  65. if(header.magic == LFRFID_RAW_FILE_MAGIC && header.version == LFRFID_RAW_FILE_VERSION) {
  66. *frequency = header.frequency;
  67. *duty_cycle = header.duty_cycle;
  68. file->max_buffer_size = header.max_buffer_size;
  69. file->buffer = malloc(file->max_buffer_size);
  70. file->buffer_size = 0;
  71. file->buffer_counter = 0;
  72. return true;
  73. } else {
  74. return false;
  75. }
  76. } else {
  77. return false;
  78. }
  79. }
  80. bool lfrfid_raw_file_read_pair(
  81. LFRFIDRawFile* file,
  82. uint32_t* duration,
  83. uint32_t* pulse,
  84. bool* pass_end) {
  85. size_t length = 0;
  86. if(file->buffer_counter >= file->buffer_size) {
  87. if(stream_eof(file->stream)) {
  88. // rewind stream and pass header
  89. stream_seek(file->stream, sizeof(LFRFIDRawFileHeader), StreamOffsetFromStart);
  90. if(pass_end) *pass_end = true;
  91. }
  92. length = stream_read(file->stream, (uint8_t*)&file->buffer_size, sizeof(size_t));
  93. if(length != sizeof(size_t)) {
  94. FURI_LOG_E(TAG, "read pair: failed to read size");
  95. return false;
  96. }
  97. if(file->buffer_size > file->max_buffer_size) {
  98. FURI_LOG_E(TAG, "read pair: buffer size is too big");
  99. return false;
  100. }
  101. length = stream_read(file->stream, file->buffer, file->buffer_size);
  102. if(length != file->buffer_size) {
  103. FURI_LOG_E(TAG, "read pair: failed to read data");
  104. return false;
  105. }
  106. file->buffer_counter = 0;
  107. }
  108. size_t size = 0;
  109. bool result = varint_pair_unpack(
  110. &file->buffer[file->buffer_counter],
  111. (size_t)(file->buffer_size - file->buffer_counter),
  112. pulse,
  113. duration,
  114. &size);
  115. if(result) {
  116. file->buffer_counter += size;
  117. } else {
  118. FURI_LOG_E(TAG, "read pair: buffer is too small");
  119. return false;
  120. }
  121. return true;
  122. }