|
@@ -1,18 +1,19 @@
|
|
|
#include "foc/limit.h"
|
|
#include "foc/limit.h"
|
|
|
#include "foc/core/PMSM_FOC_Core.h"
|
|
#include "foc/core/PMSM_FOC_Core.h"
|
|
|
#include "foc/motor/motor.h"
|
|
#include "foc/motor/motor.h"
|
|
|
|
|
+#include "foc/motor/motor_param.h"
|
|
|
#include "foc/samples.h"
|
|
#include "foc/samples.h"
|
|
|
#include "foc/mc_error.h"
|
|
#include "foc/mc_error.h"
|
|
|
|
|
|
|
|
static limter_t motor_temp_lim[] = {//电机过温限流,限制相电流
|
|
static limter_t motor_temp_lim[] = {//电机过温限流,限制相电流
|
|
|
{.enter_pointer = 120, .exit_pointer = 110, .limit_value = 0},
|
|
{.enter_pointer = 120, .exit_pointer = 110, .limit_value = 0},
|
|
|
- {.enter_pointer = 110, .exit_pointer = 100, .limit_value = 12},
|
|
|
|
|
- {.enter_pointer = 100, .exit_pointer = 90, .limit_value = 13},
|
|
|
|
|
|
|
+ {.enter_pointer = 110, .exit_pointer = 100, .limit_value = CONFIG_MAX_MOTOR_TORQUE/2},
|
|
|
|
|
+ {.enter_pointer = 100, .exit_pointer = 90, .limit_value = CONFIG_MAX_MOTOR_TORQUE/3*2},
|
|
|
};
|
|
};
|
|
|
static limter_t mos_temp_lim[] = { //mos过温限流,限制相电流
|
|
static limter_t mos_temp_lim[] = { //mos过温限流,限制相电流
|
|
|
{.enter_pointer = 95, .exit_pointer = 85, .limit_value = 0},
|
|
{.enter_pointer = 95, .exit_pointer = 85, .limit_value = 0},
|
|
|
- {.enter_pointer = 86, .exit_pointer = 80, .limit_value = 80},
|
|
|
|
|
- {.enter_pointer = 81, .exit_pointer = 70, .limit_value = 120},
|
|
|
|
|
|
|
+ {.enter_pointer = 86, .exit_pointer = 80, .limit_value = CONFIG_MAX_MOTOR_TORQUE/2},
|
|
|
|
|
+ {.enter_pointer = 81, .exit_pointer = 70, .limit_value = CONFIG_MAX_MOTOR_TORQUE/3*2},
|
|
|
};
|
|
};
|
|
|
static limter_t vol_under_lim[] = { //欠压限流,限制母线
|
|
static limter_t vol_under_lim[] = { //欠压限流,限制母线
|
|
|
{.enter_pointer = 20, .exit_pointer = 20, .limit_value = 10},
|
|
{.enter_pointer = 20, .exit_pointer = 20, .limit_value = 10},
|
|
@@ -27,7 +28,7 @@ static u16 _temp_limiter(s16 temp, limter_t *lim) {
|
|
|
if (!lim->is_limit) {
|
|
if (!lim->is_limit) {
|
|
|
if (temp < lim->enter_pointer) {
|
|
if (temp < lim->enter_pointer) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
if (lim->ticks == 0) {
|
|
if (lim->ticks == 0) {
|
|
|
lim->ticks = get_tick_ms();
|
|
lim->ticks = get_tick_ms();
|
|
@@ -36,7 +37,7 @@ static u16 _temp_limiter(s16 temp, limter_t *lim) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
return lim->limit_value;
|
|
return lim->limit_value;
|
|
|
}
|
|
}
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}else {
|
|
}else {
|
|
|
if (temp >= lim->exit_pointer) {
|
|
if (temp >= lim->exit_pointer) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
@@ -47,7 +48,7 @@ static u16 _temp_limiter(s16 temp, limter_t *lim) {
|
|
|
}else if (get_delta_ms(lim->ticks) >= 5000) {
|
|
}else if (get_delta_ms(lim->ticks) >= 5000) {
|
|
|
lim->is_limit = false;
|
|
lim->is_limit = false;
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
return lim->limit_value;
|
|
return lim->limit_value;
|
|
|
}
|
|
}
|
|
@@ -57,7 +58,7 @@ static u16 _vol_limiter(s16 vol, limter_t *lim) {
|
|
|
if (!lim->is_limit) {
|
|
if (!lim->is_limit) {
|
|
|
if (vol > lim->enter_pointer) {
|
|
if (vol > lim->enter_pointer) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
if (lim->ticks == 0) {
|
|
if (lim->ticks == 0) {
|
|
|
lim->ticks = get_tick_ms();
|
|
lim->ticks = get_tick_ms();
|
|
@@ -66,7 +67,7 @@ static u16 _vol_limiter(s16 vol, limter_t *lim) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
return lim->limit_value;
|
|
return lim->limit_value;
|
|
|
}
|
|
}
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}else {
|
|
}else {
|
|
|
if (vol <= lim->exit_pointer) {
|
|
if (vol <= lim->exit_pointer) {
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
@@ -77,7 +78,7 @@ static u16 _vol_limiter(s16 vol, limter_t *lim) {
|
|
|
}else if (get_delta_ms(lim->ticks) >= 1000) {
|
|
}else if (get_delta_ms(lim->ticks) >= 1000) {
|
|
|
lim->is_limit = false;
|
|
lim->is_limit = false;
|
|
|
lim->ticks = 0;
|
|
lim->ticks = 0;
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
return lim->limit_value;
|
|
return lim->limit_value;
|
|
|
}
|
|
}
|
|
@@ -88,14 +89,16 @@ static u16 _motor_limit(void) {
|
|
|
for(int i = 0; i < ARRAY_SIZE(motor_temp_lim); i++) {
|
|
for(int i = 0; i < ARRAY_SIZE(motor_temp_lim); i++) {
|
|
|
limter_t *lim = motor_temp_lim + i;
|
|
limter_t *lim = motor_temp_lim + i;
|
|
|
u16 lim_value = _temp_limiter(temp, lim);
|
|
u16 lim_value = _temp_limiter(temp, lim);
|
|
|
- if (lim_value != CURRENT_LIMIT_NONE) {
|
|
|
|
|
- mc_set_critical_error(FOC_CRIT_MOTOR_TEMP_Err);
|
|
|
|
|
|
|
+ if (lim_value != HW_LIMIT_NONE) {
|
|
|
|
|
+ if (lim_value == 0) {
|
|
|
|
|
+ mc_set_critical_error(FOC_CRIT_MOTOR_TEMP_Err);
|
|
|
|
|
+ }
|
|
|
err_add_record(FOC_CRIT_MOTOR_TEMP_Err, temp);
|
|
err_add_record(FOC_CRIT_MOTOR_TEMP_Err, temp);
|
|
|
return lim_value;
|
|
return lim_value;
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
mc_clr_critical_error(FOC_CRIT_MOTOR_TEMP_Err);
|
|
mc_clr_critical_error(FOC_CRIT_MOTOR_TEMP_Err);
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
static u16 _mos_limit(void) {
|
|
static u16 _mos_limit(void) {
|
|
@@ -103,14 +106,16 @@ static u16 _mos_limit(void) {
|
|
|
for(int i = 0; i < ARRAY_SIZE(mos_temp_lim); i++) {
|
|
for(int i = 0; i < ARRAY_SIZE(mos_temp_lim); i++) {
|
|
|
limter_t *lim = mos_temp_lim + i;
|
|
limter_t *lim = mos_temp_lim + i;
|
|
|
u16 lim_value = _temp_limiter(temp, lim);
|
|
u16 lim_value = _temp_limiter(temp, lim);
|
|
|
- if (lim_value != CURRENT_LIMIT_NONE) {
|
|
|
|
|
- mc_set_critical_error(FOC_CRIT_MOS_TEMP_Err);
|
|
|
|
|
|
|
+ if (lim_value != HW_LIMIT_NONE) {
|
|
|
|
|
+ if (lim_value == 0) {
|
|
|
|
|
+ mc_set_critical_error(FOC_CRIT_MOS_TEMP_Err);
|
|
|
|
|
+ }
|
|
|
err_add_record(FOC_CRIT_MOS_TEMP_Err, temp);
|
|
err_add_record(FOC_CRIT_MOS_TEMP_Err, temp);
|
|
|
return lim_value;
|
|
return lim_value;
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
mc_clr_critical_error(FOC_CRIT_MOS_TEMP_Err);
|
|
mc_clr_critical_error(FOC_CRIT_MOS_TEMP_Err);
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
u16 torque_temp_high_limit(void) {
|
|
u16 torque_temp_high_limit(void) {
|
|
@@ -124,11 +129,11 @@ u16 vbus_current_vol_lower_limit(void) {
|
|
|
for(int i = 0; i < ARRAY_SIZE(vol_under_lim); i++) {
|
|
for(int i = 0; i < ARRAY_SIZE(vol_under_lim); i++) {
|
|
|
limter_t *lim = vol_under_lim + i;
|
|
limter_t *lim = vol_under_lim + i;
|
|
|
u16 lim_value = _vol_limiter(vol, lim);
|
|
u16 lim_value = _vol_limiter(vol, lim);
|
|
|
- if (lim_value != CURRENT_LIMIT_NONE) {
|
|
|
|
|
|
|
+ if (lim_value != HW_LIMIT_NONE) {
|
|
|
mc_set_critical_error(FOC_CRIT_UN_Vol_Err);
|
|
mc_set_critical_error(FOC_CRIT_UN_Vol_Err);
|
|
|
return lim_value;
|
|
return lim_value;
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
mc_clr_critical_error(FOC_CRIT_UN_Vol_Err);
|
|
mc_clr_critical_error(FOC_CRIT_UN_Vol_Err);
|
|
|
- return CURRENT_LIMIT_NONE;
|
|
|
|
|
|
|
+ return HW_LIMIT_NONE;
|
|
|
}
|
|
}
|