mux.c 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. #include "at32f403a_407.h"
  2. #include "mux.h"
  3. #include "FreeRTOS.h"
  4. #include "task.h"
  5. #include <stdbool.h>
  6. mux_channel_t leds[LED_NUMBER] = {
  7. {INP_1, {0, 0, 0}, LED_OFF, 0},
  8. {INP_2, {0, 0, 0}, LED_OFF, 0},
  9. {INP_3, {0, 0, 0}, LED_OFF, 0},
  10. {INP_4, {0, 0, 0}, LED_OFF, 0},
  11. {INP_5, {0, 1, 1}, LED_OFF, 0},
  12. {INP_6, {0, 1, 1}, LED_OFF, 0},
  13. {INP_7, {0, 1, 1}, LED_OFF, 0},
  14. {INP_8, {0, 1, 1}, LED_OFF, 0},
  15. {OUT_1_G, {1, 0, 0}, LED_OFF, 0},
  16. {OUT_2_G, {1, 0, 0}, LED_OFF, 0},
  17. {OUT_3_G, {1, 0, 0}, LED_OFF, 0},
  18. {OUT_4_G, {1, 0, 0}, LED_OFF, 0},
  19. {OUT_1_R, {0, 1, 0}, LED_OFF, 0},
  20. {OUT_2_R, {0, 1, 0}, LED_OFF, 0},
  21. {OUT_3_R, {0, 1, 0}, LED_OFF, 0},
  22. {OUT_4_R, {0, 1, 0}, LED_OFF, 0},
  23. {STATUS_G, {1, 1, 0}, LED_OFF, 0},
  24. {STATUS_R, {1, 1, 0}, LED_OFF, 0},
  25. {RX_G, {1, 1, 0}, LED_OFF, 0},
  26. {TX_R, {1, 1, 0}, LED_OFF, 0},
  27. {OUT_5_R, {0, 0, 1}, LED_OFF, 0},
  28. {OUT_6_R, {0, 0, 1}, LED_OFF, 0},
  29. {OUT_7_R, {0, 0, 1}, LED_OFF, 0},
  30. {OUT_8_R, {0, 0, 1}, LED_OFF, 0},
  31. {OUT_5_G, {1, 0, 1}, LED_OFF, 0},
  32. {OUT_6_G, {1, 0, 1}, LED_OFF, 0},
  33. {OUT_7_G, {1, 0, 1}, LED_OFF, 0},
  34. {OUT_8_G, {1, 0, 1}, LED_OFF, 0}
  35. };
  36. //
  37. void mux_led_init(mux_channel_t *ch)
  38. {
  39. }
  40. //
  41. void mux_gpio_init(void)
  42. {
  43. gpio_init_type gpio_initstructure;
  44. crm_periph_clock_enable(CRM_GPIOB_PERIPH_CLOCK, TRUE);
  45. crm_periph_clock_enable(CRM_GPIOB_PERIPH_CLOCK, TRUE);
  46. crm_periph_clock_enable(CRM_GPIOE_PERIPH_CLOCK, TRUE);
  47. // LED_COL
  48. // COL_1 - PD6
  49. // COL_2 - PD7
  50. // COL_3 - PB6
  51. // COL_4 - PB7
  52. gpio_initstructure.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  53. gpio_initstructure.gpio_pull = GPIO_PULL_NONE;
  54. gpio_initstructure.gpio_mode = GPIO_MODE_OUTPUT;
  55. gpio_initstructure.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  56. gpio_initstructure.gpio_pins = GPIO_PINS_6 | GPIO_PINS_7;
  57. gpio_init(GPIOB, &gpio_initstructure);
  58. gpio_initstructure.gpio_pins = GPIO_PINS_6 | GPIO_PINS_7;
  59. gpio_init(GPIOD, &gpio_initstructure);
  60. gpio_bits_reset(GPIOB, GPIO_PINS_6 | GPIO_PINS_7);
  61. gpio_bits_reset(GPIOD, GPIO_PINS_6 | GPIO_PINS_7);
  62. // LED_LINE (низкий уровень на пине = высокий уровень на входе MUX)
  63. // LINE_0 - PE3
  64. // LINE_1 - PE2
  65. // LINE_2 - PB9
  66. gpio_initstructure.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  67. gpio_initstructure.gpio_pull = GPIO_PULL_NONE;
  68. gpio_initstructure.gpio_mode = GPIO_MODE_OUTPUT;
  69. gpio_initstructure.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  70. gpio_initstructure.gpio_pins = GPIO_PINS_2 | GPIO_PINS_3;
  71. gpio_init(GPIOE, &gpio_initstructure);
  72. gpio_initstructure.gpio_pins = GPIO_PINS_9;
  73. gpio_init(GPIOB, &gpio_initstructure);
  74. gpio_bits_reset(GPIOE, GPIO_PINS_2 | GPIO_PINS_3);
  75. gpio_bits_reset(GPIOB, GPIO_PINS_9);
  76. }
  77. //
  78. void mux_led_proc(void)
  79. {
  80. uint8_t shift = 0;
  81. for (uint8_t i = 0; i < LED_NUMBER/4; i++)
  82. {
  83. leds[shift].line[0] ? (LINE_0_RESET) : (LINE_0_SET);
  84. leds[shift].line[1] ? (LINE_1_RESET) : (LINE_1_SET);
  85. leds[shift].line[2] ? (LINE_2_RESET) : (LINE_2_SET);
  86. leds[i*4].state == LED_ON ? (COL_1_SET) : (COL_1_RESET);
  87. leds[i*4 + 1].state == LED_ON ? (COL_2_SET) : (COL_2_RESET);
  88. leds[i*4 + 2].state == LED_ON ? (COL_3_SET) : (COL_3_RESET);
  89. leds[i*4 + 3].state == LED_ON ? (COL_4_SET) : (COL_4_RESET);
  90. if (leds[i*4].state == LED_ON || leds[i*4 + 1].state == LED_ON ||
  91. leds[i*4 + 2].state == LED_ON || leds[i*4 + 3].state == LED_ON)
  92. {
  93. vTaskDelay(1);
  94. }
  95. shift += 4;
  96. }
  97. }
  98. //
  99. void mux_led_test_init(void)
  100. {
  101. LINE_0_SET;
  102. LINE_1_SET;
  103. LINE_2_SET;
  104. }
  105. //
  106. void mux_led_test_toggle(void)
  107. {
  108. static bool flag = false;
  109. if (!flag) {
  110. COL_1_SET;
  111. flag = true;
  112. }
  113. else {
  114. COL_1_RESET;
  115. flag = false;
  116. }
  117. }
  118. //
  119. void mux_led_blink(void)
  120. {
  121. for (int i = 0; i < LED_NUMBER; i++)
  122. {
  123. leds[i].state = LED_ON;
  124. vTaskDelay(100);
  125. leds[i].state = LED_OFF;
  126. }
  127. }
  128. // true - normal
  129. // false - alarm
  130. void mux_led_status(bool state)
  131. {
  132. if (state) {
  133. leds[STATUS_G].state = LED_ON;
  134. leds[STATUS_R].state = LED_OFF;
  135. }
  136. else {
  137. leds[STATUS_G].state = LED_OFF;
  138. leds[STATUS_R].state = LED_ON;
  139. }
  140. }