gpio.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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 gpio_led_init(void) {
  116. #ifdef GPIO_LED_OUT_GROUP
  117. rcu_periph_clock_enable(GPIO_LED_OUT_RCU);
  118. gpio_init(GPIO_LED_OUT_GROUP, GPIO_LED_OUT_MODE, GPIO_OSPEED_50MHZ, GPIO_LED_OUT_PIN);
  119. gpio_bit_reset(GPIO_LED_OUT_GROUP, GPIO_LED_OUT_PIN);
  120. #endif
  121. }
  122. void gpio_brk_light_init(void) {
  123. #ifdef GPIO_BRAKE_LIGHT_OUT_GROUP
  124. rcu_periph_clock_enable(GPIO_BRAKE_LIGHT_OUT_RCU);
  125. gpio_init(GPIO_BRAKE_LIGHT_OUT_GROUP, GPIO_BRAKE_LIGHT_OUT_MODE, GPIO_OSPEED_50MHZ, GPIO_BRAKE_LIGHT_OUT_PIN);
  126. gpio_bit_reset(GPIO_BRAKE_LIGHT_OUT_GROUP, GPIO_BRAKE_LIGHT_OUT_PIN);
  127. #endif
  128. }
  129. void mc_gpio_init(void) {
  130. gpio_mlock_init();
  131. gpio_mc_brk_init();
  132. gpio_fan_det_init();
  133. gpio_led_init();
  134. gpio_brk_light_init();
  135. }
  136. void gpio_led_enable(bool enable) {
  137. #ifdef GPIO_LED_OUT_GROUP
  138. gpio_bit_write(GPIO_BRAKE_LIGHT_OUT_GROUP, GPIO_BRAKE_LIGHT_OUT_PIN, enable?SET:RESET);
  139. #endif
  140. }
  141. void gpio_brk_light_enable(bool enable) {
  142. #ifdef GPIO_BRAKE_LIGHT_OUT_GROUP
  143. gpio_bit_write(GPIO_BRAKE_LIGHT_OUT_GROUP, GPIO_BRAKE_LIGHT_OUT_PIN, enable?SET:RESET);
  144. #endif
  145. }
  146. bool mc_get_gpio_brake(void) {
  147. return gpio_input_bit_get(GPIO_BRAKE_IN_GROUP, GPIO_BRAKE_IN_PIN) == SET;
  148. }
  149. bool mc_get_gpio_brake1(void) {
  150. #ifdef GPIO_BRAKE1_IN_GROUP
  151. return gpio_input_bit_get(GPIO_BRAKE1_IN_GROUP, GPIO_BRAKE1_IN_PIN) == SET;
  152. #else
  153. return mc_get_gpio_brake();
  154. #endif
  155. }
  156. bool gpio_motor_locked(void) {
  157. #ifdef GPIO_MLOCK_IN_GROUP
  158. return gpio_input_bit_get(GPIO_MLOCK_IN_GROUP, GPIO_MLOCK_IN_PIN) == RESET;
  159. #else
  160. return false;
  161. #endif
  162. }
  163. void gpio_ir2136_enable(bool enable) {
  164. #ifdef GD32_FOC_DEMO
  165. gpio_bit_write(_pins[IR2136S_Enable_pin].group, _pins[IR2136S_Enable_pin].pin, (enable)?SET:RESET);
  166. #endif
  167. }
  168. void gpio_led1_enable(bool enable) {
  169. #ifdef GD32_FOC_DEMO
  170. gpio_bit_write(_pins[LED1_Enable_pin].group, _pins[LED1_Enable_pin].pin, (enable)?SET:RESET);
  171. #endif
  172. }
  173. void gpio_led2_enable(bool enable) {
  174. #ifdef GD32_FOC_DEMO
  175. //gpio_bit_write(_pins[LED2_Enable_pin].group, _pins[LED2_Enable_pin].pin, (enable)?SET:RESET);
  176. #endif
  177. }
  178. void gpio_led3_enable(bool enable) {
  179. #ifdef GD32_FOC_DEMO
  180. gpio_bit_write(_pins[LED3_Enable_pin].group, _pins[LED3_Enable_pin].pin, (enable)?SET:RESET);
  181. #endif
  182. }
  183. int gpio_startkey_value(void) {
  184. #ifdef GD32_FOC_DEMO
  185. return gpio_input_bit_get(_pins[KEY_Start_pin].group, _pins[KEY_Start_pin].pin)==SET?1:0;
  186. #else
  187. return 1;
  188. #endif
  189. }
  190. int gpio_stopkey_value(void) {
  191. #ifdef GD32_FOC_DEMO
  192. return gpio_input_bit_get(_pins[KEY_Stop_pin].group, _pins[KEY_Stop_pin].pin)==SET?1:0;
  193. #else
  194. return 1;
  195. #endif
  196. }
  197. int gpio_funckey_value(void) {
  198. return 0;
  199. }