common_gpio.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #include "at32f403a_407.h"
  2. #include "common_gpio.h"
  3. #include "FreeRTOS.h"
  4. #include "task.h"
  5. #include "io.h"
  6. #include <stdbool.h>
  7. #define ADDR_PIN_NUM 4
  8. #define HW_REV_PIN_NUM 3
  9. uint8_t board_rev;
  10. //
  11. din_t addr_in[ADDR_PIN_NUM] = {
  12. {GPIOC, GPIO_PINS_4, 0, 0, false, 0}, // 1
  13. {GPIOA, GPIO_PINS_7, 0, 0, false, 0}, // 2
  14. {GPIOA, GPIO_PINS_6, 0, 0, false, 0}, // 3
  15. {GPIOA, GPIO_PINS_5, 0, 0, false, 0}, // 4
  16. };
  17. //
  18. din_t rev_in[ADDR_PIN_NUM] = {
  19. {GPIOE, GPIO_PINS_7, 0, 0, false, 0}, // 1
  20. {GPIOE, GPIO_PINS_8, 0, 0, false, 0}, // 2
  21. {GPIOE, GPIO_PINS_9, 0, 0, false, 0}, // 3
  22. };
  23. //
  24. void gpio_wdt_init(void)
  25. {
  26. gpio_init_type gpio_initstructure;
  27. crm_periph_clock_enable(CRM_GPIOC_PERIPH_CLOCK, TRUE);
  28. // WDT
  29. gpio_initstructure.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  30. gpio_initstructure.gpio_pull = GPIO_PULL_NONE;
  31. gpio_initstructure.gpio_mode = GPIO_MODE_OUTPUT;
  32. gpio_initstructure.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  33. gpio_initstructure.gpio_pins = GPIO_PINS_7;
  34. gpio_init(GPIOC, &gpio_initstructure);
  35. }
  36. // Пины переключателя modbus-адреса
  37. void gpio_mbaddr_init(void)
  38. {
  39. gpio_init_type gpio_init_struct;
  40. gpio_default_para_init(&gpio_init_struct);
  41. for (uint8_t i = 0; i < ADDR_PIN_NUM; i++)
  42. {
  43. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  44. gpio_init_struct.gpio_mode = GPIO_MODE_INPUT;
  45. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  46. gpio_init_struct.gpio_pins = addr_in[i].pin ;
  47. gpio_init(addr_in[i].port, &gpio_init_struct);
  48. }
  49. }
  50. //
  51. uint8_t gpio_get_mbaddr(void)
  52. {
  53. uint8_t ret = 0;
  54. for (uint8_t i = 0; i < ADDR_PIN_NUM; i++)
  55. {
  56. ret |= ((uint8_t)!gpio_input_data_bit_read(addr_in[i].port, addr_in[i].pin) << i);
  57. }
  58. ret = ret > 1 ? ret : 1;
  59. return ret;
  60. }
  61. //
  62. bool gpio_check_mbaddr(uint8_t old_addr, uint8_t *new_addr)
  63. {
  64. uint8_t tmp = gpio_get_mbaddr();
  65. if (old_addr != tmp)
  66. {
  67. *new_addr = tmp;
  68. return true;
  69. }
  70. return false;
  71. }
  72. // Считать ревизию платы
  73. // Уточнить пины PE7, PE8, PE9
  74. void gpio_update_rev(void)
  75. {
  76. board_rev = 0;
  77. gpio_init_type gpio_init_struct;
  78. gpio_default_para_init(&gpio_init_struct);
  79. for (uint8_t i = 0; i < HW_REV_PIN_NUM; i++)
  80. {
  81. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  82. gpio_init_struct.gpio_mode = GPIO_MODE_INPUT;
  83. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  84. gpio_init_struct.gpio_pins = rev_in[i].pin ;
  85. gpio_init(rev_in[i].port, &gpio_init_struct);
  86. }
  87. for (uint8_t i = 0; i < HW_REV_PIN_NUM; i++)
  88. {
  89. board_rev |= (uint8_t)gpio_input_data_bit_read(rev_in[i].port, rev_in[i].pin) << i;
  90. }
  91. }
  92. //
  93. uint8_t gpio_get_board_rev(void)
  94. {
  95. return board_rev;
  96. }
  97. //
  98. void extern_wdt_togle(void)
  99. {
  100. static bool toogle = false;
  101. if (!toogle) {
  102. toogle = true;
  103. gpio_bits_set(GPIOC, GPIO_PINS_7);
  104. }
  105. else {
  106. toogle = false;
  107. gpio_bits_reset(GPIOC, GPIO_PINS_7);
  108. }
  109. }