uhf_worker.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #include "uhf_worker.h"
  2. #include "uhf_cmd.h"
  3. // uart callback functions
  4. void module_rx_callback(UartIrqEvent event, uint8_t data, void* ctx) {
  5. UNUSED(event);
  6. UHFData* uhf_data = ctx;
  7. uhf_data_append(uhf_data, data);
  8. // FURI_LOG_E("module_rx_callback", "%02x", data);
  9. }
  10. // yrm100 module commands
  11. UHFWorkerEvent verify_module_connected(UHFWorker* uhf_worker) {
  12. UHFResponseData* uhf_response_data = uhf_worker->data;
  13. UHFData* hardware_version = uhf_response_data->data;
  14. uhf_data_reset(hardware_version);
  15. UHFData* software_version = uhf_response_data_add_new_uhf_data(uhf_response_data);
  16. UHFData* manufacturer = uhf_response_data_add_new_uhf_data(uhf_response_data);
  17. furi_hal_uart_set_br(FuriHalUartIdUSART1, DEFAULT_BAUD_RATE);
  18. // read hardware version
  19. furi_hal_uart_set_irq_cb(FuriHalUartIdUSART1, module_rx_callback, hardware_version);
  20. furi_hal_uart_tx(FuriHalUartIdUSART1, CMD_HARDWARE_VERSION.cmd, CMD_HARDWARE_VERSION.length);
  21. furi_delay_ms(150);
  22. // read software version
  23. furi_hal_uart_set_irq_cb(FuriHalUartIdUSART1, module_rx_callback, software_version);
  24. furi_hal_uart_tx(FuriHalUartIdUSART1, CMD_SOFTWARE_VERSION.cmd, CMD_SOFTWARE_VERSION.length);
  25. furi_delay_ms(150);
  26. // read manufacturer
  27. furi_hal_uart_set_irq_cb(FuriHalUartIdUSART1, module_rx_callback, manufacturer);
  28. furi_hal_uart_tx(FuriHalUartIdUSART1, CMD_MANUFACTURERS.cmd, CMD_MANUFACTURERS.length);
  29. furi_delay_ms(150);
  30. if(!hardware_version->end) { //|| !software_version->end || !manufacturer->end) {
  31. return UHFWorkerEventFail;
  32. }
  33. return UHFWorkerEventSuccess;
  34. }
  35. UHFWorkerEvent read_single_card(UHFWorker* uhf_worker) {
  36. UHFResponseData* uhf_response_data = uhf_worker->data;
  37. UHFData* uhf_data = uhf_response_data->data;
  38. furi_hal_uart_set_br(FuriHalUartIdUSART1, DEFAULT_BAUD_RATE);
  39. furi_hal_uart_set_irq_cb(FuriHalUartIdUSART1, module_rx_callback, uhf_data);
  40. uhf_data_reset(uhf_data);
  41. while(true) {
  42. furi_hal_uart_tx(FuriHalUartIdUSART1, CMD_SINGLE_POLLING.cmd, CMD_SINGLE_POLLING.length);
  43. furi_delay_ms(100);
  44. if(uhf_worker->state == UHFWorkerStateStop) {
  45. return UHFWorkerEventAborted;
  46. }
  47. if(uhf_data->end) {
  48. // before breaking, check if the response is not an error
  49. // index 1 = response type, index 5 = parameter
  50. if(uhf_data->data[1] == 0x01 && uhf_data->data[5] == 0x15) {
  51. continue;
  52. } else if(uhf_data->data[1] == 0x02)
  53. break; // success read
  54. }
  55. }
  56. return UHFWorkerEventSuccess;
  57. }
  58. int32_t uhf_worker_task(void* ctx) {
  59. UHFWorker* uhf_worker = ctx;
  60. if(uhf_worker->state == UHFWorkerStateVerify) {
  61. UHFWorkerEvent event = verify_module_connected(uhf_worker);
  62. uhf_worker->callback(event, uhf_worker->ctx);
  63. }
  64. if(uhf_worker->state == UHFWorkerStateDetectSingle) {
  65. UHFWorkerEvent event = read_single_card(uhf_worker);
  66. uhf_worker->callback(event, uhf_worker->ctx);
  67. }
  68. return 0;
  69. }
  70. UHFWorker* uhf_worker_alloc() {
  71. UHFWorker* uhf_worker = (UHFWorker*)malloc(sizeof(UHFWorker));
  72. uhf_worker->thread = furi_thread_alloc_ex("UHFWorker", 8 * 1024, uhf_worker_task, uhf_worker);
  73. uhf_worker->data = uhf_response_data_alloc();
  74. uhf_worker->callback = NULL;
  75. uhf_worker->ctx = NULL;
  76. return uhf_worker;
  77. }
  78. void uhf_worker_change_state(UHFWorker* worker, UHFWorkerState state) {
  79. worker->state = state;
  80. }
  81. void uhf_worker_start(
  82. UHFWorker* uhf_worker,
  83. UHFWorkerState state,
  84. UHFWorkerCallback callback,
  85. void* ctx) {
  86. uhf_worker->state = state;
  87. uhf_worker->callback = callback;
  88. uhf_worker->ctx = ctx;
  89. furi_thread_start(uhf_worker->thread);
  90. }
  91. void uhf_worker_stop(UHFWorker* uhf_worker) {
  92. furi_assert(uhf_worker);
  93. furi_assert(uhf_worker->thread);
  94. if(furi_thread_get_state(uhf_worker->thread) != FuriThreadStateStopped) {
  95. uhf_worker_change_state(uhf_worker, UHFWorkerStateStop);
  96. furi_thread_join(uhf_worker->thread);
  97. }
  98. }
  99. void uhf_worker_free(UHFWorker* uhf_worker) {
  100. furi_assert(uhf_worker);
  101. furi_thread_free(uhf_worker->thread);
  102. uhf_response_data_free(uhf_worker->data);
  103. free(uhf_worker);
  104. }