gpio-tester.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. #include <furi.h>
  2. #include <api-hal.h>
  3. #include <gui/gui.h>
  4. #include <input/input.h>
  5. typedef struct {
  6. const char* name;
  7. GpioPin pin;
  8. } GpioItem;
  9. const GpioItem GPIO_PINS[] = {
  10. {"1.2: PA7", {GPIOA, GPIO_PIN_7}},
  11. {"1.3: PA6", {GPIOA, GPIO_PIN_6}},
  12. {"1.4: PA4", {GPIOA, GPIO_PIN_4}},
  13. {"1.5: PB3", {GPIOB, GPIO_PIN_3}},
  14. {"1.6: PB2", {GPIOB, GPIO_PIN_2}},
  15. {"1.7: PC3", {GPIOC, GPIO_PIN_3}},
  16. {"2.7: PC1", {GPIOC, GPIO_PIN_1}},
  17. {"2.8: PC0", {GPIOC, GPIO_PIN_0}},
  18. };
  19. typedef enum {
  20. EventTypeTick,
  21. EventTypeKey,
  22. } EventType;
  23. typedef struct {
  24. union {
  25. InputEvent input;
  26. } value;
  27. EventType type;
  28. } AppEvent;
  29. typedef struct {
  30. uint8_t gpio_index;
  31. } State;
  32. static void render_callback(Canvas* canvas, void* ctx) {
  33. State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25);
  34. canvas_clear(canvas);
  35. canvas_set_color(canvas, ColorBlack);
  36. canvas_set_font(canvas, FontPrimary);
  37. canvas_draw_str(canvas, 2, 10, "GPIO demo");
  38. canvas_set_font(canvas, FontSecondary);
  39. canvas_draw_str(canvas, 2, 25, GPIO_PINS[state->gpio_index].name);
  40. release_mutex((ValueMutex*)ctx, state);
  41. }
  42. static void input_callback(InputEvent* input_event, void* ctx) {
  43. osMessageQueueId_t event_queue = ctx;
  44. AppEvent event;
  45. event.type = EventTypeKey;
  46. event.value.input = *input_event;
  47. osMessageQueuePut(event_queue, &event, 0, 0);
  48. }
  49. int32_t app_gpio_test(void* p) {
  50. osMessageQueueId_t event_queue = osMessageQueueNew(8, sizeof(AppEvent), NULL);
  51. furi_check(event_queue);
  52. State _state;
  53. _state.gpio_index = 0;
  54. ValueMutex state_mutex;
  55. if(!init_mutex(&state_mutex, &_state, sizeof(State))) {
  56. printf("[gpio-tester] cannot create mutex\r\n");
  57. return 255;
  58. }
  59. ViewPort* view_port = view_port_alloc();
  60. view_port_draw_callback_set(view_port, render_callback, &state_mutex);
  61. view_port_input_callback_set(view_port, input_callback, event_queue);
  62. // Open GUI and register view_port
  63. Gui* gui = furi_record_open("gui");
  64. gui_add_view_port(gui, view_port, GuiLayerFullscreen);
  65. // configure pin
  66. for(uint8_t i = 0; i < sizeof(GPIO_PINS) / sizeof(GPIO_PINS[0]); i++) {
  67. gpio_init((GpioPin*)&GPIO_PINS[i].pin, GpioModeOutputPushPull);
  68. }
  69. AppEvent event;
  70. while(1) {
  71. osStatus_t event_status = osMessageQueueGet(event_queue, &event, NULL, osWaitForever);
  72. State* state = (State*)acquire_mutex_block(&state_mutex);
  73. if(event_status == osOK) {
  74. if(event.type == EventTypeKey) {
  75. if(event.value.input.type == InputTypeShort &&
  76. event.value.input.key == InputKeyBack) {
  77. printf("[gpio-tester] bye!\r\n");
  78. api_hal_light_set(LightGreen, 0x00);
  79. view_port_enabled_set(view_port, false);
  80. gui_remove_view_port(gui, view_port);
  81. view_port_free(view_port);
  82. return 0;
  83. }
  84. if(event.value.input.type == InputTypeShort &&
  85. event.value.input.key == InputKeyRight) {
  86. if(state->gpio_index < (sizeof(GPIO_PINS) / sizeof(GPIO_PINS[0]) - 1)) {
  87. state->gpio_index++;
  88. }
  89. }
  90. if(event.value.input.type == InputTypeShort &&
  91. event.value.input.key == InputKeyLeft) {
  92. if(state->gpio_index > 0) {
  93. state->gpio_index--;
  94. }
  95. }
  96. if(event.value.input.key == InputKeyOk) {
  97. if(event.value.input.type == InputTypePress) {
  98. gpio_write((GpioPin*)&GPIO_PINS[state->gpio_index].pin, true);
  99. api_hal_light_set(LightGreen, 0xFF);
  100. } else if(event.value.input.type == InputTypeRelease) {
  101. gpio_write((GpioPin*)&GPIO_PINS[state->gpio_index].pin, false);
  102. api_hal_light_set(LightGreen, 0x00);
  103. }
  104. }
  105. }
  106. }
  107. release_mutex(&state_mutex, state);
  108. view_port_update(view_port);
  109. }
  110. return 0;
  111. }