]> mj.ucw.cz Git - home-hw.git/blob - ssr/Src/main.c
SSR: Move declaration
[home-hw.git] / ssr / Src / main.c
1
2 /**
3   ******************************************************************************
4   * @file           : main.c
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.
12   *
13   * COPYRIGHT(c) 2018 STMicroelectronics
14   *
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.
25   *
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.
36   *
37   ******************************************************************************
38   */
39 /* Includes ------------------------------------------------------------------*/
40 #include "main.h"
41 #include "stm32f1xx_hal.h"
42
43 /* USER CODE BEGIN Includes */
44 #include "util.h"
45 #include "usb.h"
46 #include "app.h"
47
48 #include <string.h>
49
50 /* USER CODE END Includes */
51
52 /* Private variables ---------------------------------------------------------*/
53
54 PCD_HandleTypeDef hpcd_USB_FS;
55
56 /* USER CODE BEGIN PV */
57 /* Private variables ---------------------------------------------------------*/
58 struct usb usb;
59 volatile byte led_trigger;
60
61 /* USER CODE END PV */
62
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);
71
72 /* USER CODE BEGIN PFP */
73 /* Private function prototypes -----------------------------------------------*/
74
75 /* USER CODE END PFP */
76
77 /* USER CODE BEGIN 0 */
78
79 static void process_packet(void)
80 {
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);
84
85   memset(tx_packet, 0, sizeof(tx_packet));
86   put_u32_be(tx_packet, 1);
87
88   switch (cmd)
89     {
90     case 1:
91       if (arg < 16)
92         {
93           if (arg & 1)
94             LL_GPIO_ResetOutputPin(SSR1_GPIO_Port, SSR1_Pin);
95           else
96             LL_GPIO_SetOutputPin(SSR1_GPIO_Port, SSR1_Pin);
97           if (arg & 2)
98             LL_GPIO_ResetOutputPin(SSR2_GPIO_Port, SSR2_Pin);
99           else
100             LL_GPIO_SetOutputPin(SSR2_GPIO_Port, SSR2_Pin);
101           if (arg & 4)
102             LL_GPIO_ResetOutputPin(SSR3_GPIO_Port, SSR3_Pin);
103           else
104             LL_GPIO_SetOutputPin(SSR3_GPIO_Port, SSR3_Pin);
105           if (arg & 8)
106             LL_GPIO_ResetOutputPin(SSR4_GPIO_Port, SSR4_Pin);
107           else
108             LL_GPIO_SetOutputPin(SSR4_GPIO_Port, SSR4_Pin);
109           put_u32_be(tx_packet, 0);
110         }
111       break;
112     }
113
114   debug_printf(">> status %08x\n", get_u32_be(tx_packet));
115 }
116
117 /* USER CODE END 0 */
118
119 /**
120   * @brief  The application entry point.
121   *
122   * @retval None
123   */
124 int main(void)
125 {
126   /* USER CODE BEGIN 1 */
127
128   /* USER CODE END 1 */
129
130   /* MCU Configuration----------------------------------------------------------*/
131
132   /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
133   HAL_Init();
134
135   /* USER CODE BEGIN Init */
136
137   /* USER CODE END Init */
138
139   /* Configure the system clock */
140   SystemClock_Config();
141
142   /* USER CODE BEGIN SysInit */
143   usb_init(&usb, &hpcd_USB_FS);
144
145   /* USER CODE END SysInit */
146
147   /* Initialize all configured peripherals */
148   MX_GPIO_Init();
149   MX_DMA_Init();
150
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);
160   LL_mDelay(1000);
161
162   MX_USB_PCD_Init();
163   MX_TIM4_Init();
164   MX_USART1_UART_Init();
165   MX_TIM3_Init();
166   /* USER CODE BEGIN 2 */
167   usb_start(&usb);
168
169   LL_TIM_EnableCounter(TIM4);
170   LL_TIM_EnableIT_UPDATE(TIM4);
171   LL_TIM_GenerateEvent_UPDATE(TIM4);
172
173   /* USER CODE END 2 */
174
175   /* Infinite loop */
176   /* USER CODE BEGIN WHILE */
177   while (1)
178   {
179     if (led_trigger)
180       {
181         led_trigger = 0;
182         static byte led_state;
183         if (led_state)
184           LL_GPIO_SetOutputPin(LED_GPIO_Port, LED_Pin);
185         else
186           LL_GPIO_ResetOutputPin(LED_GPIO_Port, LED_Pin);
187         led_state ^= 1;
188       }
189
190     if (rx_packet_state == 1 && !tx_packet_state)
191       {
192         tx_packet_state = 1;
193         process_packet();
194         usb_ep_send(&usb, 0x82, tx_packet, 12);
195         rx_packet_state = 0;
196         usb_ep_receive(&usb, 0x01, rx_packet, 64);
197       }
198
199 #if 0
200     static int cnt;
201     debug_printf("Counter = %d\n", cnt);
202     cnt++;
203 #endif
204
205     __WFI();
206     // LL_mDelay(1000);
207
208   /* USER CODE END WHILE */
209
210   /* USER CODE BEGIN 3 */
211
212   }
213   /* USER CODE END 3 */
214
215 }
216
217 /**
218   * @brief System Clock Configuration
219   * @retval None
220   */
221 void SystemClock_Config(void)
222 {
223
224   LL_FLASH_SetLatency(LL_FLASH_LATENCY_2);
225
226    if(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2)
227   {
228     Error_Handler();  
229   }
230   LL_RCC_HSE_Enable();
231
232    /* Wait till HSE is ready */
233   while(LL_RCC_HSE_IsReady() != 1)
234   {
235     
236   }
237   LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSE_DIV_1, LL_RCC_PLL_MUL_9);
238
239   LL_RCC_PLL_Enable();
240
241    /* Wait till PLL is ready */
242   while(LL_RCC_PLL_IsReady() != 1)
243   {
244     
245   }
246   LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1);
247
248   LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_2);
249
250   LL_RCC_SetAPB2Prescaler(LL_RCC_APB2_DIV_1);
251
252   LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL);
253
254    /* Wait till System clock is ready */
255   while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL)
256   {
257   
258   }
259   LL_Init1msTick(72000000);
260
261   LL_SYSTICK_SetClkSource(LL_SYSTICK_CLKSOURCE_HCLK);
262
263   LL_SetSystemCoreClock(72000000);
264
265   LL_RCC_SetUSBClockSource(LL_RCC_USB_CLKSOURCE_PLL_DIV_1_5);
266
267   /* SysTick_IRQn interrupt configuration */
268   NVIC_SetPriority(SysTick_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
269 }
270
271 /* TIM3 init function */
272 static void MX_TIM3_Init(void)
273 {
274
275   LL_TIM_InitTypeDef TIM_InitStruct;
276   LL_TIM_OC_InitTypeDef TIM_OC_InitStruct;
277
278   LL_GPIO_InitTypeDef GPIO_InitStruct;
279
280   /* Peripheral clock enable */
281   LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_TIM3);
282
283   /* TIM3 DMA Init */
284   
285   /* TIM3_CH1_TRIG Init */
286   LL_DMA_SetDataTransferDirection(DMA1, LL_DMA_CHANNEL_6, LL_DMA_DIRECTION_PERIPH_TO_MEMORY);
287
288   LL_DMA_SetChannelPriorityLevel(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PRIORITY_VERYHIGH);
289
290   LL_DMA_SetMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MODE_NORMAL);
291
292   LL_DMA_SetPeriphIncMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PERIPH_NOINCREMENT);
293
294   LL_DMA_SetMemoryIncMode(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MEMORY_INCREMENT);
295
296   LL_DMA_SetPeriphSize(DMA1, LL_DMA_CHANNEL_6, LL_DMA_PDATAALIGN_HALFWORD);
297
298   LL_DMA_SetMemorySize(DMA1, LL_DMA_CHANNEL_6, LL_DMA_MDATAALIGN_HALFWORD);
299
300   /* TIM3 interrupt Init */
301   NVIC_SetPriority(TIM3_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
302   NVIC_EnableIRQ(TIM3_IRQn);
303
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);
309
310   LL_TIM_DisableARRPreload(TIM3);
311
312   LL_TIM_SetClockSource(TIM3, LL_TIM_CLOCKSOURCE_INTERNAL);
313
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);
320
321   LL_TIM_OC_DisableFast(TIM3, LL_TIM_CHANNEL_CH1);
322
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);
327
328   LL_TIM_OC_DisableFast(TIM3, LL_TIM_CHANNEL_CH2);
329
330   LL_TIM_SetTriggerOutput(TIM3, LL_TIM_TRGO_RESET);
331
332   LL_TIM_DisableMasterSlaveMode(TIM3);
333
334   /**TIM3 GPIO Configuration  
335   PA7   ------> TIM3_CH2 
336   */
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);
342
343 }
344
345 /* TIM4 init function */
346 static void MX_TIM4_Init(void)
347 {
348
349   LL_TIM_InitTypeDef TIM_InitStruct;
350   LL_TIM_OC_InitTypeDef TIM_OC_InitStruct;
351
352   /* Peripheral clock enable */
353   LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_TIM4);
354
355   /* TIM4 interrupt Init */
356   NVIC_SetPriority(TIM4_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),0, 0));
357   NVIC_EnableIRQ(TIM4_IRQn);
358
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);
364
365   LL_TIM_DisableARRPreload(TIM4);
366
367   LL_TIM_SetClockSource(TIM4, LL_TIM_CLOCKSOURCE_INTERNAL);
368
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);
375
376   LL_TIM_OC_DisableFast(TIM4, LL_TIM_CHANNEL_CH1);
377
378   LL_TIM_SetTriggerOutput(TIM4, LL_TIM_TRGO_RESET);
379
380   LL_TIM_DisableMasterSlaveMode(TIM4);
381
382 }
383
384 /* USART1 init function */
385 static void MX_USART1_UART_Init(void)
386 {
387
388   LL_USART_InitTypeDef USART_InitStruct;
389
390   LL_GPIO_InitTypeDef GPIO_InitStruct;
391
392   /* Peripheral clock enable */
393   LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_USART1);
394   
395   /**USART1 GPIO Configuration  
396   PA9   ------> USART1_TX
397   PA10   ------> USART1_RX 
398   */
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);
404
405   GPIO_InitStruct.Pin = LL_GPIO_PIN_10;
406   GPIO_InitStruct.Mode = LL_GPIO_MODE_FLOATING;
407   LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
408
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);
416
417   LL_USART_ConfigAsyncMode(USART1);
418
419   LL_USART_Enable(USART1);
420
421 }
422
423 /* USB init function */
424 static void MX_USB_PCD_Init(void)
425 {
426
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)
435   {
436     _Error_Handler(__FILE__, __LINE__);
437   }
438
439 }
440
441 /** 
442   * Enable DMA controller clock
443   */
444 static void MX_DMA_Init(void) 
445 {
446   /* DMA controller clock enable */
447   __HAL_RCC_DMA1_CLK_ENABLE();
448
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);
453
454 }
455
456 /** Configure pins as 
457         * Analog 
458         * Input 
459         * Output
460         * EVENT_OUT
461         * EXTI
462 */
463 static void MX_GPIO_Init(void)
464 {
465
466   LL_GPIO_InitTypeDef GPIO_InitStruct;
467
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);
473
474   /* LED output is OC, active low, defaults to high */
475   LL_GPIO_SetOutputPin(LED_GPIO_Port, LED_Pin);
476
477   /* SSR outputs are OC, active low, default to high */
478   LL_GPIO_SetOutputPin(GPIOB, SSR3_Pin|SSR4_Pin|SSR1_Pin|SSR2_Pin);
479
480   /**/
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);
486
487   /**/
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);
493
494 }
495
496 /* USER CODE BEGIN 4 */
497
498 /* USER CODE END 4 */
499
500 /**
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.
504   * @retval None
505   */
506 void _Error_Handler(char *file, int line)
507 {
508   /* USER CODE BEGIN Error_Handler_Debug */
509   /* User can add his own implementation to report the HAL error return state */
510   while(1)
511   {
512   }
513   /* USER CODE END Error_Handler_Debug */
514 }
515
516 #ifdef  USE_FULL_ASSERT
517 /**
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
522   * @retval None
523   */
524 void assert_failed(uint8_t* file, uint32_t line)
525
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 */
530 }
531 #endif /* USE_FULL_ASSERT */
532
533 /**
534   * @}
535   */
536
537 /**
538   * @}
539   */
540
541 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/