main.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file : main.c
  5. * @brief : Main program body
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; Copyright (c) 2020 STMicroelectronics.
  10. * All rights reserved.</center></h2>
  11. *
  12. * This software component is licensed by ST under Ultimate Liberty license
  13. * SLA0044, the "License"; You may not use this file except in compliance with
  14. * the License. You may obtain a copy of the License at:
  15. * www.st.com/SLA0044
  16. *
  17. ******************************************************************************
  18. */
  19. /* USER CODE END Header */
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "main.h"
  22. #include "cmsis_os.h"
  23. #include "usb_device.h"
  24. /* Private includes ----------------------------------------------------------*/
  25. /* USER CODE BEGIN Includes */
  26. /* USER CODE END Includes */
  27. /* Private typedef -----------------------------------------------------------*/
  28. /* USER CODE BEGIN PTD */
  29. /* USER CODE END PTD */
  30. /* Private define ------------------------------------------------------------*/
  31. /* USER CODE BEGIN PD */
  32. /* USER CODE END PD */
  33. /* Private macro -------------------------------------------------------------*/
  34. /* USER CODE BEGIN PM */
  35. /* USER CODE END PM */
  36. /* Private variables ---------------------------------------------------------*/
  37. ADC_HandleTypeDef hadc1;
  38. COMP_HandleTypeDef hcomp1;
  39. DAC_HandleTypeDef hdac1;
  40. SPI_HandleTypeDef hspi1;
  41. SPI_HandleTypeDef hspi3;
  42. TIM_HandleTypeDef htim5;
  43. TIM_HandleTypeDef htim8;
  44. TIM_HandleTypeDef htim15;
  45. UART_HandleTypeDef huart1;
  46. osThreadId defaultTaskHandle;
  47. /* USER CODE BEGIN PV */
  48. /* USER CODE END PV */
  49. /* Private function prototypes -----------------------------------------------*/
  50. void SystemClock_Config(void);
  51. static void MX_GPIO_Init(void);
  52. static void MX_SPI1_Init(void);
  53. static void MX_SPI3_Init(void);
  54. static void MX_ADC1_Init(void);
  55. static void MX_COMP1_Init(void);
  56. static void MX_DAC1_Init(void);
  57. static void MX_TIM5_Init(void);
  58. static void MX_TIM15_Init(void);
  59. static void MX_USART1_UART_Init(void);
  60. static void MX_TIM8_Init(void);
  61. void StartDefaultTask(void const* argument);
  62. /* USER CODE BEGIN PFP */
  63. /* USER CODE END PFP */
  64. /* Private user code ---------------------------------------------------------*/
  65. /* USER CODE BEGIN 0 */
  66. /* USER CODE END 0 */
  67. /**
  68. * @brief The application entry point.
  69. * @retval int
  70. */
  71. int main(void) {
  72. /* USER CODE BEGIN 1 */
  73. /* USER CODE END 1 */
  74. /* MCU Configuration--------------------------------------------------------*/
  75. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  76. HAL_Init();
  77. /* USER CODE BEGIN Init */
  78. /* USER CODE END Init */
  79. /* Configure the system clock */
  80. SystemClock_Config();
  81. /* USER CODE BEGIN SysInit */
  82. /* USER CODE END SysInit */
  83. /* Initialize all configured peripherals */
  84. MX_GPIO_Init();
  85. MX_SPI1_Init();
  86. MX_SPI3_Init();
  87. MX_ADC1_Init();
  88. MX_COMP1_Init();
  89. MX_DAC1_Init();
  90. MX_TIM5_Init();
  91. MX_TIM15_Init();
  92. MX_USART1_UART_Init();
  93. MX_TIM8_Init();
  94. /* USER CODE BEGIN 2 */
  95. /* USER CODE END 2 */
  96. /* USER CODE BEGIN RTOS_MUTEX */
  97. /* add mutexes, ... */
  98. /* USER CODE END RTOS_MUTEX */
  99. /* USER CODE BEGIN RTOS_SEMAPHORES */
  100. /* add semaphores, ... */
  101. /* USER CODE END RTOS_SEMAPHORES */
  102. /* USER CODE BEGIN RTOS_TIMERS */
  103. /* start timers, add new ones, ... */
  104. /* USER CODE END RTOS_TIMERS */
  105. /* USER CODE BEGIN RTOS_QUEUES */
  106. /* add queues, ... */
  107. /* USER CODE END RTOS_QUEUES */
  108. /* Create the thread(s) */
  109. /* definition and creation of defaultTask */
  110. osThreadDef(defaultTask, StartDefaultTask, osPriorityNormal, 0, 1024);
  111. defaultTaskHandle = osThreadCreate(osThread(defaultTask), NULL);
  112. /* USER CODE BEGIN RTOS_THREADS */
  113. /* add threads, ... */
  114. /* USER CODE END RTOS_THREADS */
  115. /* Start scheduler */
  116. osKernelStart();
  117. /* We should never get here as control is now taken by the scheduler */
  118. /* Infinite loop */
  119. /* USER CODE BEGIN WHILE */
  120. while(1) {
  121. /* USER CODE END WHILE */
  122. /* USER CODE BEGIN 3 */
  123. }
  124. /* USER CODE END 3 */
  125. }
  126. /**
  127. * @brief System Clock Configuration
  128. * @retval None
  129. */
  130. void SystemClock_Config(void) {
  131. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  132. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  133. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  134. /** Initializes the CPU, AHB and APB busses clocks
  135. */
  136. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  137. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  138. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  139. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  140. RCC_OscInitStruct.PLL.PLLM = 2;
  141. RCC_OscInitStruct.PLL.PLLN = 16;
  142. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7;
  143. RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
  144. RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
  145. if(HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) {
  146. Error_Handler();
  147. }
  148. /** Initializes the CPU, AHB and APB busses clocks
  149. */
  150. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1 |
  151. RCC_CLOCKTYPE_PCLK2;
  152. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  153. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  154. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  155. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  156. if(HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3) != HAL_OK) {
  157. Error_Handler();
  158. }
  159. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USB |
  160. RCC_PERIPHCLK_ADC;
  161. PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK2;
  162. PeriphClkInit.AdcClockSelection = RCC_ADCCLKSOURCE_SYSCLK;
  163. PeriphClkInit.UsbClockSelection = RCC_USBCLKSOURCE_PLLSAI1;
  164. PeriphClkInit.PLLSAI1.PLLSAI1Source = RCC_PLLSOURCE_HSE;
  165. PeriphClkInit.PLLSAI1.PLLSAI1M = 2;
  166. PeriphClkInit.PLLSAI1.PLLSAI1N = 12;
  167. PeriphClkInit.PLLSAI1.PLLSAI1P = RCC_PLLP_DIV7;
  168. PeriphClkInit.PLLSAI1.PLLSAI1Q = RCC_PLLQ_DIV2;
  169. PeriphClkInit.PLLSAI1.PLLSAI1R = RCC_PLLR_DIV2;
  170. PeriphClkInit.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_48M2CLK;
  171. if(HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK) {
  172. Error_Handler();
  173. }
  174. /** Configure the main internal regulator output voltage
  175. */
  176. if(HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK) {
  177. Error_Handler();
  178. }
  179. }
  180. /**
  181. * @brief ADC1 Initialization Function
  182. * @param None
  183. * @retval None
  184. */
  185. static void MX_ADC1_Init(void) {
  186. /* USER CODE BEGIN ADC1_Init 0 */
  187. /* USER CODE END ADC1_Init 0 */
  188. ADC_MultiModeTypeDef multimode = {0};
  189. ADC_ChannelConfTypeDef sConfig = {0};
  190. /* USER CODE BEGIN ADC1_Init 1 */
  191. /* USER CODE END ADC1_Init 1 */
  192. /** Common config
  193. */
  194. hadc1.Instance = ADC1;
  195. hadc1.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
  196. hadc1.Init.Resolution = ADC_RESOLUTION_12B;
  197. hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
  198. hadc1.Init.ScanConvMode = ADC_SCAN_DISABLE;
  199. hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
  200. hadc1.Init.LowPowerAutoWait = DISABLE;
  201. hadc1.Init.ContinuousConvMode = DISABLE;
  202. hadc1.Init.NbrOfConversion = 1;
  203. hadc1.Init.DiscontinuousConvMode = DISABLE;
  204. hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
  205. hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
  206. hadc1.Init.DMAContinuousRequests = DISABLE;
  207. hadc1.Init.Overrun = ADC_OVR_DATA_PRESERVED;
  208. hadc1.Init.OversamplingMode = DISABLE;
  209. if(HAL_ADC_Init(&hadc1) != HAL_OK) {
  210. Error_Handler();
  211. }
  212. /** Configure the ADC multi-mode
  213. */
  214. multimode.Mode = ADC_MODE_INDEPENDENT;
  215. if(HAL_ADCEx_MultiModeConfigChannel(&hadc1, &multimode) != HAL_OK) {
  216. Error_Handler();
  217. }
  218. /** Configure Regular Channel
  219. */
  220. sConfig.Channel = ADC_CHANNEL_4;
  221. sConfig.Rank = ADC_REGULAR_RANK_1;
  222. sConfig.SamplingTime = ADC_SAMPLETIME_2CYCLES_5;
  223. sConfig.SingleDiff = ADC_SINGLE_ENDED;
  224. sConfig.OffsetNumber = ADC_OFFSET_NONE;
  225. sConfig.Offset = 0;
  226. if(HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK) {
  227. Error_Handler();
  228. }
  229. /* USER CODE BEGIN ADC1_Init 2 */
  230. /* USER CODE END ADC1_Init 2 */
  231. }
  232. /**
  233. * @brief COMP1 Initialization Function
  234. * @param None
  235. * @retval None
  236. */
  237. static void MX_COMP1_Init(void) {
  238. /* USER CODE BEGIN COMP1_Init 0 */
  239. /* USER CODE END COMP1_Init 0 */
  240. /* USER CODE BEGIN COMP1_Init 1 */
  241. /* USER CODE END COMP1_Init 1 */
  242. hcomp1.Instance = COMP1;
  243. hcomp1.Init.InvertingInput = COMP_INPUT_MINUS_DAC1_CH1;
  244. hcomp1.Init.NonInvertingInput = COMP_INPUT_PLUS_IO1;
  245. hcomp1.Init.OutputPol = COMP_OUTPUTPOL_NONINVERTED;
  246. hcomp1.Init.Hysteresis = COMP_HYSTERESIS_NONE;
  247. hcomp1.Init.BlankingSrce = COMP_BLANKINGSRC_NONE;
  248. hcomp1.Init.Mode = COMP_POWERMODE_HIGHSPEED;
  249. hcomp1.Init.WindowMode = COMP_WINDOWMODE_DISABLE;
  250. hcomp1.Init.TriggerMode = COMP_TRIGGERMODE_NONE;
  251. if(HAL_COMP_Init(&hcomp1) != HAL_OK) {
  252. Error_Handler();
  253. }
  254. /* USER CODE BEGIN COMP1_Init 2 */
  255. /* USER CODE END COMP1_Init 2 */
  256. }
  257. /**
  258. * @brief DAC1 Initialization Function
  259. * @param None
  260. * @retval None
  261. */
  262. static void MX_DAC1_Init(void) {
  263. /* USER CODE BEGIN DAC1_Init 0 */
  264. /* USER CODE END DAC1_Init 0 */
  265. DAC_ChannelConfTypeDef sConfig = {0};
  266. /* USER CODE BEGIN DAC1_Init 1 */
  267. /* USER CODE END DAC1_Init 1 */
  268. /** DAC Initialization
  269. */
  270. hdac1.Instance = DAC1;
  271. if(HAL_DAC_Init(&hdac1) != HAL_OK) {
  272. Error_Handler();
  273. }
  274. /** DAC channel OUT1 config
  275. */
  276. sConfig.DAC_SampleAndHold = DAC_SAMPLEANDHOLD_DISABLE;
  277. sConfig.DAC_Trigger = DAC_TRIGGER_NONE;
  278. sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE;
  279. sConfig.DAC_ConnectOnChipPeripheral = DAC_CHIPCONNECT_ENABLE;
  280. sConfig.DAC_UserTrimming = DAC_TRIMMING_FACTORY;
  281. if(HAL_DAC_ConfigChannel(&hdac1, &sConfig, DAC_CHANNEL_1) != HAL_OK) {
  282. Error_Handler();
  283. }
  284. /* USER CODE BEGIN DAC1_Init 2 */
  285. /* USER CODE END DAC1_Init 2 */
  286. }
  287. /**
  288. * @brief SPI1 Initialization Function
  289. * @param None
  290. * @retval None
  291. */
  292. static void MX_SPI1_Init(void) {
  293. /* USER CODE BEGIN SPI1_Init 0 */
  294. /* USER CODE END SPI1_Init 0 */
  295. /* USER CODE BEGIN SPI1_Init 1 */
  296. /* USER CODE END SPI1_Init 1 */
  297. /* SPI1 parameter configuration*/
  298. hspi1.Instance = SPI1;
  299. hspi1.Init.Mode = SPI_MODE_MASTER;
  300. hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  301. hspi1.Init.DataSize = SPI_DATASIZE_8BIT;
  302. hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  303. hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  304. hspi1.Init.NSS = SPI_NSS_SOFT;
  305. hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_16;
  306. hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
  307. hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
  308. hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  309. hspi1.Init.CRCPolynomial = 7;
  310. hspi1.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  311. hspi1.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  312. if(HAL_SPI_Init(&hspi1) != HAL_OK) {
  313. Error_Handler();
  314. }
  315. /* USER CODE BEGIN SPI1_Init 2 */
  316. /* USER CODE END SPI1_Init 2 */
  317. }
  318. /**
  319. * @brief SPI3 Initialization Function
  320. * @param None
  321. * @retval None
  322. */
  323. static void MX_SPI3_Init(void) {
  324. /* USER CODE BEGIN SPI3_Init 0 */
  325. /* USER CODE END SPI3_Init 0 */
  326. /* USER CODE BEGIN SPI3_Init 1 */
  327. /* USER CODE END SPI3_Init 1 */
  328. /* SPI3 parameter configuration*/
  329. hspi3.Instance = SPI3;
  330. hspi3.Init.Mode = SPI_MODE_MASTER;
  331. hspi3.Init.Direction = SPI_DIRECTION_2LINES;
  332. hspi3.Init.DataSize = SPI_DATASIZE_8BIT;
  333. hspi3.Init.CLKPolarity = SPI_POLARITY_LOW;
  334. hspi3.Init.CLKPhase = SPI_PHASE_1EDGE;
  335. hspi3.Init.NSS = SPI_NSS_SOFT;
  336. hspi3.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_64;
  337. hspi3.Init.FirstBit = SPI_FIRSTBIT_MSB;
  338. hspi3.Init.TIMode = SPI_TIMODE_DISABLE;
  339. hspi3.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  340. hspi3.Init.CRCPolynomial = 7;
  341. hspi3.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  342. hspi3.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  343. if(HAL_SPI_Init(&hspi3) != HAL_OK) {
  344. Error_Handler();
  345. }
  346. /* USER CODE BEGIN SPI3_Init 2 */
  347. /* USER CODE END SPI3_Init 2 */
  348. }
  349. /**
  350. * @brief TIM5 Initialization Function
  351. * @param None
  352. * @retval None
  353. */
  354. static void MX_TIM5_Init(void) {
  355. /* USER CODE BEGIN TIM5_Init 0 */
  356. /* USER CODE END TIM5_Init 0 */
  357. TIM_MasterConfigTypeDef sMasterConfig = {0};
  358. TIM_OC_InitTypeDef sConfigOC = {0};
  359. /* USER CODE BEGIN TIM5_Init 1 */
  360. /* USER CODE END TIM5_Init 1 */
  361. htim5.Instance = TIM5;
  362. htim5.Init.Prescaler = 500 - 1;
  363. htim5.Init.CounterMode = TIM_COUNTERMODE_UP;
  364. htim5.Init.Period = 291;
  365. htim5.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  366. htim5.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  367. if(HAL_TIM_PWM_Init(&htim5) != HAL_OK) {
  368. Error_Handler();
  369. }
  370. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  371. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  372. if(HAL_TIMEx_MasterConfigSynchronization(&htim5, &sMasterConfig) != HAL_OK) {
  373. Error_Handler();
  374. }
  375. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  376. sConfigOC.Pulse = 145;
  377. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  378. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  379. if(HAL_TIM_PWM_ConfigChannel(&htim5, &sConfigOC, TIM_CHANNEL_4) != HAL_OK) {
  380. Error_Handler();
  381. }
  382. /* USER CODE BEGIN TIM5_Init 2 */
  383. /* USER CODE END TIM5_Init 2 */
  384. HAL_TIM_MspPostInit(&htim5);
  385. }
  386. /**
  387. * @brief TIM8 Initialization Function
  388. * @param None
  389. * @retval None
  390. */
  391. static void MX_TIM8_Init(void) {
  392. /* USER CODE BEGIN TIM8_Init 0 */
  393. /* USER CODE END TIM8_Init 0 */
  394. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  395. TIM_MasterConfigTypeDef sMasterConfig = {0};
  396. TIM_IC_InitTypeDef sConfigIC = {0};
  397. /* USER CODE BEGIN TIM8_Init 1 */
  398. /* USER CODE END TIM8_Init 1 */
  399. htim8.Instance = TIM8;
  400. htim8.Init.Prescaler = 64 - 1;
  401. htim8.Init.CounterMode = TIM_COUNTERMODE_UP;
  402. htim8.Init.Period = 32768 - 1;
  403. htim8.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  404. htim8.Init.RepetitionCounter = 0;
  405. htim8.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  406. if(HAL_TIM_Base_Init(&htim8) != HAL_OK) {
  407. Error_Handler();
  408. }
  409. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  410. if(HAL_TIM_ConfigClockSource(&htim8, &sClockSourceConfig) != HAL_OK) {
  411. Error_Handler();
  412. }
  413. if(HAL_TIM_IC_Init(&htim8) != HAL_OK) {
  414. Error_Handler();
  415. }
  416. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  417. sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
  418. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  419. if(HAL_TIMEx_MasterConfigSynchronization(&htim8, &sMasterConfig) != HAL_OK) {
  420. Error_Handler();
  421. }
  422. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_BOTHEDGE;
  423. sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  424. sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  425. sConfigIC.ICFilter = 0;
  426. if(HAL_TIM_IC_ConfigChannel(&htim8, &sConfigIC, TIM_CHANNEL_2) != HAL_OK) {
  427. Error_Handler();
  428. }
  429. /* USER CODE BEGIN TIM8_Init 2 */
  430. /* USER CODE END TIM8_Init 2 */
  431. }
  432. /**
  433. * @brief TIM15 Initialization Function
  434. * @param None
  435. * @retval None
  436. */
  437. static void MX_TIM15_Init(void) {
  438. /* USER CODE BEGIN TIM15_Init 0 */
  439. /* USER CODE END TIM15_Init 0 */
  440. TIM_MasterConfigTypeDef sMasterConfig = {0};
  441. TIM_OC_InitTypeDef sConfigOC = {0};
  442. TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  443. /* USER CODE BEGIN TIM15_Init 1 */
  444. /* USER CODE END TIM15_Init 1 */
  445. htim15.Instance = TIM15;
  446. htim15.Init.Prescaler = 0;
  447. htim15.Init.CounterMode = TIM_COUNTERMODE_UP;
  448. htim15.Init.Period = 0;
  449. htim15.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  450. htim15.Init.RepetitionCounter = 0;
  451. htim15.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  452. if(HAL_TIM_OC_Init(&htim15) != HAL_OK) {
  453. Error_Handler();
  454. }
  455. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  456. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  457. if(HAL_TIMEx_MasterConfigSynchronization(&htim15, &sMasterConfig) != HAL_OK) {
  458. Error_Handler();
  459. }
  460. sConfigOC.OCMode = TIM_OCMODE_TIMING;
  461. sConfigOC.Pulse = 0;
  462. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  463. sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
  464. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  465. sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
  466. sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  467. if(HAL_TIM_OC_ConfigChannel(&htim15, &sConfigOC, TIM_CHANNEL_1) != HAL_OK) {
  468. Error_Handler();
  469. }
  470. if(HAL_TIM_OC_ConfigChannel(&htim15, &sConfigOC, TIM_CHANNEL_2) != HAL_OK) {
  471. Error_Handler();
  472. }
  473. sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
  474. sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  475. sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
  476. sBreakDeadTimeConfig.DeadTime = 0;
  477. sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
  478. sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
  479. sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
  480. if(HAL_TIMEx_ConfigBreakDeadTime(&htim15, &sBreakDeadTimeConfig) != HAL_OK) {
  481. Error_Handler();
  482. }
  483. /* USER CODE BEGIN TIM15_Init 2 */
  484. /* USER CODE END TIM15_Init 2 */
  485. HAL_TIM_MspPostInit(&htim15);
  486. }
  487. /**
  488. * @brief USART1 Initialization Function
  489. * @param None
  490. * @retval None
  491. */
  492. static void MX_USART1_UART_Init(void) {
  493. /* USER CODE BEGIN USART1_Init 0 */
  494. /* USER CODE END USART1_Init 0 */
  495. /* USER CODE BEGIN USART1_Init 1 */
  496. /* USER CODE END USART1_Init 1 */
  497. huart1.Instance = USART1;
  498. huart1.Init.BaudRate = 115200;
  499. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  500. huart1.Init.StopBits = UART_STOPBITS_1;
  501. huart1.Init.Parity = UART_PARITY_NONE;
  502. huart1.Init.Mode = UART_MODE_TX_RX;
  503. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  504. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  505. huart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  506. huart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  507. if(HAL_UART_Init(&huart1) != HAL_OK) {
  508. Error_Handler();
  509. }
  510. /* USER CODE BEGIN USART1_Init 2 */
  511. /* USER CODE END USART1_Init 2 */
  512. }
  513. /**
  514. * @brief GPIO Initialization Function
  515. * @param None
  516. * @retval None
  517. */
  518. static void MX_GPIO_Init(void) {
  519. GPIO_InitTypeDef GPIO_InitStruct = {0};
  520. /* GPIO Ports Clock Enable */
  521. __HAL_RCC_GPIOC_CLK_ENABLE();
  522. __HAL_RCC_GPIOH_CLK_ENABLE();
  523. __HAL_RCC_GPIOA_CLK_ENABLE();
  524. __HAL_RCC_GPIOB_CLK_ENABLE();
  525. __HAL_RCC_GPIOD_CLK_ENABLE();
  526. /*Configure GPIO pin Output Level */
  527. HAL_GPIO_WritePin(GPIOA, DISPLAY_DI_Pin | CC1101_CS_Pin, GPIO_PIN_RESET);
  528. /*Configure GPIO pin Output Level */
  529. HAL_GPIO_WritePin(GPIOB, LED_BLUE_Pin | LED_GREEN_Pin, GPIO_PIN_SET);
  530. /*Configure GPIO pin Output Level */
  531. HAL_GPIO_WritePin(GPIOB, DISPLAY_RST_Pin | IR_TX_Pin | DISPLAY_BACKLIGHT_Pin, GPIO_PIN_RESET);
  532. /*Configure GPIO pin Output Level */
  533. HAL_GPIO_WritePin(GPIOC, VIBRO_Pin | DISPLAY_CS_Pin, GPIO_PIN_RESET);
  534. /*Configure GPIO pin Output Level */
  535. HAL_GPIO_WritePin(LED_RED_GPIO_Port, LED_RED_Pin, GPIO_PIN_SET);
  536. /*Configure GPIO pins : PC13 PC0 PC1 PC9 */
  537. GPIO_InitStruct.Pin = GPIO_PIN_13 | GPIO_PIN_0 | GPIO_PIN_1 | GPIO_PIN_9;
  538. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  539. GPIO_InitStruct.Pull = GPIO_NOPULL;
  540. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  541. /*Configure GPIO pin : CHRG_Pin */
  542. GPIO_InitStruct.Pin = CHRG_Pin;
  543. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  544. GPIO_InitStruct.Pull = GPIO_PULLUP;
  545. HAL_GPIO_Init(CHRG_GPIO_Port, &GPIO_InitStruct);
  546. /*Configure GPIO pins : BUTTON_DOWN_Pin BUTTON_BACK_Pin */
  547. GPIO_InitStruct.Pin = BUTTON_DOWN_Pin | BUTTON_BACK_Pin;
  548. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  549. GPIO_InitStruct.Pull = GPIO_PULLDOWN;
  550. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  551. /*Configure GPIO pins : DISPLAY_DI_Pin CC1101_CS_Pin */
  552. GPIO_InitStruct.Pin = DISPLAY_DI_Pin | CC1101_CS_Pin;
  553. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  554. GPIO_InitStruct.Pull = GPIO_NOPULL;
  555. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  556. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  557. /*Configure GPIO pins : PA5 PA7 */
  558. GPIO_InitStruct.Pin = GPIO_PIN_5 | GPIO_PIN_7;
  559. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  560. GPIO_InitStruct.Pull = GPIO_NOPULL;
  561. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  562. /*Configure GPIO pins : BUTTON_UP_Pin BUTTON_RIGHT_Pin BUTTON_OK_Pin */
  563. GPIO_InitStruct.Pin = BUTTON_UP_Pin | BUTTON_RIGHT_Pin | BUTTON_OK_Pin;
  564. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  565. GPIO_InitStruct.Pull = GPIO_PULLDOWN;
  566. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  567. /*Configure GPIO pins : LED_BLUE_Pin LED_GREEN_Pin */
  568. GPIO_InitStruct.Pin = LED_BLUE_Pin | LED_GREEN_Pin;
  569. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_OD;
  570. GPIO_InitStruct.Pull = GPIO_NOPULL;
  571. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_MEDIUM;
  572. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  573. /*Configure GPIO pins : PB2 PB12 */
  574. GPIO_InitStruct.Pin = GPIO_PIN_2 | GPIO_PIN_12;
  575. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  576. GPIO_InitStruct.Pull = GPIO_NOPULL;
  577. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  578. /*Configure GPIO pins : DISPLAY_RST_Pin IR_TX_Pin DISPLAY_BACKLIGHT_Pin */
  579. GPIO_InitStruct.Pin = DISPLAY_RST_Pin | IR_TX_Pin | DISPLAY_BACKLIGHT_Pin;
  580. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  581. GPIO_InitStruct.Pull = GPIO_NOPULL;
  582. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  583. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  584. /*Configure GPIO pins : VIBRO_Pin DISPLAY_CS_Pin */
  585. GPIO_InitStruct.Pin = VIBRO_Pin | DISPLAY_CS_Pin;
  586. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  587. GPIO_InitStruct.Pull = GPIO_NOPULL;
  588. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  589. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  590. /*Configure GPIO pin : LED_RED_Pin */
  591. GPIO_InitStruct.Pin = LED_RED_Pin;
  592. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_OD;
  593. GPIO_InitStruct.Pull = GPIO_NOPULL;
  594. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_MEDIUM;
  595. HAL_GPIO_Init(LED_RED_GPIO_Port, &GPIO_InitStruct);
  596. /*Configure GPIO pin : PD2 */
  597. GPIO_InitStruct.Pin = GPIO_PIN_2;
  598. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  599. GPIO_InitStruct.Pull = GPIO_NOPULL;
  600. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  601. /*Configure GPIO pin : BUTTON_LEFT_Pin */
  602. GPIO_InitStruct.Pin = BUTTON_LEFT_Pin;
  603. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
  604. GPIO_InitStruct.Pull = GPIO_PULLDOWN;
  605. HAL_GPIO_Init(BUTTON_LEFT_GPIO_Port, &GPIO_InitStruct);
  606. /*Configure GPIO pin : CC1101_G0_Pin */
  607. GPIO_InitStruct.Pin = CC1101_G0_Pin;
  608. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  609. GPIO_InitStruct.Pull = GPIO_NOPULL;
  610. HAL_GPIO_Init(CC1101_G0_GPIO_Port, &GPIO_InitStruct);
  611. /* EXTI interrupt init*/
  612. HAL_NVIC_SetPriority(EXTI0_IRQn, 5, 0);
  613. HAL_NVIC_EnableIRQ(EXTI0_IRQn);
  614. HAL_NVIC_SetPriority(EXTI1_IRQn, 5, 0);
  615. HAL_NVIC_EnableIRQ(EXTI1_IRQn);
  616. HAL_NVIC_SetPriority(EXTI2_IRQn, 5, 0);
  617. HAL_NVIC_EnableIRQ(EXTI2_IRQn);
  618. HAL_NVIC_SetPriority(EXTI4_IRQn, 5, 0);
  619. HAL_NVIC_EnableIRQ(EXTI4_IRQn);
  620. HAL_NVIC_SetPriority(EXTI9_5_IRQn, 5, 0);
  621. HAL_NVIC_EnableIRQ(EXTI9_5_IRQn);
  622. }
  623. /* USER CODE BEGIN 4 */
  624. void app();
  625. /* USER CODE END 4 */
  626. /* USER CODE BEGIN Header_StartDefaultTask */
  627. /**
  628. * @brief Function implementing the defaultTask thread.
  629. * @param argument: Not used
  630. * @retval None
  631. */
  632. /* USER CODE END Header_StartDefaultTask */
  633. void StartDefaultTask(void const* argument) {
  634. /* init code for USB_DEVICE */
  635. MX_USB_DEVICE_Init();
  636. /* USER CODE BEGIN 5 */
  637. /* Infinite loop */
  638. app();
  639. for(;;) {
  640. osDelay(1);
  641. }
  642. /* USER CODE END 5 */
  643. }
  644. /**
  645. * @brief This function is executed in case of error occurrence.
  646. * @retval None
  647. */
  648. void Error_Handler(void) {
  649. /* USER CODE BEGIN Error_Handler_Debug */
  650. /* User can add his own implementation to report the HAL error return state */
  651. /* USER CODE END Error_Handler_Debug */
  652. }
  653. #ifdef USE_FULL_ASSERT
  654. /**
  655. * @brief Reports the name of the source file and the source line number
  656. * where the assert_param error has occurred.
  657. * @param file: pointer to the source file name
  658. * @param line: assert_param error line source number
  659. * @retval None
  660. */
  661. void assert_failed(char* file, uint32_t line) {
  662. /* USER CODE BEGIN 6 */
  663. /* User can add his own implementation to report the file name and line number,
  664. tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  665. /* USER CODE END 6 */
  666. }
  667. #endif /* USE_FULL_ASSERT */
  668. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/