gpio_usb_uart.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. #include "../usb_uart_bridge.h"
  2. #include "../gpio_app_i.h"
  3. #include "furi_hal.h"
  4. #include <gui/elements.h>
  5. struct GpioUsbUart {
  6. View* view;
  7. GpioUsbUartCallback callback;
  8. void* context;
  9. };
  10. typedef struct {
  11. uint32_t baudrate;
  12. uint32_t tx_cnt;
  13. uint32_t rx_cnt;
  14. uint8_t vcp_port;
  15. uint8_t tx_pin;
  16. uint8_t rx_pin;
  17. bool tx_active;
  18. bool rx_active;
  19. } GpioUsbUartModel;
  20. static void gpio_usb_uart_draw_callback(Canvas* canvas, void* _model) {
  21. GpioUsbUartModel* model = _model;
  22. char temp_str[18];
  23. elements_button_left(canvas, "Config");
  24. canvas_draw_line(canvas, 2, 10, 125, 10);
  25. canvas_draw_line(canvas, 44, 52, 123, 52);
  26. canvas_set_font(canvas, FontPrimary);
  27. canvas_draw_str(canvas, 2, 9, "USB Serial");
  28. canvas_draw_str(canvas, 3, 25, "TX:");
  29. canvas_draw_str(canvas, 3, 42, "RX:");
  30. canvas_set_font(canvas, FontSecondary);
  31. snprintf(temp_str, 18, "COM PORT:%u", model->vcp_port);
  32. canvas_draw_str_aligned(canvas, 126, 8, AlignRight, AlignBottom, temp_str);
  33. snprintf(temp_str, 18, "Pin %u", model->tx_pin);
  34. canvas_draw_str(canvas, 22, 25, temp_str);
  35. snprintf(temp_str, 18, "Pin %u", model->rx_pin);
  36. canvas_draw_str(canvas, 22, 42, temp_str);
  37. if(model->baudrate == 0)
  38. snprintf(temp_str, 18, "Baud: ????");
  39. else
  40. snprintf(temp_str, 18, "Baud: %lu", model->baudrate);
  41. canvas_draw_str(canvas, 45, 62, temp_str);
  42. if(model->tx_cnt < 100000000) {
  43. canvas_set_font(canvas, FontSecondary);
  44. canvas_draw_str_aligned(canvas, 127, 24, AlignRight, AlignBottom, "B.");
  45. canvas_set_font(canvas, FontKeyboard);
  46. snprintf(temp_str, 18, "%lu", model->tx_cnt);
  47. canvas_draw_str_aligned(canvas, 116, 24, AlignRight, AlignBottom, temp_str);
  48. } else {
  49. canvas_set_font(canvas, FontSecondary);
  50. canvas_draw_str_aligned(canvas, 127, 24, AlignRight, AlignBottom, "KiB.");
  51. canvas_set_font(canvas, FontKeyboard);
  52. snprintf(temp_str, 18, "%lu", model->tx_cnt / 1024);
  53. canvas_draw_str_aligned(canvas, 111, 24, AlignRight, AlignBottom, temp_str);
  54. }
  55. if(model->rx_cnt < 100000000) {
  56. canvas_set_font(canvas, FontSecondary);
  57. canvas_draw_str_aligned(canvas, 127, 41, AlignRight, AlignBottom, "B.");
  58. canvas_set_font(canvas, FontKeyboard);
  59. snprintf(temp_str, 18, "%lu", model->rx_cnt);
  60. canvas_draw_str_aligned(canvas, 116, 41, AlignRight, AlignBottom, temp_str);
  61. } else {
  62. canvas_set_font(canvas, FontSecondary);
  63. canvas_draw_str_aligned(canvas, 127, 41, AlignRight, AlignBottom, "KiB.");
  64. canvas_set_font(canvas, FontKeyboard);
  65. snprintf(temp_str, 18, "%lu", model->rx_cnt / 1024);
  66. canvas_draw_str_aligned(canvas, 111, 41, AlignRight, AlignBottom, temp_str);
  67. }
  68. if(model->tx_active)
  69. canvas_draw_icon(canvas, 48, 14, &I_ArrowUpFilled_14x15);
  70. else
  71. canvas_draw_icon(canvas, 48, 14, &I_ArrowUpEmpty_14x15);
  72. if(model->rx_active)
  73. canvas_draw_icon_ex(canvas, 48, 34, &I_ArrowUpFilled_14x15, IconRotation180);
  74. else
  75. canvas_draw_icon_ex(canvas, 48, 34, &I_ArrowUpEmpty_14x15, IconRotation180);
  76. }
  77. static bool gpio_usb_uart_input_callback(InputEvent* event, void* context) {
  78. furi_assert(context);
  79. GpioUsbUart* usb_uart = context;
  80. bool consumed = false;
  81. if(event->type == InputTypeShort) {
  82. if(event->key == InputKeyLeft) {
  83. consumed = true;
  84. furi_assert(usb_uart->callback);
  85. usb_uart->callback(GpioUsbUartEventConfig, usb_uart->context);
  86. }
  87. }
  88. return consumed;
  89. }
  90. GpioUsbUart* gpio_usb_uart_alloc() {
  91. GpioUsbUart* usb_uart = malloc(sizeof(GpioUsbUart));
  92. usb_uart->view = view_alloc();
  93. view_allocate_model(usb_uart->view, ViewModelTypeLocking, sizeof(GpioUsbUartModel));
  94. view_set_context(usb_uart->view, usb_uart);
  95. view_set_draw_callback(usb_uart->view, gpio_usb_uart_draw_callback);
  96. view_set_input_callback(usb_uart->view, gpio_usb_uart_input_callback);
  97. return usb_uart;
  98. }
  99. void gpio_usb_uart_free(GpioUsbUart* usb_uart) {
  100. furi_assert(usb_uart);
  101. view_free(usb_uart->view);
  102. free(usb_uart);
  103. }
  104. View* gpio_usb_uart_get_view(GpioUsbUart* usb_uart) {
  105. furi_assert(usb_uart);
  106. return usb_uart->view;
  107. }
  108. void gpio_usb_uart_set_callback(GpioUsbUart* usb_uart, GpioUsbUartCallback callback, void* context) {
  109. furi_assert(usb_uart);
  110. furi_assert(callback);
  111. with_view_model(
  112. usb_uart->view,
  113. GpioUsbUartModel * model,
  114. {
  115. UNUSED(model);
  116. usb_uart->callback = callback;
  117. usb_uart->context = context;
  118. },
  119. false);
  120. }
  121. void gpio_usb_uart_update_state(GpioUsbUart* instance, UsbUartConfig* cfg, UsbUartState* st) {
  122. furi_assert(instance);
  123. furi_assert(cfg);
  124. furi_assert(st);
  125. with_view_model(
  126. instance->view,
  127. GpioUsbUartModel * model,
  128. {
  129. model->baudrate = st->baudrate_cur;
  130. model->vcp_port = cfg->vcp_ch;
  131. model->tx_pin = (cfg->uart_ch == 0) ? (13) : (15);
  132. model->rx_pin = (cfg->uart_ch == 0) ? (14) : (16);
  133. model->tx_active = (model->tx_cnt != st->tx_cnt);
  134. model->rx_active = (model->rx_cnt != st->rx_cnt);
  135. model->tx_cnt = st->tx_cnt;
  136. model->rx_cnt = st->rx_cnt;
  137. },
  138. true);
  139. }