subghz_tx_rx_worker.h 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #pragma once
  2. #include <furi_hal.h>
  3. #ifdef __cplusplus
  4. extern "C" {
  5. #endif
  6. typedef void (*SubGhzTxRxWorkerCallbackHaveRead)(void* context);
  7. typedef struct SubGhzTxRxWorker SubGhzTxRxWorker;
  8. typedef enum {
  9. SubGhzTxRxWorkerStatusIDLE,
  10. SubGhzTxRxWorkerStatusTx,
  11. SubGhzTxRxWorkerStatusRx,
  12. } SubGhzTxRxWorkerStatus;
  13. /**
  14. * SubGhzTxRxWorker, add data to transfer
  15. * @param instance Pointer to a SubGhzTxRxWorker instance
  16. * @param data *data
  17. * @param size data size
  18. * @return bool true if ok
  19. */
  20. bool subghz_tx_rx_worker_write(SubGhzTxRxWorker* instance, uint8_t* data, size_t size);
  21. /**
  22. * SubGhzTxRxWorker, get available data
  23. * @param instance Pointer to a SubGhzTxRxWorker instance
  24. * @return size_t data size
  25. */
  26. size_t subghz_tx_rx_worker_available(SubGhzTxRxWorker* instance);
  27. /**
  28. * SubGhzTxRxWorker, read data
  29. * @param instance Pointer to a SubGhzTxRxWorker instance
  30. * @param data *data
  31. * @param size max data size, which can be read
  32. * @return size_t data size, how much is actually read
  33. */
  34. size_t subghz_tx_rx_worker_read(SubGhzTxRxWorker* instance, uint8_t* data, size_t size);
  35. /**
  36. * Сallback SubGhzTxRxWorker when there is data to read in an empty buffer
  37. * @param instance Pointer to a SubGhzTxRxWorker instance
  38. * @param callback SubGhzTxRxWorkerCallbackHaveRead callback
  39. * @param context
  40. */
  41. void subghz_tx_rx_worker_set_callback_have_read(
  42. SubGhzTxRxWorker* instance,
  43. SubGhzTxRxWorkerCallbackHaveRead callback,
  44. void* context);
  45. /**
  46. * Allocate SubGhzTxRxWorker
  47. * @return SubGhzTxRxWorker* Pointer to a SubGhzTxRxWorker instance
  48. */
  49. SubGhzTxRxWorker* subghz_tx_rx_worker_alloc();
  50. /**
  51. * Free SubGhzTxRxWorker
  52. * @param instance Pointer to a SubGhzTxRxWorker instance
  53. */
  54. void subghz_tx_rx_worker_free(SubGhzTxRxWorker* instance);
  55. /**
  56. * Start SubGhzTxRxWorker
  57. * @param instance Pointer to a SubGhzTxRxWorker instance
  58. * @return bool - true if ok
  59. */
  60. bool subghz_tx_rx_worker_start(SubGhzTxRxWorker* instance, uint32_t frequency);
  61. /**
  62. * Stop SubGhzTxRxWorker
  63. * @param instance Pointer to a SubGhzTxRxWorker instance
  64. */
  65. void subghz_tx_rx_worker_stop(SubGhzTxRxWorker* instance);
  66. /**
  67. * Check if worker is running
  68. * @param instance Pointer to a SubGhzTxRxWorker instance
  69. * @return bool - true if running
  70. */
  71. bool subghz_tx_rx_worker_is_running(SubGhzTxRxWorker* instance);
  72. #ifdef __cplusplus
  73. }
  74. #endif