-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpwm.c
executable file
·94 lines (84 loc) · 2.85 KB
/
pwm.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
* TongSheng TSDZ2 motor controller firmware/
*
* Copyright (C) Casainho, 2018.
*
* Released under the GPL License, Version 3
*/
#include <stdint.h>
#include <stdio.h>
#include "stm8s_tim1.h"
#include "stm8s_flash.h"
#include "interrupts.h"
#include "pwm.h"
#include "pins.h"
void pwm_init_bipolar_4q (void)
{
// verify if PWM N channels are active on option bytes, if not, enable
FLASH_SetProgrammingTime(FLASH_PROGRAMTIME_STANDARD);
if (FLASH_ReadOptionByte (0x4803) != 0x20)
{
FLASH_Unlock (FLASH_MEMTYPE_DATA);
FLASH_EraseOptionByte(0x4803);
FLASH_ProgramOptionByte(0x4803, 0x20);
FLASH_Lock (FLASH_MEMTYPE_DATA);
}
TIM1_TimeBaseInit(0, // TIM1_Prescaler = 0
TIM1_COUNTERMODE_CENTERALIGNED1,
(512 - 1), // clock = 16MHz; counter period = 1024; PWM freq = 16MHz / 1024 = 15.625kHz;
//(BUT PWM center aligned mode needs twice the frequency)
1); // will fire the TIM1_IT_UPDATE at every PWM period cycle
//#define DISABLE_PWM_CHANNELS_1_3
TIM1_OC1Init(TIM1_OCMODE_PWM1,
#ifdef DISABLE_PWM_CHANNELS_1_3
TIM1_OUTPUTSTATE_DISABLE,
TIM1_OUTPUTNSTATE_DISABLE,
#else
TIM1_OUTPUTSTATE_ENABLE,
TIM1_OUTPUTNSTATE_ENABLE,
#endif
255, // initial duty_cycle value
TIM1_OCPOLARITY_HIGH,
TIM1_OCPOLARITY_HIGH,
TIM1_OCIDLESTATE_RESET,
TIM1_OCNIDLESTATE_SET);
TIM1_OC2Init(TIM1_OCMODE_PWM1,
TIM1_OUTPUTSTATE_ENABLE,
TIM1_OUTPUTNSTATE_ENABLE,
255, // initial duty_cycle value
TIM1_OCPOLARITY_HIGH,
TIM1_OCPOLARITY_HIGH,
TIM1_OCIDLESTATE_RESET,
TIM1_OCIDLESTATE_SET);
TIM1_OC3Init(TIM1_OCMODE_PWM1,
#ifdef DISABLE_PWM_CHANNELS_1_3
TIM1_OUTPUTSTATE_DISABLE,
TIM1_OUTPUTNSTATE_DISABLE,
#else
TIM1_OUTPUTSTATE_ENABLE,
TIM1_OUTPUTNSTATE_ENABLE,
#endif
255, // initial duty_cycle value
TIM1_OCPOLARITY_HIGH,
TIM1_OCPOLARITY_HIGH,
TIM1_OCIDLESTATE_RESET,
TIM1_OCNIDLESTATE_SET);
// OC4 is being used only to fire interrupt at a specific time (middle of DC link current pulses)
// OC4 is always syncronized with PWM
TIM1_OC4Init(TIM1_OCMODE_PWM1,
TIM1_OUTPUTSTATE_DISABLE,
285, // timming for interrupt firing (hand adjusted)
TIM1_OCPOLARITY_HIGH,
TIM1_OCIDLESTATE_RESET);
// break, dead time and lock configuration
TIM1_BDTRConfig(TIM1_OSSISTATE_ENABLE,
TIM1_LOCKLEVEL_OFF,
// hardware nees a dead time of 1us
16, // DTG = 0; dead time in 62.5 ns steps; 1us/62.5ns = 16
TIM1_BREAK_DISABLE,
TIM1_BREAKPOLARITY_LOW,
TIM1_AUTOMATICOUTPUT_DISABLE);
TIM1_ITConfig(TIM1_IT_CC4, ENABLE);
TIM1_Cmd(ENABLE); // TIM1 counter enable
TIM1_CtrlPWMOutputs(ENABLE);
}