1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- #include "stm32f0xx_hal.h"
- #include "logic.h"
- #include "pwm_in.h"
- #include "gpio.h"
- #include "pwm_out.h"
- static uint8_t step_number = 0;
- //
- void logic_main(void)
- {
- IWDG->KR = 0xAAAA;
-
- if (get_button())
- {
- gpio_set_output(true);
- HAL_Delay(500);
- IWDG->KR = 0xAAAA;
- HAL_Delay(500);
- IWDG->KR = 0xAAAA;
- logic_set_out_pwm();
- HAL_Delay(500);
- IWDG->KR = 0xAAAA;
- gpio_set_output(false);
- tim_pwm_pulse_idle();
-
- set_button(false);
- }
-
- }
- //
- void logic_set_out_pwm(void)
- {
- switch (step_number)
- {
- case 0:
- tim_pwm_out_set_pulse(PWM_OUT_CH_1, 1300);
- break;
-
- case 1:
- tim_pwm_out_set_pulse(PWM_OUT_CH_2, 1300);
- break;
-
- case 2:
- tim_pwm_out_set_pulse(PWM_OUT_CH_1, 1850);
- break;
-
- case 3:
- tim_pwm_out_set_pulse(PWM_OUT_CH_2, 1850);
- break;
-
- default : break;
- }
-
- step_number = step_number == 3 ? 0 : step_number + 1;
- }
- //
- void wdt_init(void)
- {
- RCC_OscInitTypeDef RCC_OscInitStruct;
-
- RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI;
- RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
- RCC_OscInitStruct.LSIState = RCC_LSI_ON;
- HAL_RCC_OscConfig(&RCC_OscInitStruct);
-
- // 1. Enable the IWDG by writing 0x0000 CCCC in the IWDG_KR register.
- IWDG->KR = 0xCCCC;
- // 2. Enable register access by writing 0x0000 5555 in the IWDG_KR register.
- IWDG->KR = 0x5555;
- // 3. Write the IWDG prescaler by programming IWDG_PR from 0 to 7.
- IWDG->PR = 4;
- // 4. Write the reload register (IWDG_RLR).
- IWDG->RLR = 1000;
- // 5. Wait for the registers to be updated (IWDG_SR = 0x0000 0000).
- while (IWDG->SR);
- // 6. Refresh the counter value with IWDG_RLR (IWDG_KR = 0x0000 AAAA)
- IWDG->KR = 0xAAAA;
- }
|