stm32f1xx_hal_msp.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * File Name : stm32f1xx_hal_msp.c
  5. * Description : This file provides code for the MSP Initialization
  6. * and de-Initialization codes.
  7. ******************************************************************************
  8. ** This notice applies to any and all portions of this file
  9. * that are not between comment pairs USER CODE BEGIN and
  10. * USER CODE END. Other portions of this file, whether
  11. * inserted by the user or by software development tools
  12. * are owned by their respective copyright owners.
  13. *
  14. * COPYRIGHT(c) 2018 STMicroelectronics
  15. *
  16. * Redistribution and use in source and binary forms, with or without modification,
  17. * are permitted provided that the following conditions are met:
  18. * 1. Redistributions of source code must retain the above copyright notice,
  19. * this list of conditions and the following disclaimer.
  20. * 2. Redistributions in binary form must reproduce the above copyright notice,
  21. * this list of conditions and the following disclaimer in the documentation
  22. * and/or other materials provided with the distribution.
  23. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  24. * may be used to endorse or promote products derived from this software
  25. * without specific prior written permission.
  26. *
  27. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  28. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  29. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  30. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  31. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  32. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  33. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  34. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  35. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  36. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  37. *
  38. ******************************************************************************
  39. */
  40. /* USER CODE END Header */
  41. /* Includes ------------------------------------------------------------------*/
  42. #include "main.h"
  43. /* USER CODE BEGIN Includes */
  44. #include <drv_common.h>
  45. /* USER CODE END Includes */
  46. /* Private typedef -----------------------------------------------------------*/
  47. /* USER CODE BEGIN TD */
  48. /* USER CODE END TD */
  49. /* Private define ------------------------------------------------------------*/
  50. /* USER CODE BEGIN Define */
  51. /* USER CODE END Define */
  52. /* Private macro -------------------------------------------------------------*/
  53. /* USER CODE BEGIN Macro */
  54. /* USER CODE END Macro */
  55. /* Private variables ---------------------------------------------------------*/
  56. /* USER CODE BEGIN PV */
  57. /* USER CODE END PV */
  58. /* Private function prototypes -----------------------------------------------*/
  59. /* USER CODE BEGIN PFP */
  60. /* USER CODE END PFP */
  61. /* External functions --------------------------------------------------------*/
  62. /* USER CODE BEGIN ExternalFunctions */
  63. /* USER CODE END ExternalFunctions */
  64. /* USER CODE BEGIN 0 */
  65. /* USER CODE END 0 */
  66. void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
  67. /**
  68. * Initializes the Global MSP.
  69. */
  70. void HAL_MspInit(void)
  71. {
  72. /* USER CODE BEGIN MspInit 0 */
  73. /* USER CODE END MspInit 0 */
  74. __HAL_RCC_AFIO_CLK_ENABLE();
  75. __HAL_RCC_PWR_CLK_ENABLE();
  76. /* System interrupt init*/
  77. /** NOJTAG: JTAG-DP Disabled and SW-DP Enabled
  78. */
  79. __HAL_AFIO_REMAP_SWJ_NOJTAG();
  80. /* USER CODE BEGIN MspInit 1 */
  81. /* USER CODE END MspInit 1 */
  82. }
  83. /**
  84. * @brief ADC MSP Initialization
  85. * This function configures the hardware resources used in this example
  86. * @param hadc: ADC handle pointer
  87. * @retval None
  88. */
  89. void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
  90. {
  91. GPIO_InitTypeDef GPIO_InitStruct = {0};
  92. if(hadc->Instance==ADC1)
  93. {
  94. /* USER CODE BEGIN ADC1_MspInit 0 */
  95. /* USER CODE END ADC1_MspInit 0 */
  96. /* Peripheral clock enable */
  97. __HAL_RCC_ADC1_CLK_ENABLE();
  98. __HAL_RCC_GPIOC_CLK_ENABLE();
  99. /**ADC1 GPIO Configuration
  100. PC1 ------> ADC1_IN11
  101. */
  102. GPIO_InitStruct.Pin = GPIO_PIN_1;
  103. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  104. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  105. /* USER CODE BEGIN ADC1_MspInit 1 */
  106. /* USER CODE END ADC1_MspInit 1 */
  107. }
  108. }
  109. /**
  110. * @brief ADC MSP De-Initialization
  111. * This function freeze the hardware resources used in this example
  112. * @param hadc: ADC handle pointer
  113. * @retval None
  114. */
  115. void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc)
  116. {
  117. if(hadc->Instance==ADC1)
  118. {
  119. /* USER CODE BEGIN ADC1_MspDeInit 0 */
  120. /* USER CODE END ADC1_MspDeInit 0 */
  121. /* Peripheral clock disable */
  122. __HAL_RCC_ADC1_CLK_DISABLE();
  123. /**ADC1 GPIO Configuration
  124. PC1 ------> ADC1_IN11
  125. */
  126. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_1);
  127. /* USER CODE BEGIN ADC1_MspDeInit 1 */
  128. /* USER CODE END ADC1_MspDeInit 1 */
  129. }
  130. }
  131. /**
  132. * @brief CAN MSP Initialization
  133. * This function configures the hardware resources used in this example
  134. * @param hcan: CAN handle pointer
  135. * @retval None
  136. */
  137. void HAL_CAN_MspInit(CAN_HandleTypeDef* hcan)
  138. {
  139. GPIO_InitTypeDef GPIO_InitStruct = {0};
  140. if(hcan->Instance==CAN1)
  141. {
  142. /* USER CODE BEGIN CAN1_MspInit 0 */
  143. /* USER CODE END CAN1_MspInit 0 */
  144. /* Peripheral clock enable */
  145. __HAL_RCC_CAN1_CLK_ENABLE();
  146. __HAL_RCC_GPIOB_CLK_ENABLE();
  147. /**CAN GPIO Configuration
  148. PB8 ------> CAN_RX
  149. PB9 ------> CAN_TX
  150. */
  151. GPIO_InitStruct.Pin = GPIO_PIN_8;
  152. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  153. GPIO_InitStruct.Pull = GPIO_NOPULL;
  154. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  155. GPIO_InitStruct.Pin = GPIO_PIN_9;
  156. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  157. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  158. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  159. __HAL_AFIO_REMAP_CAN1_2();
  160. /* USER CODE BEGIN CAN1_MspInit 1 */
  161. /* USER CODE END CAN1_MspInit 1 */
  162. }
  163. }
  164. /**
  165. * @brief CAN MSP De-Initialization
  166. * This function freeze the hardware resources used in this example
  167. * @param hcan: CAN handle pointer
  168. * @retval None
  169. */
  170. void HAL_CAN_MspDeInit(CAN_HandleTypeDef* hcan)
  171. {
  172. if(hcan->Instance==CAN1)
  173. {
  174. /* USER CODE BEGIN CAN1_MspDeInit 0 */
  175. /* USER CODE END CAN1_MspDeInit 0 */
  176. /* Peripheral clock disable */
  177. __HAL_RCC_CAN1_CLK_DISABLE();
  178. /**CAN GPIO Configuration
  179. PB8 ------> CAN_RX
  180. PB9 ------> CAN_TX
  181. */
  182. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_8|GPIO_PIN_9);
  183. /* USER CODE BEGIN CAN1_MspDeInit 1 */
  184. /* USER CODE END CAN1_MspDeInit 1 */
  185. }
  186. }
  187. /**
  188. * @brief RTC MSP Initialization
  189. * This function configures the hardware resources used in this example
  190. * @param hrtc: RTC handle pointer
  191. * @retval None
  192. */
  193. void HAL_RTC_MspInit(RTC_HandleTypeDef* hrtc)
  194. {
  195. if(hrtc->Instance==RTC)
  196. {
  197. /* USER CODE BEGIN RTC_MspInit 0 */
  198. /* USER CODE END RTC_MspInit 0 */
  199. HAL_PWR_EnableBkUpAccess();
  200. /* Enable BKP CLK enable for backup registers */
  201. __HAL_RCC_BKP_CLK_ENABLE();
  202. /* Peripheral clock enable */
  203. __HAL_RCC_RTC_ENABLE();
  204. /* USER CODE BEGIN RTC_MspInit 1 */
  205. /* USER CODE END RTC_MspInit 1 */
  206. }
  207. }
  208. /**
  209. * @brief RTC MSP De-Initialization
  210. * This function freeze the hardware resources used in this example
  211. * @param hrtc: RTC handle pointer
  212. * @retval None
  213. */
  214. void HAL_RTC_MspDeInit(RTC_HandleTypeDef* hrtc)
  215. {
  216. if(hrtc->Instance==RTC)
  217. {
  218. /* USER CODE BEGIN RTC_MspDeInit 0 */
  219. /* USER CODE END RTC_MspDeInit 0 */
  220. /* Peripheral clock disable */
  221. __HAL_RCC_RTC_DISABLE();
  222. /* USER CODE BEGIN RTC_MspDeInit 1 */
  223. /* USER CODE END RTC_MspDeInit 1 */
  224. }
  225. }
  226. /**
  227. * @brief SD MSP Initialization
  228. * This function configures the hardware resources used in this example
  229. * @param hsd: SD handle pointer
  230. * @retval None
  231. */
  232. void HAL_SD_MspInit(SD_HandleTypeDef* hsd)
  233. {
  234. GPIO_InitTypeDef GPIO_InitStruct = {0};
  235. if(hsd->Instance==SDIO)
  236. {
  237. /* USER CODE BEGIN SDIO_MspInit 0 */
  238. /* USER CODE END SDIO_MspInit 0 */
  239. /* Peripheral clock enable */
  240. __HAL_RCC_SDIO_CLK_ENABLE();
  241. __HAL_RCC_GPIOC_CLK_ENABLE();
  242. __HAL_RCC_GPIOD_CLK_ENABLE();
  243. /**SDIO GPIO Configuration
  244. PC8 ------> SDIO_D0
  245. PC9 ------> SDIO_D1
  246. PC10 ------> SDIO_D2
  247. PC11 ------> SDIO_D3
  248. PC12 ------> SDIO_CK
  249. PD2 ------> SDIO_CMD
  250. */
  251. GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10|GPIO_PIN_11
  252. |GPIO_PIN_12;
  253. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  254. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  255. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  256. GPIO_InitStruct.Pin = GPIO_PIN_2;
  257. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  258. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  259. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  260. /* USER CODE BEGIN SDIO_MspInit 1 */
  261. /* USER CODE END SDIO_MspInit 1 */
  262. }
  263. }
  264. /**
  265. * @brief SD MSP De-Initialization
  266. * This function freeze the hardware resources used in this example
  267. * @param hsd: SD handle pointer
  268. * @retval None
  269. */
  270. void HAL_SD_MspDeInit(SD_HandleTypeDef* hsd)
  271. {
  272. if(hsd->Instance==SDIO)
  273. {
  274. /* USER CODE BEGIN SDIO_MspDeInit 0 */
  275. /* USER CODE END SDIO_MspDeInit 0 */
  276. /* Peripheral clock disable */
  277. __HAL_RCC_SDIO_CLK_DISABLE();
  278. /**SDIO GPIO Configuration
  279. PC8 ------> SDIO_D0
  280. PC9 ------> SDIO_D1
  281. PC10 ------> SDIO_D2
  282. PC11 ------> SDIO_D3
  283. PC12 ------> SDIO_CK
  284. PD2 ------> SDIO_CMD
  285. */
  286. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10|GPIO_PIN_11
  287. |GPIO_PIN_12);
  288. HAL_GPIO_DeInit(GPIOD, GPIO_PIN_2);
  289. /* USER CODE BEGIN SDIO_MspDeInit 1 */
  290. /* USER CODE END SDIO_MspDeInit 1 */
  291. }
  292. }
  293. /**
  294. * @brief SPI MSP Initialization
  295. * This function configures the hardware resources used in this example
  296. * @param hspi: SPI handle pointer
  297. * @retval None
  298. */
  299. void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi)
  300. {
  301. GPIO_InitTypeDef GPIO_InitStruct = {0};
  302. if(hspi->Instance==SPI1)
  303. {
  304. /* USER CODE BEGIN SPI1_MspInit 0 */
  305. /* USER CODE END SPI1_MspInit 0 */
  306. /* Peripheral clock enable */
  307. __HAL_RCC_SPI1_CLK_ENABLE();
  308. __HAL_RCC_GPIOA_CLK_ENABLE();
  309. /**SPI1 GPIO Configuration
  310. PA5 ------> SPI1_SCK
  311. PA6 ------> SPI1_MISO
  312. PA7 ------> SPI1_MOSI
  313. */
  314. GPIO_InitStruct.Pin = GPIO_PIN_5|GPIO_PIN_7;
  315. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  316. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  317. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  318. GPIO_InitStruct.Pin = GPIO_PIN_6;
  319. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  320. GPIO_InitStruct.Pull = GPIO_NOPULL;
  321. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  322. /* USER CODE BEGIN SPI1_MspInit 1 */
  323. /* USER CODE END SPI1_MspInit 1 */
  324. }
  325. else if(hspi->Instance==SPI2)
  326. {
  327. /* USER CODE BEGIN SPI2_MspInit 0 */
  328. /* USER CODE END SPI2_MspInit 0 */
  329. /* Peripheral clock enable */
  330. __HAL_RCC_SPI2_CLK_ENABLE();
  331. __HAL_RCC_GPIOB_CLK_ENABLE();
  332. /**SPI2 GPIO Configuration
  333. PB13 ------> SPI2_SCK
  334. PB14 ------> SPI2_MISO
  335. PB15 ------> SPI2_MOSI
  336. */
  337. GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_15;
  338. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  339. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  340. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  341. GPIO_InitStruct.Pin = GPIO_PIN_14;
  342. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  343. GPIO_InitStruct.Pull = GPIO_NOPULL;
  344. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  345. /* USER CODE BEGIN SPI2_MspInit 1 */
  346. /* USER CODE END SPI2_MspInit 1 */
  347. }
  348. }
  349. /**
  350. * @brief SPI MSP De-Initialization
  351. * This function freeze the hardware resources used in this example
  352. * @param hspi: SPI handle pointer
  353. * @retval None
  354. */
  355. void HAL_SPI_MspDeInit(SPI_HandleTypeDef* hspi)
  356. {
  357. if(hspi->Instance==SPI1)
  358. {
  359. /* USER CODE BEGIN SPI1_MspDeInit 0 */
  360. /* USER CODE END SPI1_MspDeInit 0 */
  361. /* Peripheral clock disable */
  362. __HAL_RCC_SPI1_CLK_DISABLE();
  363. /**SPI1 GPIO Configuration
  364. PA5 ------> SPI1_SCK
  365. PA6 ------> SPI1_MISO
  366. PA7 ------> SPI1_MOSI
  367. */
  368. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_5|GPIO_PIN_6|GPIO_PIN_7);
  369. /* USER CODE BEGIN SPI1_MspDeInit 1 */
  370. /* USER CODE END SPI1_MspDeInit 1 */
  371. }
  372. else if(hspi->Instance==SPI2)
  373. {
  374. /* USER CODE BEGIN SPI2_MspDeInit 0 */
  375. /* USER CODE END SPI2_MspDeInit 0 */
  376. /* Peripheral clock disable */
  377. __HAL_RCC_SPI2_CLK_DISABLE();
  378. /**SPI2 GPIO Configuration
  379. PB13 ------> SPI2_SCK
  380. PB14 ------> SPI2_MISO
  381. PB15 ------> SPI2_MOSI
  382. */
  383. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15);
  384. /* USER CODE BEGIN SPI2_MspDeInit 1 */
  385. /* USER CODE END SPI2_MspDeInit 1 */
  386. }
  387. }
  388. /**
  389. * @brief TIM_Base MSP Initialization
  390. * This function configures the hardware resources used in this example
  391. * @param htim_base: TIM_Base handle pointer
  392. * @retval None
  393. */
  394. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
  395. {
  396. if(htim_base->Instance==TIM2)
  397. {
  398. /* USER CODE BEGIN TIM2_MspInit 0 */
  399. /* USER CODE END TIM2_MspInit 0 */
  400. /* Peripheral clock enable */
  401. __HAL_RCC_TIM2_CLK_ENABLE();
  402. /* USER CODE BEGIN TIM2_MspInit 1 */
  403. /* USER CODE END TIM2_MspInit 1 */
  404. }
  405. else if(htim_base->Instance==TIM3)
  406. {
  407. /* USER CODE BEGIN TIM3_MspInit 0 */
  408. /* USER CODE END TIM3_MspInit 0 */
  409. /* Peripheral clock enable */
  410. __HAL_RCC_TIM3_CLK_ENABLE();
  411. /* USER CODE BEGIN TIM3_MspInit 1 */
  412. /* USER CODE END TIM3_MspInit 1 */
  413. }
  414. else if(htim_base->Instance==TIM4)
  415. {
  416. /* USER CODE BEGIN TIM4_MspInit 0 */
  417. /* USER CODE END TIM4_MspInit 0 */
  418. /* Peripheral clock enable */
  419. __HAL_RCC_TIM4_CLK_ENABLE();
  420. /* USER CODE BEGIN TIM4_MspInit 1 */
  421. /* USER CODE END TIM4_MspInit 1 */
  422. }
  423. else if(htim_base->Instance==TIM5)
  424. {
  425. /* USER CODE BEGIN TIM5_MspInit 0 */
  426. /* USER CODE END TIM5_MspInit 0 */
  427. /* Peripheral clock enable */
  428. __HAL_RCC_TIM5_CLK_ENABLE();
  429. /* USER CODE BEGIN TIM5_MspInit 1 */
  430. /* USER CODE END TIM5_MspInit 1 */
  431. }
  432. }
  433. void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
  434. {
  435. GPIO_InitTypeDef GPIO_InitStruct = {0};
  436. if(htim->Instance==TIM3)
  437. {
  438. /* USER CODE BEGIN TIM3_MspPostInit 0 */
  439. /* USER CODE END TIM3_MspPostInit 0 */
  440. __HAL_RCC_GPIOB_CLK_ENABLE();
  441. /**TIM3 GPIO Configuration
  442. PB0 ------> TIM3_CH3
  443. PB1 ------> TIM3_CH4
  444. PB5 ------> TIM3_CH2
  445. */
  446. GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_5;
  447. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  448. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  449. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  450. __HAL_AFIO_REMAP_TIM3_PARTIAL();
  451. /* USER CODE BEGIN TIM3_MspPostInit 1 */
  452. /* USER CODE END TIM3_MspPostInit 1 */
  453. }
  454. }
  455. /**
  456. * @brief TIM_Base MSP De-Initialization
  457. * This function freeze the hardware resources used in this example
  458. * @param htim_base: TIM_Base handle pointer
  459. * @retval None
  460. */
  461. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* htim_base)
  462. {
  463. if(htim_base->Instance==TIM2)
  464. {
  465. /* USER CODE BEGIN TIM2_MspDeInit 0 */
  466. /* USER CODE END TIM2_MspDeInit 0 */
  467. /* Peripheral clock disable */
  468. __HAL_RCC_TIM2_CLK_DISABLE();
  469. /* USER CODE BEGIN TIM2_MspDeInit 1 */
  470. /* USER CODE END TIM2_MspDeInit 1 */
  471. }
  472. else if(htim_base->Instance==TIM3)
  473. {
  474. /* USER CODE BEGIN TIM3_MspDeInit 0 */
  475. /* USER CODE END TIM3_MspDeInit 0 */
  476. /* Peripheral clock disable */
  477. __HAL_RCC_TIM3_CLK_DISABLE();
  478. /* USER CODE BEGIN TIM3_MspDeInit 1 */
  479. /* USER CODE END TIM3_MspDeInit 1 */
  480. }
  481. else if(htim_base->Instance==TIM4)
  482. {
  483. /* USER CODE BEGIN TIM4_MspDeInit 0 */
  484. /* USER CODE END TIM4_MspDeInit 0 */
  485. /* Peripheral clock disable */
  486. __HAL_RCC_TIM4_CLK_DISABLE();
  487. /* USER CODE BEGIN TIM4_MspDeInit 1 */
  488. /* USER CODE END TIM4_MspDeInit 1 */
  489. }
  490. else if(htim_base->Instance==TIM5)
  491. {
  492. /* USER CODE BEGIN TIM5_MspDeInit 0 */
  493. /* USER CODE END TIM5_MspDeInit 0 */
  494. /* Peripheral clock disable */
  495. __HAL_RCC_TIM5_CLK_DISABLE();
  496. /* USER CODE BEGIN TIM5_MspDeInit 1 */
  497. /* USER CODE END TIM5_MspDeInit 1 */
  498. }
  499. }
  500. /**
  501. * @brief UART MSP Initialization
  502. * This function configures the hardware resources used in this example
  503. * @param huart: UART handle pointer
  504. * @retval None
  505. */
  506. void HAL_UART_MspInit(UART_HandleTypeDef* huart)
  507. {
  508. GPIO_InitTypeDef GPIO_InitStruct = {0};
  509. if(huart->Instance==USART1)
  510. {
  511. /* USER CODE BEGIN USART1_MspInit 0 */
  512. /* USER CODE END USART1_MspInit 0 */
  513. /* Peripheral clock enable */
  514. __HAL_RCC_USART1_CLK_ENABLE();
  515. __HAL_RCC_GPIOA_CLK_ENABLE();
  516. /**USART1 GPIO Configuration
  517. PA9 ------> USART1_TX
  518. PA10 ------> USART1_RX
  519. */
  520. GPIO_InitStruct.Pin = GPIO_PIN_9;
  521. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  522. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  523. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  524. GPIO_InitStruct.Pin = GPIO_PIN_10;
  525. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  526. GPIO_InitStruct.Pull = GPIO_NOPULL;
  527. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  528. /* USART1 interrupt Init */
  529. HAL_NVIC_SetPriority(USART1_IRQn, 0, 0);
  530. HAL_NVIC_EnableIRQ(USART1_IRQn);
  531. /* USER CODE BEGIN USART1_MspInit 1 */
  532. /* USER CODE END USART1_MspInit 1 */
  533. }
  534. else if(huart->Instance==USART2)
  535. {
  536. /* USER CODE BEGIN USART2_MspInit 0 */
  537. /* USER CODE END USART2_MspInit 0 */
  538. /* Peripheral clock enable */
  539. __HAL_RCC_USART2_CLK_ENABLE();
  540. __HAL_RCC_GPIOA_CLK_ENABLE();
  541. /**USART2 GPIO Configuration
  542. PA2 ------> USART2_TX
  543. PA3 ------> USART2_RX
  544. */
  545. GPIO_InitStruct.Pin = GPIO_PIN_2;
  546. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  547. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  548. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  549. GPIO_InitStruct.Pin = GPIO_PIN_3;
  550. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  551. GPIO_InitStruct.Pull = GPIO_NOPULL;
  552. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  553. /* USER CODE BEGIN USART2_MspInit 1 */
  554. /* USER CODE END USART2_MspInit 1 */
  555. }
  556. else if(huart->Instance==USART3)
  557. {
  558. /* USER CODE BEGIN USART3_MspInit 0 */
  559. /* USER CODE END USART3_MspInit 0 */
  560. /* Peripheral clock enable */
  561. __HAL_RCC_USART3_CLK_ENABLE();
  562. __HAL_RCC_GPIOB_CLK_ENABLE();
  563. /**USART3 GPIO Configuration
  564. PB10 ------> USART3_TX
  565. PB11 ------> USART3_RX
  566. */
  567. GPIO_InitStruct.Pin = GPIO_PIN_10;
  568. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  569. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  570. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  571. GPIO_InitStruct.Pin = GPIO_PIN_11;
  572. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  573. GPIO_InitStruct.Pull = GPIO_NOPULL;
  574. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  575. /* USER CODE BEGIN USART3_MspInit 1 */
  576. /* USER CODE END USART3_MspInit 1 */
  577. }
  578. }
  579. /**
  580. * @brief UART MSP De-Initialization
  581. * This function freeze the hardware resources used in this example
  582. * @param huart: UART handle pointer
  583. * @retval None
  584. */
  585. void HAL_UART_MspDeInit(UART_HandleTypeDef* huart)
  586. {
  587. if(huart->Instance==USART1)
  588. {
  589. /* USER CODE BEGIN USART1_MspDeInit 0 */
  590. /* USER CODE END USART1_MspDeInit 0 */
  591. /* Peripheral clock disable */
  592. __HAL_RCC_USART1_CLK_DISABLE();
  593. /**USART1 GPIO Configuration
  594. PA9 ------> USART1_TX
  595. PA10 ------> USART1_RX
  596. */
  597. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
  598. /* USART1 interrupt DeInit */
  599. HAL_NVIC_DisableIRQ(USART1_IRQn);
  600. /* USER CODE BEGIN USART1_MspDeInit 1 */
  601. /* USER CODE END USART1_MspDeInit 1 */
  602. }
  603. else if(huart->Instance==USART2)
  604. {
  605. /* USER CODE BEGIN USART2_MspDeInit 0 */
  606. /* USER CODE END USART2_MspDeInit 0 */
  607. /* Peripheral clock disable */
  608. __HAL_RCC_USART2_CLK_DISABLE();
  609. /**USART2 GPIO Configuration
  610. PA2 ------> USART2_TX
  611. PA3 ------> USART2_RX
  612. */
  613. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_2|GPIO_PIN_3);
  614. /* USER CODE BEGIN USART2_MspDeInit 1 */
  615. /* USER CODE END USART2_MspDeInit 1 */
  616. }
  617. else if(huart->Instance==USART3)
  618. {
  619. /* USER CODE BEGIN USART3_MspDeInit 0 */
  620. /* USER CODE END USART3_MspDeInit 0 */
  621. /* Peripheral clock disable */
  622. __HAL_RCC_USART3_CLK_DISABLE();
  623. /**USART3 GPIO Configuration
  624. PB10 ------> USART3_TX
  625. PB11 ------> USART3_RX
  626. */
  627. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_10|GPIO_PIN_11);
  628. /* USER CODE BEGIN USART3_MspDeInit 1 */
  629. /* USER CODE END USART3_MspDeInit 1 */
  630. }
  631. }
  632. /**
  633. * @brief PCD MSP Initialization
  634. * This function configures the hardware resources used in this example
  635. * @param hpcd: PCD handle pointer
  636. * @retval None
  637. */
  638. void HAL_PCD_MspInit(PCD_HandleTypeDef* hpcd)
  639. {
  640. if(hpcd->Instance==USB)
  641. {
  642. /* USER CODE BEGIN USB_MspInit 0 */
  643. /* USER CODE END USB_MspInit 0 */
  644. /* Peripheral clock enable */
  645. __HAL_RCC_USB_CLK_ENABLE();
  646. /* USER CODE BEGIN USB_MspInit 1 */
  647. /* USER CODE END USB_MspInit 1 */
  648. }
  649. }
  650. /**
  651. * @brief PCD MSP De-Initialization
  652. * This function freeze the hardware resources used in this example
  653. * @param hpcd: PCD handle pointer
  654. * @retval None
  655. */
  656. void HAL_PCD_MspDeInit(PCD_HandleTypeDef* hpcd)
  657. {
  658. if(hpcd->Instance==USB)
  659. {
  660. /* USER CODE BEGIN USB_MspDeInit 0 */
  661. /* USER CODE END USB_MspDeInit 0 */
  662. /* Peripheral clock disable */
  663. __HAL_RCC_USB_CLK_DISABLE();
  664. /* USER CODE BEGIN USB_MspDeInit 1 */
  665. /* USER CODE END USB_MspDeInit 1 */
  666. }
  667. }
  668. static uint32_t FSMC_Initialized = 0;
  669. static void HAL_FSMC_MspInit(void){
  670. /* USER CODE BEGIN FSMC_MspInit 0 */
  671. /* USER CODE END FSMC_MspInit 0 */
  672. GPIO_InitTypeDef GPIO_InitStruct ={0};
  673. if (FSMC_Initialized) {
  674. return;
  675. }
  676. FSMC_Initialized = 1;
  677. /* Peripheral clock enable */
  678. __HAL_RCC_FSMC_CLK_ENABLE();
  679. /** FSMC GPIO Configuration
  680. PE7 ------> FSMC_D4
  681. PE8 ------> FSMC_D5
  682. PE9 ------> FSMC_D6
  683. PE10 ------> FSMC_D7
  684. PD11 ------> FSMC_CLE
  685. PD12 ------> FSMC_ALE
  686. PD14 ------> FSMC_D0
  687. PD15 ------> FSMC_D1
  688. PD0 ------> FSMC_D2
  689. PD1 ------> FSMC_D3
  690. PD4 ------> FSMC_NOE
  691. PD5 ------> FSMC_NWE
  692. PD6 ------> FSMC_NWAIT
  693. PD7 ------> FSMC_NCE2
  694. */
  695. GPIO_InitStruct.Pin = GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10;
  696. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  697. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  698. HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
  699. GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_14|GPIO_PIN_15
  700. |GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5
  701. |GPIO_PIN_7;
  702. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  703. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  704. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  705. GPIO_InitStruct.Pin = GPIO_PIN_6;
  706. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  707. GPIO_InitStruct.Pull = GPIO_NOPULL;
  708. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  709. /* USER CODE BEGIN FSMC_MspInit 1 */
  710. /* USER CODE END FSMC_MspInit 1 */
  711. }
  712. void HAL_NAND_MspInit(NAND_HandleTypeDef* hnand){
  713. /* USER CODE BEGIN NAND_MspInit 0 */
  714. /* USER CODE END NAND_MspInit 0 */
  715. HAL_FSMC_MspInit();
  716. /* USER CODE BEGIN NAND_MspInit 1 */
  717. /* USER CODE END NAND_MspInit 1 */
  718. }
  719. static uint32_t FSMC_DeInitialized = 0;
  720. static void HAL_FSMC_MspDeInit(void){
  721. /* USER CODE BEGIN FSMC_MspDeInit 0 */
  722. /* USER CODE END FSMC_MspDeInit 0 */
  723. if (FSMC_DeInitialized) {
  724. return;
  725. }
  726. FSMC_DeInitialized = 1;
  727. /* Peripheral clock enable */
  728. __HAL_RCC_FSMC_CLK_DISABLE();
  729. /** FSMC GPIO Configuration
  730. PE7 ------> FSMC_D4
  731. PE8 ------> FSMC_D5
  732. PE9 ------> FSMC_D6
  733. PE10 ------> FSMC_D7
  734. PD11 ------> FSMC_CLE
  735. PD12 ------> FSMC_ALE
  736. PD14 ------> FSMC_D0
  737. PD15 ------> FSMC_D1
  738. PD0 ------> FSMC_D2
  739. PD1 ------> FSMC_D3
  740. PD4 ------> FSMC_NOE
  741. PD5 ------> FSMC_NWE
  742. PD6 ------> FSMC_NWAIT
  743. PD7 ------> FSMC_NCE2
  744. */
  745. HAL_GPIO_DeInit(GPIOE, GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10);
  746. HAL_GPIO_DeInit(GPIOD, GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_14|GPIO_PIN_15
  747. |GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5
  748. |GPIO_PIN_6|GPIO_PIN_7);
  749. /* USER CODE BEGIN FSMC_MspDeInit 1 */
  750. /* USER CODE END FSMC_MspDeInit 1 */
  751. }
  752. void HAL_NAND_MspDeInit(NAND_HandleTypeDef* hnand){
  753. /* USER CODE BEGIN NAND_MspDeInit 0 */
  754. /* USER CODE END NAND_MspDeInit 0 */
  755. HAL_FSMC_MspDeInit();
  756. /* USER CODE BEGIN NAND_MspDeInit 1 */
  757. /* USER CODE END NAND_MspDeInit 1 */
  758. }
  759. /* USER CODE BEGIN 1 */
  760. /* USER CODE END 1 */