gpio.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. /*
  2. * File : gpio.c
  3. * This file is part of RT-Thread RTOS
  4. * COPYRIGHT (C) 2015, RT-Thread Development Team
  5. *
  6. * The license and distribution terms for this file may be
  7. * found in the file LICENSE in this distribution or at
  8. * http://www.rt-thread.org/license/LICENSE
  9. *
  10. * Change Logs:
  11. * Date Author Notes
  12. * 2015-01-05 Bernard the first version
  13. */
  14. #include <rthw.h>
  15. #include <rtdevice.h>
  16. #include <board.h>
  17. #ifdef RT_USING_PIN
  18. /* STM32 GPIO driver */
  19. struct pin_index
  20. {
  21. int index;
  22. uint32_t rcc;
  23. GPIO_TypeDef *gpio;
  24. uint32_t pin;
  25. };
  26. static const struct pin_index pins[] =
  27. {
  28. { 0, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_7},
  29. { 1, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_6},
  30. { 2, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_8},
  31. { 3, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_11},
  32. { 4, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_14},
  33. { 5, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_13},
  34. { 6, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_11},
  35. { 7, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_9},
  36. { 8, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_12},
  37. { 9, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_13},
  38. {10, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_14},
  39. {11, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_15},
  40. {12, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_6},
  41. {13, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_5},
  42. {14, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_8},
  43. {15, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_9},
  44. {16, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_5},
  45. {17, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_6},
  46. {18, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_6},
  47. {19, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_7},
  48. {20, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_9},
  49. {21, RCC_AHB1Periph_GPIOA, GPIOA, GPIO_Pin_8},
  50. {22, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_12},
  51. {23, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_2},
  52. {24, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_1},
  53. {25, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_0},
  54. {26, RCC_AHB1Periph_GPIOA, GPIOA, GPIO_Pin_9},
  55. {27, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_13},
  56. {28, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_15},
  57. {29, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_12},
  58. {30, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_10},
  59. {31, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_8},
  60. {32, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_7},
  61. {33, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_4},
  62. {34, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_3},
  63. {35, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_2},
  64. {36, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_1},
  65. {37, RCC_AHB1Periph_GPIOE, GPIOE, GPIO_Pin_0},
  66. {38, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_11},
  67. {39, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_10},
  68. {40, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_7},
  69. {41, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_3},
  70. {42, RCC_AHB1Periph_GPIOD, GPIOD, GPIO_Pin_4},
  71. {43, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_8},
  72. {44, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_15},
  73. {45, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_14},
  74. {46, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_11},
  75. {47, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_5},
  76. {48, RCC_AHB1Periph_GPIOC, GPIOC, GPIO_Pin_10},
  77. {49, RCC_AHB1Periph_GPIOA, GPIOA, GPIO_Pin_15},
  78. {50, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_4},
  79. {51, RCC_AHB1Periph_GPIOA, GPIOA, GPIO_Pin_7},
  80. {52, RCC_AHB1Periph_GPIOB, GPIOB, GPIO_Pin_3},
  81. {53, RCC_AHB1Periph_GPIOA, GPIOA, GPIO_Pin_4},
  82. {54, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_0},
  83. {55, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_1},
  84. {56, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_2},
  85. {57, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_3},
  86. {58, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_4},
  87. {59, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_5},
  88. {60, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_6},
  89. {61, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_7},
  90. {62, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_8},
  91. {63, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_9},
  92. {64, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_10},
  93. {65, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_11},
  94. {66, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_12},
  95. {67, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_13},
  96. {68, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_14},
  97. {69, RCC_AHB1Periph_GPIOF, GPIOF, GPIO_Pin_15},
  98. {70, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_0},
  99. {71, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_1},
  100. {72, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_2},
  101. {73, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_3},
  102. {74, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_4},
  103. {75, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_5},
  104. {76, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_6},
  105. {77, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_7},
  106. {78, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_8},
  107. {79, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_9},
  108. {80, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_10},
  109. {81, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_11},
  110. {82, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_12},
  111. {83, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_13},
  112. {84, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_14},
  113. {85, RCC_AHB1Periph_GPIOG, GPIOG, GPIO_Pin_15}
  114. };
  115. #define ITEM_NUM(items) sizeof(items)/sizeof(items[0])
  116. const struct pin_index *get_pin(uint8_t pin)
  117. {
  118. const struct pin_index *index;
  119. if (pin < ITEM_NUM(pins))
  120. {
  121. index = &pins[pin];
  122. }
  123. else
  124. {
  125. index = RT_NULL;
  126. }
  127. return index;
  128. };
  129. void stm32_pin_write(rt_device_t dev, rt_base_t pin, rt_base_t value)
  130. {
  131. const struct pin_index *index;
  132. index = get_pin(pin);
  133. if (index == RT_NULL)
  134. {
  135. return;
  136. }
  137. if (value == PIN_LOW)
  138. {
  139. GPIO_ResetBits(index->gpio, index->pin);
  140. }
  141. else
  142. {
  143. GPIO_SetBits(index->gpio, index->pin);
  144. }
  145. }
  146. int stm32_pin_read(rt_device_t dev, rt_base_t pin)
  147. {
  148. int value;
  149. const struct pin_index *index;
  150. value = PIN_LOW;
  151. index = get_pin(pin);
  152. if (index == RT_NULL)
  153. {
  154. return value;
  155. }
  156. if (GPIO_ReadInputDataBit(index->gpio, index->pin) == Bit_RESET)
  157. {
  158. value = PIN_LOW;
  159. }
  160. else
  161. {
  162. value = PIN_HIGH;
  163. }
  164. return value;
  165. }
  166. void stm32_pin_mode(rt_device_t dev, rt_base_t pin, rt_base_t mode)
  167. {
  168. const struct pin_index *index;
  169. GPIO_InitTypeDef GPIO_InitStructure;
  170. index = get_pin(pin);
  171. if (index == RT_NULL)
  172. {
  173. return;
  174. }
  175. /* GPIO Periph clock enable */
  176. RCC_AHB1PeriphClockCmd(index->rcc, ENABLE);
  177. /* Configure GPIO_InitStructure */
  178. GPIO_InitStructure.GPIO_Pin = index->pin;
  179. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  180. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  181. if (mode == PIN_MODE_OUTPUT)
  182. {
  183. /* output setting */
  184. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  185. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  186. }
  187. else if (mode == PIN_MODE_INPUT)
  188. {
  189. /* input setting: not pull. */
  190. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  191. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  192. }
  193. else if (mode == PIN_MODE_INPUT_PULLUP)
  194. {
  195. /* input setting: pull up. */
  196. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  197. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  198. }
  199. else
  200. {
  201. /* input setting:default. */
  202. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  203. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN;
  204. }
  205. GPIO_Init(index->gpio, &GPIO_InitStructure);
  206. }
  207. const static struct rt_pin_ops _stm32_pin_ops =
  208. {
  209. stm32_pin_mode,
  210. stm32_pin_write,
  211. stm32_pin_read,
  212. };
  213. int stm32_hw_pin_init(void)
  214. {
  215. rt_device_pin_register("pin", &_stm32_pin_ops, RT_NULL);
  216. return 0;
  217. }
  218. INIT_BOARD_EXPORT(stm32_hw_pin_init);
  219. #endif