gpio.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. #include "bsp/gpio.h"
  2. #include "libs/utils.h"
  3. #ifdef GD32_FOC_DEMO
  4. #define IR2136S_Enable_pin 0
  5. #define LED1_Enable_pin 1
  6. #define LED2_Enable_pin 2
  7. #define LED3_Enable_pin 3
  8. #define KEY_Start_pin 4
  9. #define KEY_Stop_pin 5
  10. #define KEY_Func_pin 6
  11. #endif
  12. /*
  13. * gpio.c
  14. * all pins used as gpio(in/out/irq) must be init&accessed here
  15. */
  16. const static gpio_pin_config_t _pins[] = {
  17. #ifdef GD32_FOC_DEMO
  18. [IR2136S_Enable_pin] = {GPIOA, GPIO_PIN_12, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, 0},
  19. [LED1_Enable_pin] = {GPIOD, GPIO_PIN_2, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, 0},
  20. [LED2_Enable_pin] = {0, GPIO_PIN_9, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, 0},
  21. [LED3_Enable_pin] = {GPIOC, GPIO_PIN_5, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, 0},
  22. [KEY_Start_pin] = {GPIOB, GPIO_PIN_5, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, 0},
  23. [KEY_Stop_pin] = {GPIOB, GPIO_PIN_11, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, 0},
  24. #endif
  25. };
  26. void gpio_pin_init(void){
  27. rcu_periph_clock_enable(RCU_GPIOA);
  28. rcu_periph_clock_enable(RCU_GPIOB);
  29. rcu_periph_clock_enable(RCU_GPIOC);
  30. rcu_periph_clock_enable(RCU_GPIOD);
  31. rcu_periph_clock_enable(RCU_GPIOF);
  32. rcu_periph_clock_enable(RCU_AF);
  33. for (int i = 0; i < ARRAY_SIZE(_pins); i++){
  34. if (_pins[i].init_value != -1){
  35. gpio_bit_write(_pins[i].group, _pins[i].pin, (bit_status)_pins[i].init_value);
  36. }
  37. if (_pins[i].group != 0) {
  38. gpio_init(_pins[i].group, _pins[i].mode, _pins[i].speed, _pins[i].pin);
  39. }
  40. }
  41. #ifdef CONFIG_BEEP
  42. gpio_init(GPIOB, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_2);
  43. gpio_beep(50);
  44. #endif
  45. }
  46. void gpio_beep(u32 ms) {
  47. #ifdef CONFIG_BEEP
  48. gpio_bit_write(GPIOB, GPIO_PIN_2, SET);
  49. delay_ms(ms);
  50. gpio_bit_write(GPIOB, GPIO_PIN_2, RESET);
  51. #endif
  52. }
  53. void gpio_mc_brk_init(void) {
  54. #ifdef GPIO_BRAKE_IN_GROUP
  55. rcu_periph_clock_enable(GPIO_BRAKE_IN_RCU);
  56. gpio_init(GPIO_BRAKE_IN_GROUP, GPIO_BRAKE_IN_MODE, GPIO_OSPEED_50MHZ, GPIO_BRAKE_IN_PIN);
  57. gpio_exti_source_select(GPIO_BRAKE_EXIT_SRC_GROUP, GPIO_BRAKE_EXIT_SRC_PIN);
  58. exti_init(GPIO_BRAKE_EXTI, EXTI_INTERRUPT, EXTI_TRIG_BOTH);
  59. nvic_irq_enable(GPIO_BRAKE_IRQ, EBREAK_IRQ_PRIORITY, 0U);
  60. exti_interrupt_flag_clear(GPIO_BRAKE_EXTI);
  61. exti_interrupt_enable(GPIO_BRAKE_EXTI);
  62. #endif
  63. #ifdef GPIO_BRAKE1_IN_GROUP
  64. rcu_periph_clock_enable(GPIO_BRAKE1_IN_RCU);
  65. gpio_init(GPIO_BRAKE1_IN_GROUP, GPIO_BRAKE1_IN_MODE, GPIO_OSPEED_50MHZ, GPIO_BRAKE1_IN_PIN);
  66. gpio_exti_source_select(GPIO_BRAKE1_EXIT_SRC_GROUP, GPIO_BRAKE1_EXIT_SRC_PIN);
  67. exti_init(GPIO_BRAKE1_EXTI, EXTI_INTERRUPT, EXTI_TRIG_BOTH);
  68. nvic_irq_enable(GPIO_BRAKE1_IRQ, EBREAK_IRQ_PRIORITY, 0U);
  69. exti_interrupt_flag_clear(GPIO_BRAKE1_EXTI);
  70. exti_interrupt_enable(GPIO_BRAKE1_EXTI);
  71. #endif
  72. }
  73. void gpio_mlock_init(void) {
  74. #ifdef GPIO_MLOCK_IN_GROUP
  75. rcu_periph_clock_enable(GPIO_MLOCK_IN_RCU);
  76. gpio_init(GPIO_MLOCK_IN_GROUP, GPIO_MLOCK_IN_MODE, GPIO_OSPEED_50MHZ, GPIO_MLOCK_IN_PIN);
  77. #endif
  78. }
  79. void gpio_fan_det_init(void) {
  80. #ifdef GPIO_FAN1_IN_GROUP
  81. rcu_periph_clock_enable(GPIO_FAN1_IN_RCU);
  82. gpio_init(GPIO_FAN1_IN_GROUP, GPIO_FAN1_IN_MODE, GPIO_OSPEED_50MHZ, GPIO_FAN1_IN_PIN);
  83. gpio_exti_source_select(GPIO_FAN1_EXIT_SRC_GROUP, GPIO_FAN1_EXIT_SRC_PIN);
  84. exti_init(GPIO_FAN1_EXTI, EXTI_INTERRUPT, EXTI_TRIG_RISING);
  85. nvic_irq_enable(GPIO_FAN1_IRQ, ENC_OTHER_IRQ_PRIORITY, 0U);
  86. exti_interrupt_flag_clear(GPIO_FAN1_EXTI);
  87. exti_interrupt_enable(GPIO_FAN1_EXTI);
  88. #endif
  89. #ifdef GPIO_FAN2_IN_GROUP
  90. rcu_periph_clock_enable(GPIO_FAN2_IN_RCU);
  91. gpio_init(GPIO_FAN2_IN_GROUP, GPIO_FAN2_IN_MODE, GPIO_OSPEED_50MHZ, GPIO_FAN2_IN_PIN);
  92. gpio_exti_source_select(GPIO_FAN2_EXIT_SRC_GROUP, GPIO_FAN2_EXIT_SRC_PIN);
  93. exti_init(GPIO_FAN2_EXTI, EXTI_INTERRUPT, EXTI_TRIG_RISING);
  94. nvic_irq_enable(GPIO_FAN2_IRQ, ENC_OTHER_IRQ_PRIORITY, 0U);
  95. exti_interrupt_flag_clear(GPIO_FAN2_EXTI);
  96. exti_interrupt_enable(GPIO_FAN2_EXTI);
  97. #endif
  98. }
  99. void gpio_phase_u_detect(bool enable) {
  100. #ifdef GPIO_UDEC_OUT_GROUP
  101. if (enable) {
  102. gpio_init(GPIO_UDEC_OUT_GROUP, GPIO_UDEC_OUT_MODE, GPIO_OSPEED_50MHZ, GPIO_UDEC_OUT_PIN);
  103. #ifdef GPIO_UDEC_OUT_REMAP_DISABLE
  104. gpio_pin_remap_config(GPIO_UDEC_OUT_REMAP_DISABLE, ENABLE);
  105. #endif
  106. gpio_bit_write(GPIO_UDEC_OUT_GROUP, GPIO_UDEC_OUT_PIN, SET);
  107. }else {
  108. gpio_init(GPIO_UDEC_OUT_GROUP, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, GPIO_UDEC_OUT_PIN);
  109. #ifdef GPIO_UDEC_OUT_REMAP_ENABLE
  110. gpio_pin_remap_config(GPIO_UDEC_OUT_REMAP_ENABLE, ENABLE);
  111. #endif
  112. }
  113. #endif
  114. }
  115. void mc_gpio_init(void) {
  116. gpio_mlock_init();
  117. gpio_mc_brk_init();
  118. gpio_fan_det_init();
  119. }
  120. bool mc_get_gpio_brake(void) {
  121. return gpio_input_bit_get(GPIO_BRAKE_IN_GROUP, GPIO_BRAKE_IN_PIN) == SET;
  122. }
  123. bool mc_get_gpio_brake1(void) {
  124. #ifdef GPIO_BRAKE1_IN_GROUP
  125. return gpio_input_bit_get(GPIO_BRAKE1_IN_GROUP, GPIO_BRAKE1_IN_PIN) == SET;
  126. #else
  127. return mc_get_gpio_brake();
  128. #endif
  129. }
  130. bool gpio_motor_locked(void) {
  131. #ifdef GPIO_MLOCK_IN_GROUP
  132. return gpio_input_bit_get(GPIO_MLOCK_IN_GROUP, GPIO_MLOCK_IN_PIN) == RESET;
  133. #else
  134. return false;
  135. #endif
  136. }
  137. void gpio_ir2136_enable(bool enable) {
  138. #ifdef GD32_FOC_DEMO
  139. gpio_bit_write(_pins[IR2136S_Enable_pin].group, _pins[IR2136S_Enable_pin].pin, (enable)?SET:RESET);
  140. #endif
  141. }
  142. void gpio_led1_enable(bool enable) {
  143. #ifdef GD32_FOC_DEMO
  144. gpio_bit_write(_pins[LED1_Enable_pin].group, _pins[LED1_Enable_pin].pin, (enable)?SET:RESET);
  145. #endif
  146. }
  147. void gpio_led2_enable(bool enable) {
  148. #ifdef GD32_FOC_DEMO
  149. //gpio_bit_write(_pins[LED2_Enable_pin].group, _pins[LED2_Enable_pin].pin, (enable)?SET:RESET);
  150. #endif
  151. }
  152. void gpio_led3_enable(bool enable) {
  153. #ifdef GD32_FOC_DEMO
  154. gpio_bit_write(_pins[LED3_Enable_pin].group, _pins[LED3_Enable_pin].pin, (enable)?SET:RESET);
  155. #endif
  156. }
  157. int gpio_startkey_value(void) {
  158. #ifdef GD32_FOC_DEMO
  159. return gpio_input_bit_get(_pins[KEY_Start_pin].group, _pins[KEY_Start_pin].pin)==SET?1:0;
  160. #else
  161. return 1;
  162. #endif
  163. }
  164. int gpio_stopkey_value(void) {
  165. #ifdef GD32_FOC_DEMO
  166. return gpio_input_bit_get(_pins[KEY_Stop_pin].group, _pins[KEY_Stop_pin].pin)==SET?1:0;
  167. #else
  168. return 1;
  169. #endif
  170. }
  171. int gpio_funckey_value(void) {
  172. return 0;
  173. }