3 ******************************************************************************
5 * @brief : Main program body
6 ******************************************************************************
7 ** This notice applies to any and all portions of this file
8 * that are not between comment pairs USER CODE BEGIN and
9 * USER CODE END. Other portions of this file, whether
10 * inserted by the user or by software development tools
11 * are owned by their respective copyright owners.
13 * COPYRIGHT(c) 2018 STMicroelectronics
15 * Redistribution and use in source and binary forms, with or without modification,
16 * are permitted provided that the following conditions are met:
17 * 1. Redistributions of source code must retain the above copyright notice,
18 * this list of conditions and the following disclaimer.
19 * 2. Redistributions in binary form must reproduce the above copyright notice,
20 * this list of conditions and the following disclaimer in the documentation
21 * and/or other materials provided with the distribution.
22 * 3. Neither the name of STMicroelectronics nor the names of its contributors
23 * may be used to endorse or promote products derived from this software
24 * without specific prior written permission.
26 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
27 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
29 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
30 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
32 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
33 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
34 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 ******************************************************************************
39 /* Includes ------------------------------------------------------------------*/
41 #include "stm32f1xx_hal.h"
43 /* USER CODE BEGIN Includes */
50 /* USER CODE END Includes */
52 /* Private variables ---------------------------------------------------------*/
54 PCD_HandleTypeDef hpcd_USB_FS;
56 /* USER CODE BEGIN PV */
57 /* Private variables ---------------------------------------------------------*/
59 volatile byte led_trigger;
61 /* USER CODE END PV */
63 /* Private function prototypes -----------------------------------------------*/
64 void SystemClock_Config(void);
65 static void MX_GPIO_Init(void);
66 static void MX_DMA_Init(void);
67 static void MX_USB_PCD_Init(void);
68 static void MX_TIM4_Init(void);
69 static void MX_USART1_UART_Init(void);
70 static void MX_TIM3_Init(void);
72 /* USER CODE BEGIN PFP */
73 /* Private function prototypes -----------------------------------------------*/
75 /* USER CODE END PFP */
77 /* USER CODE BEGIN 0 */
79 static void process_packet(void)
81 uint cmd = get_u32_be(rx_packet);
82 uint arg = get_u32_be(rx_packet+4);
83 debug_printf("<< cmd %08x %08x\n", cmd, arg);
85 memset(tx_packet, 0, sizeof(tx_packet));
86 put_u32_be(tx_packet, 1);
94 LL_GPIO_ResetOutputPin(SSR1_GPIO_Port, SSR1_Pin);
96 LL_GPIO_SetOutputPin(SSR1_GPIO_Port, SSR1_Pin);
98 LL_GPIO_ResetOutputPin(SSR2_GPIO_Port, SSR2_Pin);
100 LL_GPIO_SetOutputPin(SSR2_GPIO_Port, SSR2_Pin);
102 LL_GPIO_ResetOutputPin(SSR3_GPIO_Port, SSR3_Pin);
104 LL_GPIO_SetOutputPin(SSR3_GPIO_Port, SSR3_Pin);
106 LL_GPIO_ResetOutputPin(SSR4_GPIO_Port, SSR4_Pin);
108 LL_GPIO_SetOutputPin(SSR4_GPIO_Port, SSR4_Pin);
109 put_u32_be(tx_packet, 0);
114 debug_printf(">> status %08x\n", get_u32_be(tx_packet));
117 /* USER CODE END 0 */
120 * @brief The application entry point.
126 /* USER CODE BEGIN 1 */
128 /* USER CODE END 1 */
130 /* MCU Configuration----------------------------------------------------------*/
132 /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
135 /* USER CODE BEGIN Init */
137 /* USER CODE END Init */
139 /* Configure the system clock */
140 SystemClock_Config();
142 /* USER CODE BEGIN SysInit */
143 usb_init(&usb, &hpcd_USB_FS);
145 /* USER CODE END SysInit */
147 /* Initialize all configured peripherals */
151 // A hack to let USB host reset us
152 LL_GPIO_InitTypeDef gpio;
153 gpio.Pin = LL_GPIO_PIN_12 | LL_GPIO_PIN_13;
154 gpio.Mode = LL_GPIO_MODE_OUTPUT;
155 gpio.Speed = LL_GPIO_SPEED_FREQ_HIGH;
156 gpio.OutputType = LL_GPIO_OUTPUT_OPENDRAIN;
157 LL_GPIO_Init(GPIOA, &gpio);
158 LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_12);
159 LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_13);
164 MX_USART1_UART_Init();
166 /* USER CODE BEGIN 2 */
169 LL_TIM_EnableCounter(TIM4);
170 LL_TIM_EnableIT_UPDATE(TIM4);
171 LL_TIM_GenerateEvent_UPDATE(TIM4);
173 /* USER CODE END 2 */
176 /* USER CODE BEGIN WHILE */
182 static byte led_state;
184 LL_GPIO_SetOutputPin(LED_GPIO_Port, LED_Pin);
186 LL_GPIO_ResetOutputPin(LED_GPIO_Port, LED_Pin);
190 if (rx_packet_state == 1 && !tx_packet_state)
194 usb_ep_send(&usb, 0x82, tx_packet, 12);
196 usb_ep_receive(&usb, 0x01, rx_packet, 64);
201 debug_printf("Counter = %d\n", cnt);
208 /* USER CODE END WHILE */
210 /* USER CODE BEGIN 3 */
213 /* USER CODE END 3 */
218 * @brief System Clock Configuration
221 void SystemClock_Config(void)
224 LL_FLASH_SetLatency(LL_FLASH_LATENCY_2);
226 if(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2)
232 /* Wait till HSE is ready */
233 while(LL_RCC_HSE_IsReady() != 1)
237 LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSE_DIV_1, LL_RCC_PLL_MUL_9);
241 /* Wait till PLL is ready */
242 while(LL_RCC_PLL_IsReady() != 1)
246 LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1);
248 LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_2);
250 LL_RCC_SetAPB2Prescaler(LL_RCC_APB2_DIV_1);
252 LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL);
254 /* Wait till System clock is ready */
255 while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL)
259 LL_Init1msTick(72000000);
261 LL_SYSTICK_SetClkSource(LL_SYSTICK_CLKSOURCE_HCLK);
263 LL_SetSystemCoreClock(72000000);
265 LL_RCC_SetUSBClockSource(LL_RCC_USB_CLKSOURCE_PLL_DIV_1_5);
267 /* SysTick_IRQn interrupt configuration */
268 NVIC_SetPriority(SysTick_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
271 /* TIM3 init function */
272 static void MX_TIM3_Init(void)
275 LL_TIM_InitTypeDef TIM_InitStruct;
276 LL_TIM_OC_InitTypeDef TIM_OC_InitStruct;
278 LL_GPIO_InitTypeDef GPIO_InitStruct;
280 /* Peripheral clock enable */
281 LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_TIM3);
285 /* TIM3_CH1_TRIG Init */
286 LL_DMA_SetDataTransferDirection(DMA1, LL_DMA_CHANNEL_6, LL_DMA_DIRECTION_PERIPH_TO_MEMORY);
288 LL_DMA_SetChannelPriorityLevel(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PRIORITY_VERYHIGH);
290 LL_DMA_SetMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MODE_NORMAL);
292 LL_DMA_SetPeriphIncMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PERIPH_NOINCREMENT);
294 LL_DMA_SetMemoryIncMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MEMORY_INCREMENT);
296 LL_DMA_SetPeriphSize(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PDATAALIGN_HALFWORD);
298 LL_DMA_SetMemorySize(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MDATAALIGN_HALFWORD);
300 /* TIM3 interrupt Init */
301 NVIC_SetPriority(TIM3_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
302 NVIC_EnableIRQ(TIM3_IRQn);
304 TIM_InitStruct.Prescaler = 71;
305 TIM_InitStruct.CounterMode = LL_TIM_COUNTERMODE_UP;
306 TIM_InitStruct.Autoreload = 0;
307 TIM_InitStruct.ClockDivision = LL_TIM_CLOCKDIVISION_DIV1;
308 LL_TIM_Init(TIM3, &TIM_InitStruct);
310 LL_TIM_DisableARRPreload(TIM3);
312 LL_TIM_SetClockSource(TIM3, LL_TIM_CLOCKSOURCE_INTERNAL);
314 TIM_OC_InitStruct.OCMode = LL_TIM_OCMODE_FROZEN;
315 TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
316 TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
317 TIM_OC_InitStruct.CompareValue = 0;
318 TIM_OC_InitStruct.OCPolarity = LL_TIM_OCPOLARITY_HIGH;
319 LL_TIM_OC_Init(TIM3, LL_TIM_CHANNEL_CH1, &TIM_OC_InitStruct);
321 LL_TIM_OC_DisableFast(TIM3, LL_TIM_CHANNEL_CH1);
323 TIM_OC_InitStruct.OCMode = LL_TIM_OCMODE_ACTIVE;
324 TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
325 TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
326 LL_TIM_OC_Init(TIM3, LL_TIM_CHANNEL_CH2, &TIM_OC_InitStruct);
328 LL_TIM_OC_DisableFast(TIM3, LL_TIM_CHANNEL_CH2);
330 LL_TIM_SetTriggerOutput(TIM3, LL_TIM_TRGO_RESET);
332 LL_TIM_DisableMasterSlaveMode(TIM3);
334 /**TIM3 GPIO Configuration
337 GPIO_InitStruct.Pin = THERMO_Pin;
338 GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
339 GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
340 GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
341 LL_GPIO_Init(THERMO_GPIO_Port, &GPIO_InitStruct);
345 /* TIM4 init function */
346 static void MX_TIM4_Init(void)
349 LL_TIM_InitTypeDef TIM_InitStruct;
350 LL_TIM_OC_InitTypeDef TIM_OC_InitStruct;
352 /* Peripheral clock enable */
353 LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_TIM4);
355 /* TIM4 interrupt Init */
356 NVIC_SetPriority(TIM4_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
357 NVIC_EnableIRQ(TIM4_IRQn);
359 TIM_InitStruct.Prescaler = 7200;
360 TIM_InitStruct.CounterMode = LL_TIM_COUNTERMODE_UP;
361 TIM_InitStruct.Autoreload = 1000;
362 TIM_InitStruct.ClockDivision = LL_TIM_CLOCKDIVISION_DIV1;
363 LL_TIM_Init(TIM4, &TIM_InitStruct);
365 LL_TIM_DisableARRPreload(TIM4);
367 LL_TIM_SetClockSource(TIM4, LL_TIM_CLOCKSOURCE_INTERNAL);
369 TIM_OC_InitStruct.OCMode = LL_TIM_OCMODE_FROZEN;
370 TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
371 TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
372 TIM_OC_InitStruct.CompareValue = 0;
373 TIM_OC_InitStruct.OCPolarity = LL_TIM_OCPOLARITY_HIGH;
374 LL_TIM_OC_Init(TIM4, LL_TIM_CHANNEL_CH1, &TIM_OC_InitStruct);
376 LL_TIM_OC_DisableFast(TIM4, LL_TIM_CHANNEL_CH1);
378 LL_TIM_SetTriggerOutput(TIM4, LL_TIM_TRGO_RESET);
380 LL_TIM_DisableMasterSlaveMode(TIM4);
384 /* USART1 init function */
385 static void MX_USART1_UART_Init(void)
388 LL_USART_InitTypeDef USART_InitStruct;
390 LL_GPIO_InitTypeDef GPIO_InitStruct;
392 /* Peripheral clock enable */
393 LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_USART1);
395 /**USART1 GPIO Configuration
396 PA9 ------> USART1_TX
397 PA10 ------> USART1_RX
399 GPIO_InitStruct.Pin = LL_GPIO_PIN_9;
400 GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
401 GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
402 GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
403 LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
405 GPIO_InitStruct.Pin = LL_GPIO_PIN_10;
406 GPIO_InitStruct.Mode = LL_GPIO_MODE_FLOATING;
407 LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
409 USART_InitStruct.BaudRate = 115200;
410 USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
411 USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
412 USART_InitStruct.Parity = LL_USART_PARITY_NONE;
413 USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
414 USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
415 LL_USART_Init(USART1, &USART_InitStruct);
417 LL_USART_ConfigAsyncMode(USART1);
419 LL_USART_Enable(USART1);
423 /* USB init function */
424 static void MX_USB_PCD_Init(void)
427 hpcd_USB_FS.Instance = USB;
428 hpcd_USB_FS.Init.dev_endpoints = 8;
429 hpcd_USB_FS.Init.speed = PCD_SPEED_FULL;
430 hpcd_USB_FS.Init.ep0_mps = DEP0CTL_MPS_64;
431 hpcd_USB_FS.Init.low_power_enable = DISABLE;
432 hpcd_USB_FS.Init.lpm_enable = DISABLE;
433 hpcd_USB_FS.Init.battery_charging_enable = DISABLE;
434 if (HAL_PCD_Init(&hpcd_USB_FS) != HAL_OK)
436 _Error_Handler(__FILE__, __LINE__);
442 * Enable DMA controller clock
444 static void MX_DMA_Init(void)
446 /* DMA controller clock enable */
447 __HAL_RCC_DMA1_CLK_ENABLE();
449 /* DMA interrupt init */
450 /* DMA1_Channel6_IRQn interrupt configuration */
451 NVIC_SetPriority(DMA1_Channel6_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
452 NVIC_EnableIRQ(DMA1_Channel6_IRQn);
456 /** Configure pins as
463 static void MX_GPIO_Init(void)
466 LL_GPIO_InitTypeDef GPIO_InitStruct;
468 /* GPIO Ports Clock Enable */
469 LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOC);
470 LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOD);
471 LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOA);
472 LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOB);
474 /* LED output is OC, active low, defaults to high */
475 LL_GPIO_SetOutputPin(LED_GPIO_Port, LED_Pin);
477 /* SSR outputs are OC, active low, default to high */
478 LL_GPIO_SetOutputPin(GPIOB, SSR3_Pin|SSR4_Pin|SSR1_Pin|SSR2_Pin);
481 GPIO_InitStruct.Pin = LED_Pin;
482 GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT;
483 GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
484 GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_OPENDRAIN;
485 LL_GPIO_Init(LED_GPIO_Port, &GPIO_InitStruct);
488 GPIO_InitStruct.Pin = SSR3_Pin|SSR4_Pin|SSR1_Pin|SSR2_Pin;
489 GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT;
490 GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
491 GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_OPENDRAIN;
492 LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
496 /* USER CODE BEGIN 4 */
498 /* USER CODE END 4 */
501 * @brief This function is executed in case of error occurrence.
502 * @param file: The file name as string.
503 * @param line: The line in file as a number.
506 void _Error_Handler(char *file, int line)
508 /* USER CODE BEGIN Error_Handler_Debug */
509 /* User can add his own implementation to report the HAL error return state */
513 /* USER CODE END Error_Handler_Debug */
516 #ifdef USE_FULL_ASSERT
518 * @brief Reports the name of the source file and the source line number
519 * where the assert_param error has occurred.
520 * @param file: pointer to the source file name
521 * @param line: assert_param error line source number
524 void assert_failed(uint8_t* file, uint32_t line)
526 /* USER CODE BEGIN 6 */
527 /* User can add his own implementation to report the file name and line number,
528 tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
529 /* USER CODE END 6 */
531 #endif /* USE_FULL_ASSERT */
541 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/