gpio.c 5.5 KB

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