PWM Variant update
- made the 2 channels to operate independently #61 - added defines to enable/disable motors, if one motor is not needed #63
This commit is contained in:
parent
8ddfc82882
commit
205c054235
3 changed files with 34 additions and 6 deletions
|
@ -124,6 +124,10 @@
|
|||
Outputs:
|
||||
- speedR and speedL: normal driving INPUT_MIN to INPUT_MAX
|
||||
*/
|
||||
// Enable/Disable Motor
|
||||
#define MOTOR_LEFT_ENA // [-] Enable LEFT motor. Comment-out if this motor is not needed to be operational
|
||||
#define MOTOR_RIGHT_ENA // [-] Enable RIGHT motor. Comment-out if this motor is not needed to be operational
|
||||
|
||||
// Control selections
|
||||
#define CTRL_TYP_SEL 2 // [-] Control type selection: 0 = Commutation , 1 = Sinusoidal, 2 = FOC Field Oriented Control (default)
|
||||
#define CTRL_MOD_REQ 1 // [-] Control mode request: 0 = Open mode, 1 = VOLTAGE mode (default), 2 = SPEED mode, 3 = TORQUE mode. Note: SPEED and TORQUE modes are only available for FOC!
|
||||
|
|
|
@ -171,7 +171,9 @@ void DMA1_Channel1_IRQHandler(void) {
|
|||
rtU_Left.i_DCLink = curL_DC;
|
||||
|
||||
/* Step the controller */
|
||||
#ifdef MOTOR_LEFT_ENA
|
||||
BLDC_controller_step(rtM_Left);
|
||||
#endif
|
||||
|
||||
/* Get motor outputs here */
|
||||
ul = rtY_Left.DC_phaA;
|
||||
|
@ -206,7 +208,9 @@ void DMA1_Channel1_IRQHandler(void) {
|
|||
rtU_Right.i_DCLink = curR_DC;
|
||||
|
||||
/* Step the controller */
|
||||
#ifdef MOTOR_RIGHT_ENA
|
||||
BLDC_controller_step(rtM_Right);
|
||||
#endif
|
||||
|
||||
/* Get motor outputs here */
|
||||
ur = rtY_Right.DC_phaA;
|
||||
|
|
|
@ -86,17 +86,32 @@ void PPM_Init(void) {
|
|||
|
||||
|
||||
#ifdef CONTROL_PWM
|
||||
/*
|
||||
* Illustration of the PWM functionality
|
||||
* CH1 ________|‾‾‾‾‾‾‾‾‾‾|________
|
||||
* CH2 ______________|‾‾‾‾‾‾‾‾‾‾‾|________
|
||||
* ↑ ↑ ↑ ↑
|
||||
* TIM2 RST SAVE RC_CH1 RC_CH1
|
||||
*/
|
||||
|
||||
uint16_t pwm_captured_ch1_value = 500;
|
||||
uint16_t pwm_captured_ch2_value = 500;
|
||||
uint16_t pwm_CNT_prev_ch1 = 0;
|
||||
uint16_t pwm_CNT_prev_ch2 = 0;
|
||||
uint32_t pwm_timeout_ch1 = 0;
|
||||
uint32_t pwm_timeout_ch2 = 0;
|
||||
|
||||
void PWM_ISR_CH1_Callback(void) {
|
||||
// Dummy loop with 16 bit count wrap around
|
||||
if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_2)) { // Rising Edge interrupt -> reset timer
|
||||
TIM2->CNT = 0;
|
||||
if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_2)) { // Rising Edge interrupt -> save timer value OR reset timer
|
||||
if (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_3)) {
|
||||
pwm_CNT_prev_ch1 = TIM2->CNT;
|
||||
} else {
|
||||
TIM2->CNT = 0;
|
||||
pwm_CNT_prev_ch1 = 0;
|
||||
}
|
||||
} else { // Falling Edge interrupt -> measure pulse duration
|
||||
uint16_t rc_signal = TIM2->CNT;
|
||||
uint16_t rc_signal = TIM2->CNT - pwm_CNT_prev_ch1;
|
||||
if (IN_RANGE(rc_signal, 900, 2100)){
|
||||
timeout = 0;
|
||||
pwm_timeout_ch1 = 0;
|
||||
|
@ -107,10 +122,15 @@ void PWM_ISR_CH1_Callback(void) {
|
|||
|
||||
void PWM_ISR_CH2_Callback(void) {
|
||||
// Dummy loop with 16 bit count wrap around
|
||||
if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_3)) { // Rising Edge interrupt -> reset timer
|
||||
TIM2->CNT = 0;
|
||||
if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_3)) { // Rising Edge interrupt -> save timer value OR reset timer
|
||||
if (HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_2)) {
|
||||
pwm_CNT_prev_ch2 = TIM2->CNT;
|
||||
} else {
|
||||
TIM2->CNT = 0;
|
||||
pwm_CNT_prev_ch2 = 0;
|
||||
}
|
||||
} else { // Falling Edge interrupt -> measure pulse duration
|
||||
uint16_t rc_signal = TIM2->CNT;
|
||||
uint16_t rc_signal = TIM2->CNT - pwm_CNT_prev_ch2;
|
||||
if (IN_RANGE(rc_signal, 900, 2100)){
|
||||
timeout = 0;
|
||||
pwm_timeout_ch2 = 0;
|
||||
|
|
Loading…
Reference in a new issue