stm32f1xx_hal_msp.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557
  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. * @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. extern DMA_HandleTypeDef hdma_adc1;
  26. extern DMA_HandleTypeDef hdma_usart1_rx;
  27. extern DMA_HandleTypeDef hdma_usart1_tx;
  28. extern DMA_HandleTypeDef hdma_usart2_rx;
  29. extern DMA_HandleTypeDef hdma_usart2_tx;
  30. /* Private typedef -----------------------------------------------------------*/
  31. /* USER CODE BEGIN TD */
  32. /* USER CODE END TD */
  33. /* Private define ------------------------------------------------------------*/
  34. /* USER CODE BEGIN Define */
  35. /* USER CODE END Define */
  36. /* Private macro -------------------------------------------------------------*/
  37. /* USER CODE BEGIN Macro */
  38. /* USER CODE END Macro */
  39. /* Private variables ---------------------------------------------------------*/
  40. /* USER CODE BEGIN PV */
  41. /* USER CODE END PV */
  42. /* Private function prototypes -----------------------------------------------*/
  43. /* USER CODE BEGIN PFP */
  44. /* USER CODE END PFP */
  45. /* External functions --------------------------------------------------------*/
  46. /* USER CODE BEGIN ExternalFunctions */
  47. /* USER CODE END ExternalFunctions */
  48. /* USER CODE BEGIN 0 */
  49. /* USER CODE END 0 */
  50. /**
  51. * Initializes the Global MSP.
  52. */
  53. void HAL_MspInit(void)
  54. {
  55. /* USER CODE BEGIN MspInit 0 */
  56. /* USER CODE END MspInit 0 */
  57. __HAL_RCC_AFIO_CLK_ENABLE();
  58. __HAL_RCC_PWR_CLK_ENABLE();
  59. /* System interrupt init*/
  60. /** DISABLE: JTAG-DP Disabled and SW-DP Disabled
  61. */
  62. __HAL_AFIO_REMAP_SWJ_DISABLE();
  63. /* USER CODE BEGIN MspInit 1 */
  64. /* USER CODE END MspInit 1 */
  65. }
  66. /**
  67. * @brief ADC MSP Initialization
  68. * This function configures the hardware resources used in this example
  69. * @param hadc: ADC handle pointer
  70. * @retval None
  71. */
  72. void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
  73. {
  74. GPIO_InitTypeDef GPIO_InitStruct = {0};
  75. if(hadc->Instance==ADC1)
  76. {
  77. /* USER CODE BEGIN ADC1_MspInit 0 */
  78. /* USER CODE END ADC1_MspInit 0 */
  79. /* Peripheral clock enable */
  80. __HAL_RCC_ADC1_CLK_ENABLE();
  81. __HAL_RCC_GPIOB_CLK_ENABLE();
  82. /**ADC1 GPIO Configuration
  83. PB1 ------> ADC1_IN9
  84. */
  85. GPIO_InitStruct.Pin = RFU_TEMP_Pin;
  86. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  87. HAL_GPIO_Init(RFU_TEMP_GPIO_Port, &GPIO_InitStruct);
  88. /* ADC1 DMA Init */
  89. /* ADC1 Init */
  90. hdma_adc1.Instance = DMA1_Channel1;
  91. hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
  92. hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
  93. hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
  94. hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_WORD;
  95. hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
  96. hdma_adc1.Init.Mode = DMA_CIRCULAR;
  97. hdma_adc1.Init.Priority = DMA_PRIORITY_LOW;
  98. if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
  99. {
  100. Error_Handler();
  101. }
  102. __HAL_LINKDMA(hadc,DMA_Handle,hdma_adc1);
  103. /* USER CODE BEGIN ADC1_MspInit 1 */
  104. /* USER CODE END ADC1_MspInit 1 */
  105. }
  106. else if(hadc->Instance==ADC2)
  107. {
  108. /* USER CODE BEGIN ADC2_MspInit 0 */
  109. /* USER CODE END ADC2_MspInit 0 */
  110. /* Peripheral clock enable */
  111. __HAL_RCC_ADC2_CLK_ENABLE();
  112. __HAL_RCC_GPIOC_CLK_ENABLE();
  113. /**ADC2 GPIO Configuration
  114. PC0 ------> ADC2_IN10
  115. */
  116. GPIO_InitStruct.Pin = DET_OUT_B_Pin;
  117. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  118. HAL_GPIO_Init(DET_OUT_B_GPIO_Port, &GPIO_InitStruct);
  119. /* USER CODE BEGIN ADC2_MspInit 1 */
  120. /* USER CODE END ADC2_MspInit 1 */
  121. }
  122. else if(hadc->Instance==ADC3)
  123. {
  124. /* USER CODE BEGIN ADC3_MspInit 0 */
  125. /* USER CODE END ADC3_MspInit 0 */
  126. /* Peripheral clock enable */
  127. __HAL_RCC_ADC3_CLK_ENABLE();
  128. __HAL_RCC_GPIOC_CLK_ENABLE();
  129. /**ADC3 GPIO Configuration
  130. PC1 ------> ADC3_IN11
  131. */
  132. GPIO_InitStruct.Pin = EXT_DET_B_Pin;
  133. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  134. HAL_GPIO_Init(EXT_DET_B_GPIO_Port, &GPIO_InitStruct);
  135. /* USER CODE BEGIN ADC3_MspInit 1 */
  136. /* USER CODE END ADC3_MspInit 1 */
  137. }
  138. }
  139. /**
  140. * @brief ADC MSP De-Initialization
  141. * This function freeze the hardware resources used in this example
  142. * @param hadc: ADC handle pointer
  143. * @retval None
  144. */
  145. void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc)
  146. {
  147. if(hadc->Instance==ADC1)
  148. {
  149. /* USER CODE BEGIN ADC1_MspDeInit 0 */
  150. /* USER CODE END ADC1_MspDeInit 0 */
  151. /* Peripheral clock disable */
  152. __HAL_RCC_ADC1_CLK_DISABLE();
  153. /**ADC1 GPIO Configuration
  154. PB1 ------> ADC1_IN9
  155. */
  156. HAL_GPIO_DeInit(RFU_TEMP_GPIO_Port, RFU_TEMP_Pin);
  157. /* ADC1 DMA DeInit */
  158. HAL_DMA_DeInit(hadc->DMA_Handle);
  159. /* ADC1 interrupt DeInit */
  160. /* USER CODE BEGIN ADC1:ADC1_2_IRQn disable */
  161. /**
  162. * Uncomment the line below to disable the "ADC1_2_IRQn" interrupt
  163. * Be aware, disabling shared interrupt may affect other IPs
  164. */
  165. /* HAL_NVIC_DisableIRQ(ADC1_2_IRQn); */
  166. /* USER CODE END ADC1:ADC1_2_IRQn disable */
  167. /* USER CODE BEGIN ADC1_MspDeInit 1 */
  168. /* USER CODE END ADC1_MspDeInit 1 */
  169. }
  170. else if(hadc->Instance==ADC2)
  171. {
  172. /* USER CODE BEGIN ADC2_MspDeInit 0 */
  173. /* USER CODE END ADC2_MspDeInit 0 */
  174. /* Peripheral clock disable */
  175. __HAL_RCC_ADC2_CLK_DISABLE();
  176. /**ADC2 GPIO Configuration
  177. PC0 ------> ADC2_IN10
  178. */
  179. HAL_GPIO_DeInit(DET_OUT_B_GPIO_Port, DET_OUT_B_Pin);
  180. /* ADC2 interrupt DeInit */
  181. /* USER CODE BEGIN ADC2:ADC1_2_IRQn disable */
  182. /**
  183. * Uncomment the line below to disable the "ADC1_2_IRQn" interrupt
  184. * Be aware, disabling shared interrupt may affect other IPs
  185. */
  186. /* HAL_NVIC_DisableIRQ(ADC1_2_IRQn); */
  187. /* USER CODE END ADC2:ADC1_2_IRQn disable */
  188. /* USER CODE BEGIN ADC2_MspDeInit 1 */
  189. /* USER CODE END ADC2_MspDeInit 1 */
  190. }
  191. else if(hadc->Instance==ADC3)
  192. {
  193. /* USER CODE BEGIN ADC3_MspDeInit 0 */
  194. /* USER CODE END ADC3_MspDeInit 0 */
  195. /* Peripheral clock disable */
  196. __HAL_RCC_ADC3_CLK_DISABLE();
  197. /**ADC3 GPIO Configuration
  198. PC1 ------> ADC3_IN11
  199. */
  200. HAL_GPIO_DeInit(EXT_DET_B_GPIO_Port, EXT_DET_B_Pin);
  201. /* ADC3 interrupt DeInit */
  202. HAL_NVIC_DisableIRQ(ADC3_IRQn);
  203. /* USER CODE BEGIN ADC3_MspDeInit 1 */
  204. /* USER CODE END ADC3_MspDeInit 1 */
  205. }
  206. }
  207. /**
  208. * @brief TIM_Base MSP Initialization
  209. * This function configures the hardware resources used in this example
  210. * @param htim_base: TIM_Base handle pointer
  211. * @retval None
  212. */
  213. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
  214. {
  215. if(htim_base->Instance==TIM6)
  216. {
  217. /* USER CODE BEGIN TIM6_MspInit 0 */
  218. /* USER CODE END TIM6_MspInit 0 */
  219. /* Peripheral clock enable */
  220. __HAL_RCC_TIM6_CLK_ENABLE();
  221. /* USER CODE BEGIN TIM6_MspInit 1 */
  222. /* USER CODE END TIM6_MspInit 1 */
  223. }
  224. }
  225. /**
  226. * @brief TIM_Base MSP De-Initialization
  227. * This function freeze the hardware resources used in this example
  228. * @param htim_base: TIM_Base handle pointer
  229. * @retval None
  230. */
  231. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* htim_base)
  232. {
  233. if(htim_base->Instance==TIM6)
  234. {
  235. /* USER CODE BEGIN TIM6_MspDeInit 0 */
  236. /* USER CODE END TIM6_MspDeInit 0 */
  237. /* Peripheral clock disable */
  238. __HAL_RCC_TIM6_CLK_DISABLE();
  239. /* TIM6 interrupt DeInit */
  240. HAL_NVIC_DisableIRQ(TIM6_IRQn);
  241. /* USER CODE BEGIN TIM6_MspDeInit 1 */
  242. /* USER CODE END TIM6_MspDeInit 1 */
  243. }
  244. }
  245. /**
  246. * @brief UART MSP Initialization
  247. * This function configures the hardware resources used in this example
  248. * @param huart: UART handle pointer
  249. * @retval None
  250. */
  251. void HAL_UART_MspInit(UART_HandleTypeDef* huart)
  252. {
  253. GPIO_InitTypeDef GPIO_InitStruct = {0};
  254. if(huart->Instance==UART4)
  255. {
  256. /* USER CODE BEGIN UART4_MspInit 0 */
  257. /* USER CODE END UART4_MspInit 0 */
  258. /* Peripheral clock enable */
  259. __HAL_RCC_UART4_CLK_ENABLE();
  260. __HAL_RCC_GPIOC_CLK_ENABLE();
  261. /**UART4 GPIO Configuration
  262. PC10 ------> UART4_TX
  263. PC11 ------> UART4_RX
  264. */
  265. GPIO_InitStruct.Pin = GPIO_PIN_10;
  266. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  267. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  268. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  269. GPIO_InitStruct.Pin = GPIO_PIN_11;
  270. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  271. GPIO_InitStruct.Pull = GPIO_NOPULL;
  272. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  273. /* USER CODE BEGIN UART4_MspInit 1 */
  274. /* USER CODE END UART4_MspInit 1 */
  275. }
  276. else if(huart->Instance==USART1)
  277. {
  278. /* USER CODE BEGIN USART1_MspInit 0 */
  279. /* USER CODE END USART1_MspInit 0 */
  280. /* Peripheral clock enable */
  281. __HAL_RCC_USART1_CLK_ENABLE();
  282. __HAL_RCC_GPIOA_CLK_ENABLE();
  283. /**USART1 GPIO Configuration
  284. PA9 ------> USART1_TX
  285. PA10 ------> USART1_RX
  286. */
  287. GPIO_InitStruct.Pin = GPIO_PIN_9;
  288. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  289. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  290. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  291. GPIO_InitStruct.Pin = GPIO_PIN_10;
  292. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  293. GPIO_InitStruct.Pull = GPIO_NOPULL;
  294. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  295. /* USART1 DMA Init */
  296. /* USART1_RX Init */
  297. hdma_usart1_rx.Instance = DMA1_Channel5;
  298. hdma_usart1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  299. hdma_usart1_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  300. hdma_usart1_rx.Init.MemInc = DMA_MINC_ENABLE;
  301. hdma_usart1_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  302. hdma_usart1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  303. hdma_usart1_rx.Init.Mode = DMA_NORMAL;
  304. hdma_usart1_rx.Init.Priority = DMA_PRIORITY_LOW;
  305. if (HAL_DMA_Init(&hdma_usart1_rx) != HAL_OK)
  306. {
  307. Error_Handler();
  308. }
  309. __HAL_LINKDMA(huart,hdmarx,hdma_usart1_rx);
  310. /* USART1_TX Init */
  311. hdma_usart1_tx.Instance = DMA1_Channel4;
  312. hdma_usart1_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  313. hdma_usart1_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  314. hdma_usart1_tx.Init.MemInc = DMA_MINC_ENABLE;
  315. hdma_usart1_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  316. hdma_usart1_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  317. hdma_usart1_tx.Init.Mode = DMA_NORMAL;
  318. hdma_usart1_tx.Init.Priority = DMA_PRIORITY_LOW;
  319. if (HAL_DMA_Init(&hdma_usart1_tx) != HAL_OK)
  320. {
  321. Error_Handler();
  322. }
  323. __HAL_LINKDMA(huart,hdmatx,hdma_usart1_tx);
  324. /* USER CODE BEGIN USART1_MspInit 1 */
  325. /* USER CODE END USART1_MspInit 1 */
  326. }
  327. else if(huart->Instance==USART2)
  328. {
  329. /* USER CODE BEGIN USART2_MspInit 0 */
  330. /* USER CODE END USART2_MspInit 0 */
  331. /* Peripheral clock enable */
  332. __HAL_RCC_USART2_CLK_ENABLE();
  333. __HAL_RCC_GPIOA_CLK_ENABLE();
  334. /**USART2 GPIO Configuration
  335. PA2 ------> USART2_TX
  336. PA3 ------> USART2_RX
  337. */
  338. GPIO_InitStruct.Pin = GPIO_PIN_2;
  339. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  340. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  341. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  342. GPIO_InitStruct.Pin = GPIO_PIN_3;
  343. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  344. GPIO_InitStruct.Pull = GPIO_NOPULL;
  345. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  346. /* USART2 DMA Init */
  347. /* USART2_RX Init */
  348. hdma_usart2_rx.Instance = DMA1_Channel6;
  349. hdma_usart2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  350. hdma_usart2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  351. hdma_usart2_rx.Init.MemInc = DMA_MINC_ENABLE;
  352. hdma_usart2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  353. hdma_usart2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  354. hdma_usart2_rx.Init.Mode = DMA_NORMAL;
  355. hdma_usart2_rx.Init.Priority = DMA_PRIORITY_LOW;
  356. if (HAL_DMA_Init(&hdma_usart2_rx) != HAL_OK)
  357. {
  358. Error_Handler();
  359. }
  360. __HAL_LINKDMA(huart,hdmarx,hdma_usart2_rx);
  361. /* USART2_TX Init */
  362. hdma_usart2_tx.Instance = DMA1_Channel7;
  363. hdma_usart2_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  364. hdma_usart2_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  365. hdma_usart2_tx.Init.MemInc = DMA_MINC_ENABLE;
  366. hdma_usart2_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  367. hdma_usart2_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  368. hdma_usart2_tx.Init.Mode = DMA_NORMAL;
  369. hdma_usart2_tx.Init.Priority = DMA_PRIORITY_LOW;
  370. if (HAL_DMA_Init(&hdma_usart2_tx) != HAL_OK)
  371. {
  372. Error_Handler();
  373. }
  374. __HAL_LINKDMA(huart,hdmatx,hdma_usart2_tx);
  375. /* USER CODE BEGIN USART2_MspInit 1 */
  376. /* USER CODE END USART2_MspInit 1 */
  377. }
  378. }
  379. /**
  380. * @brief UART MSP De-Initialization
  381. * This function freeze the hardware resources used in this example
  382. * @param huart: UART handle pointer
  383. * @retval None
  384. */
  385. void HAL_UART_MspDeInit(UART_HandleTypeDef* huart)
  386. {
  387. if(huart->Instance==UART4)
  388. {
  389. /* USER CODE BEGIN UART4_MspDeInit 0 */
  390. /* USER CODE END UART4_MspDeInit 0 */
  391. /* Peripheral clock disable */
  392. __HAL_RCC_UART4_CLK_DISABLE();
  393. /**UART4 GPIO Configuration
  394. PC10 ------> UART4_TX
  395. PC11 ------> UART4_RX
  396. */
  397. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
  398. /* UART4 interrupt DeInit */
  399. HAL_NVIC_DisableIRQ(UART4_IRQn);
  400. /* USER CODE BEGIN UART4_MspDeInit 1 */
  401. /* USER CODE END UART4_MspDeInit 1 */
  402. }
  403. else if(huart->Instance==USART1)
  404. {
  405. /* USER CODE BEGIN USART1_MspDeInit 0 */
  406. /* USER CODE END USART1_MspDeInit 0 */
  407. /* Peripheral clock disable */
  408. __HAL_RCC_USART1_CLK_DISABLE();
  409. /**USART1 GPIO Configuration
  410. PA9 ------> USART1_TX
  411. PA10 ------> USART1_RX
  412. */
  413. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
  414. /* USART1 DMA DeInit */
  415. HAL_DMA_DeInit(huart->hdmarx);
  416. HAL_DMA_DeInit(huart->hdmatx);
  417. /* USART1 interrupt DeInit */
  418. HAL_NVIC_DisableIRQ(USART1_IRQn);
  419. /* USER CODE BEGIN USART1_MspDeInit 1 */
  420. /* USER CODE END USART1_MspDeInit 1 */
  421. }
  422. else if(huart->Instance==USART2)
  423. {
  424. /* USER CODE BEGIN USART2_MspDeInit 0 */
  425. /* USER CODE END USART2_MspDeInit 0 */
  426. /* Peripheral clock disable */
  427. __HAL_RCC_USART2_CLK_DISABLE();
  428. /**USART2 GPIO Configuration
  429. PA2 ------> USART2_TX
  430. PA3 ------> USART2_RX
  431. */
  432. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_2|GPIO_PIN_3);
  433. /* USART2 DMA DeInit */
  434. HAL_DMA_DeInit(huart->hdmarx);
  435. HAL_DMA_DeInit(huart->hdmatx);
  436. /* USART2 interrupt DeInit */
  437. HAL_NVIC_DisableIRQ(USART2_IRQn);
  438. /* USER CODE BEGIN USART2_MspDeInit 1 */
  439. /* USER CODE END USART2_MspDeInit 1 */
  440. }
  441. }
  442. /* USER CODE BEGIN 1 */
  443. /* USER CODE END 1 */
  444. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/