board.c 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. /*
  2. ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. /*
  14. * This file has been automatically generated using ChibiStudio board
  15. * generator plugin. Do not edit manually.
  16. */
  17. #include "hal.h"
  18. #include "stm32_gpio.h"
  19. /*===========================================================================*/
  20. /* Driver local definitions. */
  21. /*===========================================================================*/
  22. /*===========================================================================*/
  23. /* Driver exported variables. */
  24. /*===========================================================================*/
  25. /*===========================================================================*/
  26. /* Driver local variables and types. */
  27. /*===========================================================================*/
  28. /**
  29. * @brief Type of STM32 GPIO port setup.
  30. */
  31. typedef struct {
  32. uint32_t moder;
  33. uint32_t otyper;
  34. uint32_t ospeedr;
  35. uint32_t pupdr;
  36. uint32_t odr;
  37. uint32_t afrl;
  38. uint32_t afrh;
  39. } gpio_setup_t;
  40. /**
  41. * @brief Type of STM32 GPIO initialization data.
  42. */
  43. typedef struct {
  44. #if STM32_HAS_GPIOA || defined(__DOXYGEN__)
  45. gpio_setup_t PAData;
  46. #endif
  47. #if STM32_HAS_GPIOB || defined(__DOXYGEN__)
  48. gpio_setup_t PBData;
  49. #endif
  50. #if STM32_HAS_GPIOC || defined(__DOXYGEN__)
  51. gpio_setup_t PCData;
  52. #endif
  53. #if STM32_HAS_GPIOD || defined(__DOXYGEN__)
  54. gpio_setup_t PDData;
  55. #endif
  56. #if STM32_HAS_GPIOE || defined(__DOXYGEN__)
  57. gpio_setup_t PEData;
  58. #endif
  59. #if STM32_HAS_GPIOF || defined(__DOXYGEN__)
  60. gpio_setup_t PFData;
  61. #endif
  62. #if STM32_HAS_GPIOG || defined(__DOXYGEN__)
  63. gpio_setup_t PGData;
  64. #endif
  65. #if STM32_HAS_GPIOH || defined(__DOXYGEN__)
  66. gpio_setup_t PHData;
  67. #endif
  68. #if STM32_HAS_GPIOI || defined(__DOXYGEN__)
  69. gpio_setup_t PIData;
  70. #endif
  71. #if STM32_HAS_GPIOJ || defined(__DOXYGEN__)
  72. gpio_setup_t PJData;
  73. #endif
  74. #if STM32_HAS_GPIOK || defined(__DOXYGEN__)
  75. gpio_setup_t PKData;
  76. #endif
  77. } gpio_config_t;
  78. /**
  79. * @brief STM32 GPIO static initialization data.
  80. */
  81. static const gpio_config_t gpio_default_config = {
  82. #if STM32_HAS_GPIOA
  83. {VAL_GPIOA_MODER, VAL_GPIOA_OTYPER, VAL_GPIOA_OSPEEDR, VAL_GPIOA_PUPDR, VAL_GPIOA_ODR, VAL_GPIOA_AFRL, VAL_GPIOA_AFRH},
  84. #endif
  85. #if STM32_HAS_GPIOB
  86. {VAL_GPIOB_MODER, VAL_GPIOB_OTYPER, VAL_GPIOB_OSPEEDR, VAL_GPIOB_PUPDR, VAL_GPIOB_ODR, VAL_GPIOB_AFRL, VAL_GPIOB_AFRH},
  87. #endif
  88. #if STM32_HAS_GPIOC
  89. {VAL_GPIOC_MODER, VAL_GPIOC_OTYPER, VAL_GPIOC_OSPEEDR, VAL_GPIOC_PUPDR, VAL_GPIOC_ODR, VAL_GPIOC_AFRL, VAL_GPIOC_AFRH},
  90. #endif
  91. #if STM32_HAS_GPIOD
  92. {VAL_GPIOD_MODER, VAL_GPIOD_OTYPER, VAL_GPIOD_OSPEEDR, VAL_GPIOD_PUPDR, VAL_GPIOD_ODR, VAL_GPIOD_AFRL, VAL_GPIOD_AFRH},
  93. #endif
  94. #if STM32_HAS_GPIOE
  95. {VAL_GPIOE_MODER, VAL_GPIOE_OTYPER, VAL_GPIOE_OSPEEDR, VAL_GPIOE_PUPDR, VAL_GPIOE_ODR, VAL_GPIOE_AFRL, VAL_GPIOE_AFRH},
  96. #endif
  97. #if STM32_HAS_GPIOF
  98. {VAL_GPIOF_MODER, VAL_GPIOF_OTYPER, VAL_GPIOF_OSPEEDR, VAL_GPIOF_PUPDR, VAL_GPIOF_ODR, VAL_GPIOF_AFRL, VAL_GPIOF_AFRH},
  99. #endif
  100. #if STM32_HAS_GPIOG
  101. {VAL_GPIOG_MODER, VAL_GPIOG_OTYPER, VAL_GPIOG_OSPEEDR, VAL_GPIOG_PUPDR, VAL_GPIOG_ODR, VAL_GPIOG_AFRL, VAL_GPIOG_AFRH},
  102. #endif
  103. #if STM32_HAS_GPIOH
  104. {VAL_GPIOH_MODER, VAL_GPIOH_OTYPER, VAL_GPIOH_OSPEEDR, VAL_GPIOH_PUPDR, VAL_GPIOH_ODR, VAL_GPIOH_AFRL, VAL_GPIOH_AFRH},
  105. #endif
  106. #if STM32_HAS_GPIOI
  107. {VAL_GPIOI_MODER, VAL_GPIOI_OTYPER, VAL_GPIOI_OSPEEDR, VAL_GPIOI_PUPDR, VAL_GPIOI_ODR, VAL_GPIOI_AFRL, VAL_GPIOI_AFRH},
  108. #endif
  109. #if STM32_HAS_GPIOJ
  110. {VAL_GPIOJ_MODER, VAL_GPIOJ_OTYPER, VAL_GPIOJ_OSPEEDR, VAL_GPIOJ_PUPDR, VAL_GPIOJ_ODR, VAL_GPIOJ_AFRL, VAL_GPIOJ_AFRH},
  111. #endif
  112. #if STM32_HAS_GPIOK
  113. {VAL_GPIOK_MODER, VAL_GPIOK_OTYPER, VAL_GPIOK_OSPEEDR, VAL_GPIOK_PUPDR, VAL_GPIOK_ODR, VAL_GPIOK_AFRL, VAL_GPIOK_AFRH}
  114. #endif
  115. };
  116. /*===========================================================================*/
  117. /* Driver local functions. */
  118. /*===========================================================================*/
  119. static void gpio_init(stm32_gpio_t *gpiop, const gpio_setup_t *config) {
  120. gpiop->OTYPER = config->otyper;
  121. gpiop->OSPEEDR = config->ospeedr;
  122. gpiop->PUPDR = config->pupdr;
  123. gpiop->ODR = config->odr;
  124. gpiop->AFRL = config->afrl;
  125. gpiop->AFRH = config->afrh;
  126. gpiop->MODER = config->moder;
  127. }
  128. static void stm32_gpio_init(void) {
  129. /* Enabling GPIO-related clocks, the mask comes from the
  130. registry header file.*/
  131. rccResetAHB1(STM32_GPIO_EN_MASK);
  132. rccEnableAHB1(STM32_GPIO_EN_MASK, true);
  133. /* Initializing all the defined GPIO ports.*/
  134. #if STM32_HAS_GPIOA
  135. gpio_init(GPIOA, &gpio_default_config.PAData);
  136. #endif
  137. #if STM32_HAS_GPIOB
  138. gpio_init(GPIOB, &gpio_default_config.PBData);
  139. #endif
  140. #if STM32_HAS_GPIOC
  141. gpio_init(GPIOC, &gpio_default_config.PCData);
  142. #endif
  143. #if STM32_HAS_GPIOD
  144. gpio_init(GPIOD, &gpio_default_config.PDData);
  145. #endif
  146. #if STM32_HAS_GPIOE
  147. gpio_init(GPIOE, &gpio_default_config.PEData);
  148. #endif
  149. #if STM32_HAS_GPIOF
  150. gpio_init(GPIOF, &gpio_default_config.PFData);
  151. #endif
  152. #if STM32_HAS_GPIOG
  153. gpio_init(GPIOG, &gpio_default_config.PGData);
  154. #endif
  155. #if STM32_HAS_GPIOH
  156. gpio_init(GPIOH, &gpio_default_config.PHData);
  157. #endif
  158. #if STM32_HAS_GPIOI
  159. gpio_init(GPIOI, &gpio_default_config.PIData);
  160. #endif
  161. #if STM32_HAS_GPIOJ
  162. gpio_init(GPIOJ, &gpio_default_config.PJData);
  163. #endif
  164. #if STM32_HAS_GPIOK
  165. gpio_init(GPIOK, &gpio_default_config.PKData);
  166. #endif
  167. }
  168. /*===========================================================================*/
  169. /* Driver interrupt handlers. */
  170. /*===========================================================================*/
  171. /*===========================================================================*/
  172. /* Driver exported functions. */
  173. /*===========================================================================*/
  174. __attribute__((weak)) void enter_bootloader_mode_if_requested(void) {}
  175. /**
  176. * @brief Early initialization code.
  177. * @details GPIO ports and system clocks are initialized before everything
  178. * else.
  179. */
  180. void __early_init(void) {
  181. enter_bootloader_mode_if_requested();
  182. stm32_gpio_init();
  183. stm32_clock_init();
  184. }
  185. #if HAL_USE_SDC || defined(__DOXYGEN__)
  186. /**
  187. * @brief SDC card detection.
  188. */
  189. bool sdc_lld_is_card_inserted(SDCDriver *sdcp) {
  190. (void)sdcp;
  191. /* TODO: Fill the implementation.*/
  192. return true;
  193. }
  194. /**
  195. * @brief SDC card write protection detection.
  196. */
  197. bool sdc_lld_is_write_protected(SDCDriver *sdcp) {
  198. (void)sdcp;
  199. /* TODO: Fill the implementation.*/
  200. return false;
  201. }
  202. #endif /* HAL_USE_SDC */
  203. #if HAL_USE_MMC_SPI || defined(__DOXYGEN__)
  204. /**
  205. * @brief MMC_SPI card detection.
  206. */
  207. bool mmc_lld_is_card_inserted(MMCDriver *mmcp) {
  208. (void)mmcp;
  209. /* TODO: Fill the implementation.*/
  210. return true;
  211. }
  212. /**
  213. * @brief MMC_SPI card write protection detection.
  214. */
  215. bool mmc_lld_is_write_protected(MMCDriver *mmcp) {
  216. (void)mmcp;
  217. /* TODO: Fill the implementation.*/
  218. return false;
  219. }
  220. #endif
  221. /**
  222. * @brief Board-specific initialization code.
  223. * @todo Add your board-specific code, if any.
  224. */
  225. void boardInit(void) {}