1
0

gpio.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  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. };
  83. #define ITEM_NUM(items) sizeof(items)/sizeof(items[0])
  84. const struct pin_index *get_pin(uint8_t pin)
  85. {
  86. const struct pin_index *index;
  87. if (pin < ITEM_NUM(pins))
  88. {
  89. index = &pins[pin];
  90. }
  91. else
  92. {
  93. index = RT_NULL;
  94. }
  95. return index;
  96. };
  97. void stm32_pin_write(rt_device_t dev, rt_base_t pin, rt_base_t value)
  98. {
  99. const struct pin_index *index;
  100. index = get_pin(pin);
  101. if (index == RT_NULL)
  102. {
  103. return;
  104. }
  105. if (value == PIN_LOW)
  106. {
  107. GPIO_ResetBits(index->gpio, index->pin);
  108. }
  109. else
  110. {
  111. GPIO_SetBits(index->gpio, index->pin);
  112. }
  113. }
  114. int stm32_pin_read(rt_device_t dev, rt_base_t pin)
  115. {
  116. int value;
  117. const struct pin_index *index;
  118. value = PIN_LOW;
  119. index = get_pin(pin);
  120. if (index == RT_NULL)
  121. {
  122. return value;
  123. }
  124. if (GPIO_ReadInputDataBit(index->gpio, index->pin) == Bit_RESET)
  125. {
  126. value = PIN_LOW;
  127. }
  128. else
  129. {
  130. value = PIN_HIGH;
  131. }
  132. return value;
  133. }
  134. void stm32_pin_mode(rt_device_t dev, rt_base_t pin, rt_base_t mode)
  135. {
  136. const struct pin_index *index;
  137. GPIO_InitTypeDef GPIO_InitStructure;
  138. index = get_pin(pin);
  139. if (index == RT_NULL)
  140. {
  141. return;
  142. }
  143. /* GPIO Periph clock enable */
  144. RCC_AHB1PeriphClockCmd(index->rcc, ENABLE);
  145. /* Configure GPIO_InitStructure */
  146. GPIO_InitStructure.GPIO_Pin = index->pin;
  147. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  148. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  149. if (mode == PIN_MODE_OUTPUT)
  150. {
  151. /* output setting */
  152. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  153. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  154. }
  155. else if (mode == PIN_MODE_INPUT)
  156. {
  157. /* input setting: not pull. */
  158. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  159. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  160. }
  161. else if (mode == PIN_MODE_INPUT_PULLUP)
  162. {
  163. /* input setting: pull up. */
  164. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  165. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  166. }
  167. else
  168. {
  169. /* input setting:default. */
  170. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  171. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN;
  172. }
  173. GPIO_Init(index->gpio, &GPIO_InitStructure);
  174. }
  175. const static struct rt_pin_ops _stm32_pin_ops =
  176. {
  177. stm32_pin_mode,
  178. stm32_pin_write,
  179. stm32_pin_read,
  180. };
  181. int stm32_hw_pin_init(void)
  182. {
  183. rt_device_pin_register("pin", &_stm32_pin_ops, RT_NULL);
  184. return 0;
  185. }
  186. INIT_BOARD_EXPORT(stm32_hw_pin_init);
  187. #endif