bldc/firmware/src/Driver/motor.c

135 lines
5.9 KiB
C
Raw Normal View History

2020-10-20 14:43:40 +00:00
/*******************************************************************************
* @file motor.c
* @author: MQjehovah mail:MQjehovah@hotmail.com
* @version 1.0.0
* @date 2020.10.20
* @brief
******************************************************************************
* @attention
*******************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include "motor.h"
2020-10-21 11:17:15 +00:00
#include "GPIO.h"
2020-10-20 14:43:40 +00:00
/* Definition ----------------------------------------------------------------*/
motor_t motor_info;
/* Functions -----------------------------------------------------------------*/
2020-10-20 16:30:52 +00:00
/*******************************************************************************
* @brief
* @param None
* @retval None
* @note
*******************************************************************************/
2020-10-21 09:28:47 +00:00
void motor_start(void)
2020-10-20 16:30:52 +00:00
{
motor_info.state = 1;
//TODO:开启霍尔捕捉中断
2020-10-21 09:28:47 +00:00
motor_info.hall_position = get_hall_position();
motor_step();
2020-10-20 16:30:52 +00:00
}
2020-10-20 14:43:40 +00:00
/*******************************************************************************
* @brief
* @param None
* @retval None
* @note None
*******************************************************************************/
2020-10-21 09:28:47 +00:00
void motor_stop(void)
2020-10-20 14:43:40 +00:00
{
motor_info.state = MOTOR_STATE_STOP;
TIM1->CCR1 = 0;
TIM1->CCR2 = 0;
TIM1->CCR3 = 0;
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Disable);
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Disable);
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Disable);
}
/*******************************************************************************
* @brief 6
* @param None
* @retval None
2020-10-20 16:30:52 +00:00
* @note H-PWM, L-ON
* PWM总是出现在A+B+C+,
2020-10-20 14:43:40 +00:00
*******************************************************************************/
2020-10-21 09:28:47 +00:00
void motor_step(void)
2020-10-20 14:43:40 +00:00
{
2020-10-21 09:28:47 +00:00
u8 step = motor_info.hall_position;
2020-10-20 16:30:52 +00:00
switch (step)
2020-10-20 14:43:40 +00:00
{
2020-10-21 11:17:15 +00:00
case 0x03: //第二步 C+ B-
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_3, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Disable);
2020-10-20 16:30:52 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Disable);
2020-10-21 09:28:47 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Enable);
2020-10-20 16:30:52 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_2, TIM_ForcedAction_Active);
2020-10-20 14:43:40 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Disable);
2020-10-20 16:30:52 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Enable);
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Disable);
break;
2020-10-21 11:17:15 +00:00
case 0x01: //第三步 C+ A-
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_3, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Disable);
2020-10-20 14:43:40 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Disable);
2020-10-21 09:28:47 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Enable);
TIM_SelectOCxM(TIM1, TIM_Channel_1, TIM_ForcedAction_Active);
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Enable);
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Disable);
2020-10-20 14:43:40 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Disable);
2020-10-20 16:30:52 +00:00
break;
2020-10-21 11:17:15 +00:00
case 0x05: //第四步 B+ A-
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_2, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Disable);
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Enable);
2020-10-20 16:30:52 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Disable);
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_1, TIM_ForcedAction_Active);
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Enable);
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Disable);
2020-10-20 16:30:52 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Disable);
break;
2020-10-21 11:17:15 +00:00
case 0x04: //第五步 B+ C-
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_2, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Disable);
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Enable);
2020-10-20 14:43:40 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Disable);
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_3, TIM_ForcedAction_Active);
2020-10-20 16:30:52 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Disable);
2020-10-21 09:28:47 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Enable);
2020-10-20 16:30:52 +00:00
break;
2020-10-21 09:28:47 +00:00
case 0x06: //第六步 A+ C-
2020-10-20 16:30:52 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_1, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Enable);
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Disable);
2020-10-20 14:43:40 +00:00
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Disable);
2020-10-21 09:28:47 +00:00
TIM_SelectOCxM(TIM1, TIM_Channel_3, TIM_ForcedAction_Active);
2020-10-20 16:30:52 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Disable);
2020-10-21 09:28:47 +00:00
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Enable);
2020-10-20 16:30:52 +00:00
break;
2020-10-21 11:17:15 +00:00
case 0x02: //第一步 A+ B-
// GPIO_WritePin(&PB5, HIGH);
TIM_SelectOCxM(TIM1, TIM_Channel_1, TIM_OCMode_PWM1);
TIM_CCxCmd(TIM1, TIM_Channel_1, TIM_CCx_Enable);
TIM_CCxCmd(TIM1, TIM_Channel_2, TIM_CCx_Disable);
TIM_CCxCmd(TIM1, TIM_Channel_3, TIM_CCx_Disable);
TIM_SelectOCxM(TIM1, TIM_Channel_2, TIM_ForcedAction_Active);
TIM_CCxNCmd(TIM1, TIM_Channel_1, TIM_CCxN_Disable);
TIM_CCxNCmd(TIM1, TIM_Channel_2, TIM_CCxN_Enable);
TIM_CCxNCmd(TIM1, TIM_Channel_3, TIM_CCxN_Disable);
break;
2020-10-20 16:30:52 +00:00
default:
2020-10-21 11:17:15 +00:00
// GPIO_WritePin(&PB5, HIGH);
GPIO_WritePin(&PB5, LOW);
//motor_stop();
2020-10-20 16:30:52 +00:00
break;
2020-10-20 14:43:40 +00:00
}
2020-10-21 09:28:47 +00:00
TIM_GenerateEvent(TIM1, TIM_EventSource_COM);
2020-10-20 14:43:40 +00:00
}
/*********************************END OF FILE**********************************/