gpio.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. #include "gpio.h"
  2. /* all pins used as gpio(input/output/irq) must be defined here */
  3. void gpio_init(void){
  4. rcu_periph_clock_enable(RCU_GPIOB);
  5. rcu_periph_clock_enable(RCU_GPIOC);
  6. rcu_periph_clock_enable(RCU_GPIOF);
  7. #if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
  8. //hall 2 detect
  9. gpio_mode_input(GPIOC, GPIO_PUPD_PULLUP, GPIO_PIN_13);
  10. //hall 1 detect
  11. gpio_mode_input(GPIOC, GPIO_PUPD_PULLUP, GPIO_PIN_15);
  12. //IR uart0 enable
  13. gpio_mode_output(GPIOC, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_14);
  14. //IR uart2 enable
  15. gpio_mode_output(GPIOF, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_0);
  16. //cs1180 power enable
  17. gpio_mode_output(GPIOB, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_12);
  18. //detect cs1180 ready
  19. gpio_mode_input(GPIOA, GPIO_PUPD_NONE, GPIO_PIN_0);
  20. //CS1180 cs
  21. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9);
  22. cs1180_cs(1);
  23. #ifdef SHARK_BOARD_SP700_OLD_CS1180
  24. //老的sp700+cs1180上,GPIOA8和GPIOB15连在一起,为了不影响B15 pin的spi 功能,A8pin需要设置为输入
  25. gpio_mode_analog_input(GPIOA, GPIO_PIN_8);
  26. #endif
  27. #elif (CONFIG_BOARD_TYPE==SHARK_BOARD_SP600)
  28. //rs485 INT ,this can be used detect rs485 in/out, then open rs485 power, and then detect GPIOF0
  29. gpio_mode_input(GPIOC, GPIO_PUPD_NONE, GPIO_PIN_13);
  30. //rs485 pwr enable
  31. gpio_mode_output(GPIOC, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_14);
  32. //rs485 in/out detect, only works when rs485 pwr on
  33. gpio_mode_input(GPIOF, GPIO_PUPD_NONE, GPIO_PIN_0);
  34. //cs1180 pwr enable
  35. gpio_mode_output(GPIOC, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_15);
  36. //detect cs1180 ready
  37. gpio_mode_input(GPIOB, GPIO_PUPD_NONE, GPIO_PIN_12);
  38. //CS1180 cs
  39. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_8);
  40. cs1180_cs(1);
  41. //LED 0,1,2
  42. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_2|GPIO_PIN_3);
  43. gpio_mode_output(GPIOF, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_6);
  44. //LED3,4
  45. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_10|GPIO_PIN_9);
  46. #endif
  47. //temp senser enable
  48. gpio_mode_output(GPIOF, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_1);
  49. //charger detect
  50. gpio_mode_input(GPIOB, GPIO_PUPD_NONE, GPIO_PIN_10);
  51. //aux 12v power enable
  52. gpio_mode_output(GPIOB, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_2);
  53. //aux 12v lock detect
  54. gpio_mode_input(GPIOB, GPIO_PUPD_NONE, GPIO_PIN_11);
  55. //DC-DC power good indicat
  56. gpio_mode_input(GPIOF, GPIO_PUPD_NONE, GPIO_PIN_7);
  57. //ms5238 irq, This pin is a NMOS open drain output pin and output is “L” level if interrupted
  58. gpio_mode_input(GPIOA, GPIO_PUPD_NONE, GPIO_PIN_12);
  59. //ML5238 cs
  60. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_15);
  61. #if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP600)
  62. RS485_PWR_ENABLE(1);
  63. #endif
  64. }
  65. void enable_mcu_power(void){
  66. //DC-DC enable
  67. rcu_periph_clock_enable(RCU_GPIOA);
  68. gpio_mode_output(GPIOA, GPIO_PUPD_NONE, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, GPIO_PIN_11);
  69. gpio_bit_write(GPIOA,GPIO_PIN_11,SET);
  70. //DC-DC power good indicat
  71. rcu_periph_clock_enable(RCU_GPIOF);
  72. gpio_mode_input(GPIOF, GPIO_PUPD_NONE, GPIO_PIN_7);
  73. while(!IS_DCDC_POWER_GOOD());
  74. }
  75. static void enable_exti4_15_irq(int enable){
  76. if (enable){
  77. nvic_irq_enable(EXTI4_15_IRQn, 4U, 0U);
  78. }else { //many pins share the EXTI4_15_IRQn, do'nt stop it really
  79. //nvic_irq_disable(EXTI4_15_IRQn);
  80. }
  81. }
  82. void charger_detect_irq_enable(int enable){
  83. if (enable){
  84. syscfg_exti_line_config(EXTI_SOURCE_GPIOB, EXTI_SOURCE_PIN10);
  85. exti_init(EXTI_10, EXTI_INTERRUPT, EXTI_TRIG_FALLING);
  86. exti_flag_clear(EXTI_10);
  87. enable_exti4_15_irq(1);
  88. }else {
  89. enable_exti4_15_irq(0);
  90. exti_interrupt_disable(EXTI_10);
  91. exti_flag_clear(EXTI_10);
  92. }
  93. }
  94. void ml5238_irq_enable(int enable){
  95. if (enable){
  96. syscfg_exti_line_config(EXTI_SOURCE_GPIOA, EXTI_SOURCE_PIN12);
  97. exti_init(EXTI_12, EXTI_INTERRUPT, EXTI_TRIG_FALLING);
  98. exti_flag_clear(EXTI_12);
  99. enable_exti4_15_irq(1);
  100. }else {
  101. enable_exti4_15_irq(0);
  102. exti_interrupt_disable(EXTI_12);
  103. exti_flag_clear(EXTI_12);
  104. }
  105. }
  106. #if (CONFIG_BOARD_TYPE==SHARK_BOARD_SP700)
  107. void hall_1_detect_irq_enable(int enable){
  108. if (enable){
  109. syscfg_exti_line_config(EXTI_SOURCE_GPIOC, EXTI_SOURCE_PIN15);
  110. exti_flag_clear(EXTI_15);
  111. exti_init(EXTI_15, EXTI_INTERRUPT, EXTI_TRIG_FALLING);
  112. enable_exti4_15_irq(1);
  113. }else {
  114. enable_exti4_15_irq(0);
  115. exti_interrupt_disable(EXTI_15);
  116. exti_flag_clear(EXTI_15);
  117. }
  118. }
  119. #else
  120. void hall_1_detect_irq_enable(int enable){
  121. }
  122. #endif
  123. void hall_2_detect_irq_enable(int enable){
  124. if (enable){
  125. syscfg_exti_line_config(EXTI_SOURCE_GPIOC, EXTI_SOURCE_PIN13);
  126. exti_flag_clear(EXTI_13);
  127. exti_init(EXTI_13, EXTI_INTERRUPT, EXTI_TRIG_FALLING);
  128. enable_exti4_15_irq(1);
  129. }else {
  130. enable_exti4_15_irq(0);
  131. exti_interrupt_disable(EXTI_13);
  132. exti_flag_clear(EXTI_13);
  133. }
  134. }
  135. void small_current_short_irq_enable(int enable){
  136. if (enable){
  137. syscfg_exti_line_config(EXTI_SOURCE_GPIOB, EXTI_SOURCE_PIN11);
  138. exti_flag_clear(EXTI_11);
  139. exti_init(EXTI_11, EXTI_INTERRUPT, EXTI_TRIG_FALLING);
  140. enable_exti4_15_irq(1);
  141. }else {
  142. enable_exti4_15_irq(0);
  143. exti_interrupt_disable(EXTI_11);
  144. exti_flag_clear(EXTI_11);
  145. }
  146. }
  147. void dcdc_pwr_detect_irq_enable(int enable){
  148. if (enable){
  149. syscfg_exti_line_config(EXTI_SOURCE_GPIOF, EXTI_SOURCE_PIN7);
  150. exti_init(EXTI_7, EXTI_INTERRUPT, EXTI_TRIG_BOTH);
  151. exti_flag_clear(EXTI_7);
  152. enable_exti4_15_irq(1);
  153. }else {
  154. enable_exti4_15_irq(0);
  155. exti_interrupt_disable(EXTI_7);
  156. exti_flag_clear(EXTI_7);
  157. }
  158. }