stm32h7xx_hal_msp.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * File Name : stm32h7xx_hal_msp.c
  5. * Description : This file provides code for the MSP Initialization
  6. * and de-Initialization codes.
  7. ******************************************************************************
  8. * @attention
  9. *
  10. * <h2><center>&copy; Copyright (c) 2019 STMicroelectronics.
  11. * All rights reserved.</center></h2>
  12. *
  13. * This software component is licensed by ST under BSD 3-Clause license,
  14. * the "License"; You may not use this file except in compliance with the
  15. * License. You may obtain a copy of the License at:
  16. * opensource.org/licenses/BSD-3-Clause
  17. *
  18. ******************************************************************************
  19. */
  20. /* USER CODE END Header */
  21. /* Includes ------------------------------------------------------------------*/
  22. #include "main.h"
  23. /* USER CODE BEGIN Includes */
  24. /* USER CODE END Includes */
  25. /* Private typedef -----------------------------------------------------------*/
  26. /* USER CODE BEGIN TD */
  27. /* USER CODE END TD */
  28. /* Private define ------------------------------------------------------------*/
  29. /* USER CODE BEGIN Define */
  30. /* USER CODE END Define */
  31. /* Private macro -------------------------------------------------------------*/
  32. /* USER CODE BEGIN Macro */
  33. /* USER CODE END Macro */
  34. /* Private variables ---------------------------------------------------------*/
  35. /* USER CODE BEGIN PV */
  36. /* USER CODE END PV */
  37. /* Private function prototypes -----------------------------------------------*/
  38. /* USER CODE BEGIN PFP */
  39. /* USER CODE END PFP */
  40. /* External functions --------------------------------------------------------*/
  41. /* USER CODE BEGIN ExternalFunctions */
  42. /* USER CODE END ExternalFunctions */
  43. /* USER CODE BEGIN 0 */
  44. /* USER CODE END 0 */
  45. void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
  46. /**
  47. * Initializes the Global MSP.
  48. */
  49. void HAL_MspInit(void)
  50. {
  51. /* USER CODE BEGIN MspInit 0 */
  52. /* USER CODE END MspInit 0 */
  53. __HAL_RCC_SYSCFG_CLK_ENABLE();
  54. /* System interrupt init*/
  55. /* USER CODE BEGIN MspInit 1 */
  56. /* USER CODE END MspInit 1 */
  57. }
  58. /**
  59. * @brief ADC MSP Initialization
  60. * This function configures the hardware resources used in this example
  61. * @param hadc: ADC handle pointer
  62. * @retval None
  63. */
  64. void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
  65. {
  66. GPIO_InitTypeDef GPIO_InitStruct = {0};
  67. if(hadc->Instance==ADC3)
  68. {
  69. /* USER CODE BEGIN ADC3_MspInit 0 */
  70. /* USER CODE END ADC3_MspInit 0 */
  71. /* Peripheral clock enable */
  72. __HAL_RCC_ADC3_CLK_ENABLE();
  73. __HAL_RCC_GPIOF_CLK_ENABLE();
  74. /**ADC3 GPIO Configuration
  75. PF3 ------> ADC3_INP5
  76. PF8 ------> ADC3_INP7
  77. */
  78. GPIO_InitStruct.Pin = GPIO_PIN_3|GPIO_PIN_8;
  79. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  80. GPIO_InitStruct.Pull = GPIO_NOPULL;
  81. HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
  82. /* USER CODE BEGIN ADC3_MspInit 1 */
  83. /* USER CODE END ADC3_MspInit 1 */
  84. }
  85. }
  86. /**
  87. * @brief ADC MSP De-Initialization
  88. * This function freeze the hardware resources used in this example
  89. * @param hadc: ADC handle pointer
  90. * @retval None
  91. */
  92. void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc)
  93. {
  94. if(hadc->Instance==ADC3)
  95. {
  96. /* USER CODE BEGIN ADC3_MspDeInit 0 */
  97. /* USER CODE END ADC3_MspDeInit 0 */
  98. /* Peripheral clock disable */
  99. __HAL_RCC_ADC3_CLK_DISABLE();
  100. /**ADC3 GPIO Configuration
  101. PF3 ------> ADC3_INP5
  102. PF8 ------> ADC3_INP7
  103. */
  104. HAL_GPIO_DeInit(GPIOF, GPIO_PIN_3|GPIO_PIN_8);
  105. /* USER CODE BEGIN ADC3_MspDeInit 1 */
  106. /* USER CODE END ADC3_MspDeInit 1 */
  107. }
  108. }
  109. /**
  110. * @brief CRC MSP Initialization
  111. * This function configures the hardware resources used in this example
  112. * @param hcrc: CRC handle pointer
  113. * @retval None
  114. */
  115. void HAL_CRC_MspInit(CRC_HandleTypeDef* hcrc)
  116. {
  117. if(hcrc->Instance==CRC)
  118. {
  119. /* USER CODE BEGIN CRC_MspInit 0 */
  120. /* USER CODE END CRC_MspInit 0 */
  121. /* Peripheral clock enable */
  122. __HAL_RCC_CRC_CLK_ENABLE();
  123. /* USER CODE BEGIN CRC_MspInit 1 */
  124. /* USER CODE END CRC_MspInit 1 */
  125. }
  126. }
  127. /**
  128. * @brief CRC MSP De-Initialization
  129. * This function freeze the hardware resources used in this example
  130. * @param hcrc: CRC handle pointer
  131. * @retval None
  132. */
  133. void HAL_CRC_MspDeInit(CRC_HandleTypeDef* hcrc)
  134. {
  135. if(hcrc->Instance==CRC)
  136. {
  137. /* USER CODE BEGIN CRC_MspDeInit 0 */
  138. /* USER CODE END CRC_MspDeInit 0 */
  139. /* Peripheral clock disable */
  140. __HAL_RCC_CRC_CLK_DISABLE();
  141. /* USER CODE BEGIN CRC_MspDeInit 1 */
  142. /* USER CODE END CRC_MspDeInit 1 */
  143. }
  144. }
  145. /**
  146. * @brief DAC MSP Initialization
  147. * This function configures the hardware resources used in this example
  148. * @param hdac: DAC handle pointer
  149. * @retval None
  150. */
  151. void HAL_DAC_MspInit(DAC_HandleTypeDef* hdac)
  152. {
  153. GPIO_InitTypeDef GPIO_InitStruct = {0};
  154. if(hdac->Instance==DAC1)
  155. {
  156. /* USER CODE BEGIN DAC1_MspInit 0 */
  157. /* USER CODE END DAC1_MspInit 0 */
  158. /* Peripheral clock enable */
  159. __HAL_RCC_DAC12_CLK_ENABLE();
  160. __HAL_RCC_GPIOA_CLK_ENABLE();
  161. /**DAC1 GPIO Configuration
  162. PA4 ------> DAC1_OUT1
  163. */
  164. GPIO_InitStruct.Pin = GPIO_PIN_4;
  165. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  166. GPIO_InitStruct.Pull = GPIO_NOPULL;
  167. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  168. /* USER CODE BEGIN DAC1_MspInit 1 */
  169. /* USER CODE END DAC1_MspInit 1 */
  170. }
  171. }
  172. /**
  173. * @brief DAC MSP De-Initialization
  174. * This function freeze the hardware resources used in this example
  175. * @param hdac: DAC handle pointer
  176. * @retval None
  177. */
  178. void HAL_DAC_MspDeInit(DAC_HandleTypeDef* hdac)
  179. {
  180. if(hdac->Instance==DAC1)
  181. {
  182. /* USER CODE BEGIN DAC1_MspDeInit 0 */
  183. /* USER CODE END DAC1_MspDeInit 0 */
  184. /* Peripheral clock disable */
  185. __HAL_RCC_DAC12_CLK_DISABLE();
  186. /**DAC1 GPIO Configuration
  187. PA4 ------> DAC1_OUT1
  188. */
  189. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_4);
  190. /* USER CODE BEGIN DAC1_MspDeInit 1 */
  191. /* USER CODE END DAC1_MspDeInit 1 */
  192. }
  193. }
  194. /**
  195. * @brief ETH MSP Initialization
  196. * This function configures the hardware resources used in this example
  197. * @param heth: ETH handle pointer
  198. * @retval None
  199. */
  200. void HAL_ETH_MspInit(ETH_HandleTypeDef* heth)
  201. {
  202. GPIO_InitTypeDef GPIO_InitStruct = {0};
  203. if(heth->Instance==ETH)
  204. {
  205. /* USER CODE BEGIN ETH_MspInit 0 */
  206. /* USER CODE END ETH_MspInit 0 */
  207. /* Peripheral clock enable */
  208. __HAL_RCC_ETH1MAC_CLK_ENABLE();
  209. __HAL_RCC_ETH1TX_CLK_ENABLE();
  210. __HAL_RCC_ETH1RX_CLK_ENABLE();
  211. __HAL_RCC_GPIOG_CLK_ENABLE();
  212. __HAL_RCC_GPIOC_CLK_ENABLE();
  213. __HAL_RCC_GPIOA_CLK_ENABLE();
  214. /**ETH GPIO Configuration
  215. PG14 ------> ETH_TXD1
  216. PG13 ------> ETH_TXD0
  217. PG11 ------> ETH_TX_EN
  218. PC1 ------> ETH_MDC
  219. PA1 ------> ETH_REF_CLK
  220. PC4 ------> ETH_RXD0
  221. PA2 ------> ETH_MDIO
  222. PC5 ------> ETH_RXD1
  223. PA7 ------> ETH_CRS_DV
  224. */
  225. GPIO_InitStruct.Pin = GPIO_PIN_14|GPIO_PIN_13|GPIO_PIN_11;
  226. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  227. GPIO_InitStruct.Pull = GPIO_NOPULL;
  228. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  229. GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
  230. HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
  231. GPIO_InitStruct.Pin = GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5;
  232. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  233. GPIO_InitStruct.Pull = GPIO_NOPULL;
  234. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  235. GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
  236. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  237. GPIO_InitStruct.Pin = GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_7;
  238. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  239. GPIO_InitStruct.Pull = GPIO_NOPULL;
  240. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  241. GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
  242. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  243. /* USER CODE BEGIN ETH_MspInit 1 */
  244. /* USER CODE END ETH_MspInit 1 */
  245. }
  246. }
  247. /**
  248. * @brief ETH MSP De-Initialization
  249. * This function freeze the hardware resources used in this example
  250. * @param heth: ETH handle pointer
  251. * @retval None
  252. */
  253. void HAL_ETH_MspDeInit(ETH_HandleTypeDef* heth)
  254. {
  255. if(heth->Instance==ETH)
  256. {
  257. /* USER CODE BEGIN ETH_MspDeInit 0 */
  258. /* USER CODE END ETH_MspDeInit 0 */
  259. /* Peripheral clock disable */
  260. __HAL_RCC_ETH1MAC_CLK_DISABLE();
  261. __HAL_RCC_ETH1TX_CLK_DISABLE();
  262. __HAL_RCC_ETH1RX_CLK_DISABLE();
  263. /**ETH GPIO Configuration
  264. PG14 ------> ETH_TXD1
  265. PG13 ------> ETH_TXD0
  266. PG11 ------> ETH_TX_EN
  267. PC1 ------> ETH_MDC
  268. PA1 ------> ETH_REF_CLK
  269. PC4 ------> ETH_RXD0
  270. PA2 ------> ETH_MDIO
  271. PC5 ------> ETH_RXD1
  272. PA7 ------> ETH_CRS_DV
  273. */
  274. HAL_GPIO_DeInit(GPIOG, GPIO_PIN_14|GPIO_PIN_13|GPIO_PIN_11);
  275. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5);
  276. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_7);
  277. /* USER CODE BEGIN ETH_MspDeInit 1 */
  278. /* USER CODE END ETH_MspDeInit 1 */
  279. }
  280. }
  281. /**
  282. * @brief QSPI MSP Initialization
  283. * This function configures the hardware resources used in this example
  284. * @param hqspi: QSPI handle pointer
  285. * @retval None
  286. */
  287. void HAL_QSPI_MspInit(QSPI_HandleTypeDef* hqspi)
  288. {
  289. GPIO_InitTypeDef GPIO_InitStruct = {0};
  290. if(hqspi->Instance==QUADSPI)
  291. {
  292. /* USER CODE BEGIN QUADSPI_MspInit 0 */
  293. /* USER CODE END QUADSPI_MspInit 0 */
  294. /* Peripheral clock enable */
  295. __HAL_RCC_QSPI_CLK_ENABLE();
  296. __HAL_RCC_GPIOG_CLK_ENABLE();
  297. __HAL_RCC_GPIOF_CLK_ENABLE();
  298. __HAL_RCC_GPIOB_CLK_ENABLE();
  299. __HAL_RCC_GPIOD_CLK_ENABLE();
  300. /**QUADSPI GPIO Configuration
  301. PG6 ------> QUADSPI_BK1_NCS
  302. PF7 ------> QUADSPI_BK1_IO2
  303. PB2 ------> QUADSPI_CLK
  304. PD13 ------> QUADSPI_BK1_IO3
  305. PD12 ------> QUADSPI_BK1_IO1
  306. PD11 ------> QUADSPI_BK1_IO0
  307. */
  308. GPIO_InitStruct.Pin = GPIO_PIN_6;
  309. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  310. GPIO_InitStruct.Pull = GPIO_NOPULL;
  311. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  312. GPIO_InitStruct.Alternate = GPIO_AF10_QUADSPI;
  313. HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
  314. GPIO_InitStruct.Pin = GPIO_PIN_7;
  315. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  316. GPIO_InitStruct.Pull = GPIO_NOPULL;
  317. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  318. GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI;
  319. HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
  320. GPIO_InitStruct.Pin = GPIO_PIN_2;
  321. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  322. GPIO_InitStruct.Pull = GPIO_NOPULL;
  323. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  324. GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI;
  325. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  326. GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_12|GPIO_PIN_11;
  327. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  328. GPIO_InitStruct.Pull = GPIO_NOPULL;
  329. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  330. GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI;
  331. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  332. /* USER CODE BEGIN QUADSPI_MspInit 1 */
  333. /* USER CODE END QUADSPI_MspInit 1 */
  334. }
  335. }
  336. /**
  337. * @brief QSPI MSP De-Initialization
  338. * This function freeze the hardware resources used in this example
  339. * @param hqspi: QSPI handle pointer
  340. * @retval None
  341. */
  342. void HAL_QSPI_MspDeInit(QSPI_HandleTypeDef* hqspi)
  343. {
  344. if(hqspi->Instance==QUADSPI)
  345. {
  346. /* USER CODE BEGIN QUADSPI_MspDeInit 0 */
  347. /* USER CODE END QUADSPI_MspDeInit 0 */
  348. /* Peripheral clock disable */
  349. __HAL_RCC_QSPI_CLK_DISABLE();
  350. /**QUADSPI GPIO Configuration
  351. PG6 ------> QUADSPI_BK1_NCS
  352. PF7 ------> QUADSPI_BK1_IO2
  353. PB2 ------> QUADSPI_CLK
  354. PD13 ------> QUADSPI_BK1_IO3
  355. PD12 ------> QUADSPI_BK1_IO1
  356. PD11 ------> QUADSPI_BK1_IO0
  357. */
  358. HAL_GPIO_DeInit(GPIOG, GPIO_PIN_6);
  359. HAL_GPIO_DeInit(GPIOF, GPIO_PIN_7);
  360. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_2);
  361. HAL_GPIO_DeInit(GPIOD, GPIO_PIN_13|GPIO_PIN_12|GPIO_PIN_11);
  362. /* USER CODE BEGIN QUADSPI_MspDeInit 1 */
  363. /* USER CODE END QUADSPI_MspDeInit 1 */
  364. }
  365. }
  366. /**
  367. * @brief RNG MSP Initialization
  368. * This function configures the hardware resources used in this example
  369. * @param hrng: RNG handle pointer
  370. * @retval None
  371. */
  372. void HAL_RNG_MspInit(RNG_HandleTypeDef* hrng)
  373. {
  374. if(hrng->Instance==RNG)
  375. {
  376. /* USER CODE BEGIN RNG_MspInit 0 */
  377. /* USER CODE END RNG_MspInit 0 */
  378. /* Peripheral clock enable */
  379. __HAL_RCC_RNG_CLK_ENABLE();
  380. /* USER CODE BEGIN RNG_MspInit 1 */
  381. /* USER CODE END RNG_MspInit 1 */
  382. }
  383. }
  384. /**
  385. * @brief RNG MSP De-Initialization
  386. * This function freeze the hardware resources used in this example
  387. * @param hrng: RNG handle pointer
  388. * @retval None
  389. */
  390. void HAL_RNG_MspDeInit(RNG_HandleTypeDef* hrng)
  391. {
  392. if(hrng->Instance==RNG)
  393. {
  394. /* USER CODE BEGIN RNG_MspDeInit 0 */
  395. /* USER CODE END RNG_MspDeInit 0 */
  396. /* Peripheral clock disable */
  397. __HAL_RCC_RNG_CLK_DISABLE();
  398. /* USER CODE BEGIN RNG_MspDeInit 1 */
  399. /* USER CODE END RNG_MspDeInit 1 */
  400. }
  401. }
  402. /**
  403. * @brief MMC MSP Initialization
  404. * This function configures the hardware resources used in this example
  405. * @param hmmc: MMC handle pointer
  406. * @retval None
  407. */
  408. void HAL_MMC_MspInit(MMC_HandleTypeDef* hmmc)
  409. {
  410. GPIO_InitTypeDef GPIO_InitStruct = {0};
  411. if(hmmc->Instance==SDMMC1)
  412. {
  413. /* USER CODE BEGIN SDMMC1_MspInit 0 */
  414. /* USER CODE END SDMMC1_MspInit 0 */
  415. /* Peripheral clock enable */
  416. __HAL_RCC_SDMMC1_CLK_ENABLE();
  417. __HAL_RCC_GPIOB_CLK_ENABLE();
  418. __HAL_RCC_GPIOC_CLK_ENABLE();
  419. __HAL_RCC_GPIOD_CLK_ENABLE();
  420. /**SDMMC1 GPIO Configuration
  421. PB8 ------> SDMMC1_D4
  422. PC12 ------> SDMMC1_CK
  423. PB9 ------> SDMMC1_D5
  424. PC11 ------> SDMMC1_D3
  425. PC10 ------> SDMMC1_D2
  426. PD2 ------> SDMMC1_CMD
  427. PC9 ------> SDMMC1_D1
  428. PC8 ------> SDMMC1_D0
  429. PC7 ------> SDMMC1_D7
  430. PC6 ------> SDMMC1_D6
  431. */
  432. GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
  433. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  434. GPIO_InitStruct.Pull = GPIO_NOPULL;
  435. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  436. GPIO_InitStruct.Alternate = GPIO_AF12_SDIO1;
  437. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  438. GPIO_InitStruct.Pin = GPIO_PIN_12|GPIO_PIN_11|GPIO_PIN_10|GPIO_PIN_9
  439. |GPIO_PIN_8|GPIO_PIN_7|GPIO_PIN_6;
  440. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  441. GPIO_InitStruct.Pull = GPIO_NOPULL;
  442. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  443. GPIO_InitStruct.Alternate = GPIO_AF12_SDIO1;
  444. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  445. GPIO_InitStruct.Pin = GPIO_PIN_2;
  446. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  447. GPIO_InitStruct.Pull = GPIO_NOPULL;
  448. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  449. GPIO_InitStruct.Alternate = GPIO_AF12_SDIO1;
  450. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  451. /* USER CODE BEGIN SDMMC1_MspInit 1 */
  452. /* USER CODE END SDMMC1_MspInit 1 */
  453. }
  454. }
  455. /**
  456. * @brief MMC MSP De-Initialization
  457. * This function freeze the hardware resources used in this example
  458. * @param hmmc: MMC handle pointer
  459. * @retval None
  460. */
  461. void HAL_MMC_MspDeInit(MMC_HandleTypeDef* hmmc)
  462. {
  463. if(hmmc->Instance==SDMMC1)
  464. {
  465. /* USER CODE BEGIN SDMMC1_MspDeInit 0 */
  466. /* USER CODE END SDMMC1_MspDeInit 0 */
  467. /* Peripheral clock disable */
  468. __HAL_RCC_SDMMC1_CLK_DISABLE();
  469. /**SDMMC1 GPIO Configuration
  470. PB8 ------> SDMMC1_D4
  471. PC12 ------> SDMMC1_CK
  472. PB9 ------> SDMMC1_D5
  473. PC11 ------> SDMMC1_D3
  474. PC10 ------> SDMMC1_D2
  475. PD2 ------> SDMMC1_CMD
  476. PC9 ------> SDMMC1_D1
  477. PC8 ------> SDMMC1_D0
  478. PC7 ------> SDMMC1_D7
  479. PC6 ------> SDMMC1_D6
  480. */
  481. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_8|GPIO_PIN_9);
  482. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_12|GPIO_PIN_11|GPIO_PIN_10|GPIO_PIN_9
  483. |GPIO_PIN_8|GPIO_PIN_7|GPIO_PIN_6);
  484. HAL_GPIO_DeInit(GPIOD, GPIO_PIN_2);
  485. /* USER CODE BEGIN SDMMC1_MspDeInit 1 */
  486. /* USER CODE END SDMMC1_MspDeInit 1 */
  487. }
  488. }
  489. /**
  490. * @brief TIM_Base MSP Initialization
  491. * This function configures the hardware resources used in this example
  492. * @param htim_base: TIM_Base handle pointer
  493. * @retval None
  494. */
  495. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
  496. {
  497. GPIO_InitTypeDef GPIO_InitStruct = {0};
  498. if(htim_base->Instance==TIM12)
  499. {
  500. /* USER CODE BEGIN TIM12_MspInit 0 */
  501. /* USER CODE END TIM12_MspInit 0 */
  502. /* Peripheral clock enable */
  503. __HAL_RCC_TIM12_CLK_ENABLE();
  504. __HAL_RCC_GPIOB_CLK_ENABLE();
  505. /**TIM12 GPIO Configuration
  506. PB14 ------> TIM12_CH1
  507. */
  508. GPIO_InitStruct.Pin = GPIO_PIN_14;
  509. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  510. GPIO_InitStruct.Pull = GPIO_NOPULL;
  511. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  512. GPIO_InitStruct.Alternate = GPIO_AF2_TIM12;
  513. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  514. /* USER CODE BEGIN TIM12_MspInit 1 */
  515. /* USER CODE END TIM12_MspInit 1 */
  516. }
  517. }
  518. void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
  519. {
  520. GPIO_InitTypeDef GPIO_InitStruct = {0};
  521. if(htim->Instance==TIM12)
  522. {
  523. /* USER CODE BEGIN TIM12_MspPostInit 0 */
  524. /* USER CODE END TIM12_MspPostInit 0 */
  525. __HAL_RCC_GPIOH_CLK_ENABLE();
  526. /**TIM12 GPIO Configuration
  527. PH9 ------> TIM12_CH2
  528. */
  529. GPIO_InitStruct.Pin = GPIO_PIN_9;
  530. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  531. GPIO_InitStruct.Pull = GPIO_NOPULL;
  532. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  533. GPIO_InitStruct.Alternate = GPIO_AF2_TIM12;
  534. HAL_GPIO_Init(GPIOH, &GPIO_InitStruct);
  535. /* USER CODE BEGIN TIM12_MspPostInit 1 */
  536. /* USER CODE END TIM12_MspPostInit 1 */
  537. }
  538. }
  539. /**
  540. * @brief TIM_Base MSP De-Initialization
  541. * This function freeze the hardware resources used in this example
  542. * @param htim_base: TIM_Base handle pointer
  543. * @retval None
  544. */
  545. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* htim_base)
  546. {
  547. if(htim_base->Instance==TIM12)
  548. {
  549. /* USER CODE BEGIN TIM12_MspDeInit 0 */
  550. /* USER CODE END TIM12_MspDeInit 0 */
  551. /* Peripheral clock disable */
  552. __HAL_RCC_TIM12_CLK_DISABLE();
  553. /**TIM12 GPIO Configuration
  554. PH9 ------> TIM12_CH2
  555. PB14 ------> TIM12_CH1
  556. */
  557. HAL_GPIO_DeInit(GPIOH, GPIO_PIN_9);
  558. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_14);
  559. /* USER CODE BEGIN TIM12_MspDeInit 1 */
  560. /* USER CODE END TIM12_MspDeInit 1 */
  561. }
  562. }
  563. /**
  564. * @brief UART MSP Initialization
  565. * This function configures the hardware resources used in this example
  566. * @param huart: UART handle pointer
  567. * @retval None
  568. */
  569. void HAL_UART_MspInit(UART_HandleTypeDef* huart)
  570. {
  571. GPIO_InitTypeDef GPIO_InitStruct = {0};
  572. if(huart->Instance==UART4)
  573. {
  574. /* USER CODE BEGIN UART4_MspInit 0 */
  575. /* USER CODE END UART4_MspInit 0 */
  576. /* Peripheral clock enable */
  577. __HAL_RCC_UART4_CLK_ENABLE();
  578. __HAL_RCC_GPIOH_CLK_ENABLE();
  579. /**UART4 GPIO Configuration
  580. PH13 ------> UART4_TX
  581. PH14 ------> UART4_RX
  582. */
  583. GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14;
  584. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  585. GPIO_InitStruct.Pull = GPIO_NOPULL;
  586. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  587. GPIO_InitStruct.Alternate = GPIO_AF8_UART4;
  588. HAL_GPIO_Init(GPIOH, &GPIO_InitStruct);
  589. /* USER CODE BEGIN UART4_MspInit 1 */
  590. /* USER CODE END UART4_MspInit 1 */
  591. }
  592. else if(huart->Instance==USART1)
  593. {
  594. /* USER CODE BEGIN USART1_MspInit 0 */
  595. /* USER CODE END USART1_MspInit 0 */
  596. /* Peripheral clock enable */
  597. __HAL_RCC_USART1_CLK_ENABLE();
  598. __HAL_RCC_GPIOA_CLK_ENABLE();
  599. /**USART1 GPIO Configuration
  600. PA10 ------> USART1_RX
  601. PA9 ------> USART1_TX
  602. */
  603. GPIO_InitStruct.Pin = GPIO_PIN_10|GPIO_PIN_9;
  604. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  605. GPIO_InitStruct.Pull = GPIO_NOPULL;
  606. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  607. GPIO_InitStruct.Alternate = GPIO_AF7_USART1;
  608. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  609. /* USER CODE BEGIN USART1_MspInit 1 */
  610. /* USER CODE END USART1_MspInit 1 */
  611. }
  612. }
  613. /**
  614. * @brief UART MSP De-Initialization
  615. * This function freeze the hardware resources used in this example
  616. * @param huart: UART handle pointer
  617. * @retval None
  618. */
  619. void HAL_UART_MspDeInit(UART_HandleTypeDef* huart)
  620. {
  621. if(huart->Instance==UART4)
  622. {
  623. /* USER CODE BEGIN UART4_MspDeInit 0 */
  624. /* USER CODE END UART4_MspDeInit 0 */
  625. /* Peripheral clock disable */
  626. __HAL_RCC_UART4_CLK_DISABLE();
  627. /**UART4 GPIO Configuration
  628. PH13 ------> UART4_TX
  629. PH14 ------> UART4_RX
  630. */
  631. HAL_GPIO_DeInit(GPIOH, GPIO_PIN_13|GPIO_PIN_14);
  632. /* USER CODE BEGIN UART4_MspDeInit 1 */
  633. /* USER CODE END UART4_MspDeInit 1 */
  634. }
  635. else if(huart->Instance==USART1)
  636. {
  637. /* USER CODE BEGIN USART1_MspDeInit 0 */
  638. /* USER CODE END USART1_MspDeInit 0 */
  639. /* Peripheral clock disable */
  640. __HAL_RCC_USART1_CLK_DISABLE();
  641. /**USART1 GPIO Configuration
  642. PA10 ------> USART1_RX
  643. PA9 ------> USART1_TX
  644. */
  645. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_10|GPIO_PIN_9);
  646. /* USER CODE BEGIN USART1_MspDeInit 1 */
  647. /* USER CODE END USART1_MspDeInit 1 */
  648. }
  649. }
  650. /**
  651. * @brief PCD MSP Initialization
  652. * This function configures the hardware resources used in this example
  653. * @param hpcd: PCD handle pointer
  654. * @retval None
  655. */
  656. void HAL_PCD_MspInit(PCD_HandleTypeDef* hpcd)
  657. {
  658. GPIO_InitTypeDef GPIO_InitStruct = {0};
  659. if(hpcd->Instance==USB_OTG_HS)
  660. {
  661. /* USER CODE BEGIN USB_OTG_HS_MspInit 0 */
  662. /* USER CODE END USB_OTG_HS_MspInit 0 */
  663. __HAL_RCC_GPIOB_CLK_ENABLE();
  664. __HAL_RCC_GPIOI_CLK_ENABLE();
  665. __HAL_RCC_GPIOH_CLK_ENABLE();
  666. __HAL_RCC_GPIOC_CLK_ENABLE();
  667. __HAL_RCC_GPIOA_CLK_ENABLE();
  668. /**USB_OTG_HS GPIO Configuration
  669. PB5 ------> USB_OTG_HS_ULPI_D7
  670. PI11 ------> USB_OTG_HS_ULPI_DIR
  671. PH4 ------> USB_OTG_HS_ULPI_NXT
  672. PC0 ------> USB_OTG_HS_ULPI_STP
  673. PA5 ------> USB_OTG_HS_ULPI_CK
  674. PB12 ------> USB_OTG_HS_ULPI_D5
  675. PB13 ------> USB_OTG_HS_ULPI_D6
  676. PA3 ------> USB_OTG_HS_ULPI_D0
  677. PB1 ------> USB_OTG_HS_ULPI_D2
  678. PB0 ------> USB_OTG_HS_ULPI_D1
  679. PB10 ------> USB_OTG_HS_ULPI_D3
  680. PB11 ------> USB_OTG_HS_ULPI_D4
  681. */
  682. GPIO_InitStruct.Pin = GPIO_PIN_5|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_1
  683. |GPIO_PIN_0|GPIO_PIN_10|GPIO_PIN_11;
  684. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  685. GPIO_InitStruct.Pull = GPIO_NOPULL;
  686. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  687. GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS;
  688. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  689. GPIO_InitStruct.Pin = GPIO_PIN_11;
  690. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  691. GPIO_InitStruct.Pull = GPIO_NOPULL;
  692. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  693. GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS;
  694. HAL_GPIO_Init(GPIOI, &GPIO_InitStruct);
  695. GPIO_InitStruct.Pin = GPIO_PIN_4;
  696. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  697. GPIO_InitStruct.Pull = GPIO_NOPULL;
  698. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  699. GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS;
  700. HAL_GPIO_Init(GPIOH, &GPIO_InitStruct);
  701. GPIO_InitStruct.Pin = GPIO_PIN_0;
  702. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  703. GPIO_InitStruct.Pull = GPIO_NOPULL;
  704. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  705. GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS;
  706. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  707. GPIO_InitStruct.Pin = GPIO_PIN_5|GPIO_PIN_3;
  708. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  709. GPIO_InitStruct.Pull = GPIO_NOPULL;
  710. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  711. GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS;
  712. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  713. /* Peripheral clock enable */
  714. __HAL_RCC_USB_OTG_HS_CLK_ENABLE();
  715. __HAL_RCC_USB_OTG_HS_ULPI_CLK_ENABLE();
  716. /* USB_OTG_HS interrupt Init */
  717. HAL_NVIC_SetPriority(OTG_HS_IRQn, 0, 0);
  718. HAL_NVIC_EnableIRQ(OTG_HS_IRQn);
  719. /* USER CODE BEGIN USB_OTG_HS_MspInit 1 */
  720. /* USER CODE END USB_OTG_HS_MspInit 1 */
  721. }
  722. }
  723. /**
  724. * @brief PCD MSP De-Initialization
  725. * This function freeze the hardware resources used in this example
  726. * @param hpcd: PCD handle pointer
  727. * @retval None
  728. */
  729. void HAL_PCD_MspDeInit(PCD_HandleTypeDef* hpcd)
  730. {
  731. if(hpcd->Instance==USB_OTG_HS)
  732. {
  733. /* USER CODE BEGIN USB_OTG_HS_MspDeInit 0 */
  734. /* USER CODE END USB_OTG_HS_MspDeInit 0 */
  735. /* Peripheral clock disable */
  736. __HAL_RCC_USB_OTG_HS_CLK_DISABLE();
  737. __HAL_RCC_USB_OTG_HS_ULPI_CLK_DISABLE();
  738. /**USB_OTG_HS GPIO Configuration
  739. PB5 ------> USB_OTG_HS_ULPI_D7
  740. PI11 ------> USB_OTG_HS_ULPI_DIR
  741. PH4 ------> USB_OTG_HS_ULPI_NXT
  742. PC0 ------> USB_OTG_HS_ULPI_STP
  743. PA5 ------> USB_OTG_HS_ULPI_CK
  744. PB12 ------> USB_OTG_HS_ULPI_D5
  745. PB13 ------> USB_OTG_HS_ULPI_D6
  746. PA3 ------> USB_OTG_HS_ULPI_D0
  747. PB1 ------> USB_OTG_HS_ULPI_D2
  748. PB0 ------> USB_OTG_HS_ULPI_D1
  749. PB10 ------> USB_OTG_HS_ULPI_D3
  750. PB11 ------> USB_OTG_HS_ULPI_D4
  751. */
  752. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_5|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_1
  753. |GPIO_PIN_0|GPIO_PIN_10|GPIO_PIN_11);
  754. HAL_GPIO_DeInit(GPIOI, GPIO_PIN_11);
  755. HAL_GPIO_DeInit(GPIOH, GPIO_PIN_4);
  756. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_0);
  757. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_5|GPIO_PIN_3);
  758. /* USB_OTG_HS interrupt DeInit */
  759. HAL_NVIC_DisableIRQ(OTG_HS_IRQn);
  760. /* USER CODE BEGIN USB_OTG_HS_MspDeInit 1 */
  761. /* USER CODE END USB_OTG_HS_MspDeInit 1 */
  762. }
  763. }
  764. /* USER CODE BEGIN 1 */
  765. /* USER CODE END 1 */
  766. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/