clear OV/UV flags after trigger
This commit is contained in:
parent
a88f663afc
commit
dd0f755ae0
@ -42,6 +42,7 @@ HAL_StatusTypeDef amsCheckUnderOverVoltage(Cell_Module (*module)[N_BMS]);
|
|||||||
|
|
||||||
HAL_StatusTypeDef amsClearFlag();
|
HAL_StatusTypeDef amsClearFlag();
|
||||||
HAL_StatusTypeDef amsClearAux();
|
HAL_StatusTypeDef amsClearAux();
|
||||||
|
HAL_StatusTypeDef amsClearOVUV();
|
||||||
|
|
||||||
HAL_StatusTypeDef amsReadCellVoltages(Cell_Module (*module)[N_BMS]);
|
HAL_StatusTypeDef amsReadCellVoltages(Cell_Module (*module)[N_BMS]);
|
||||||
|
|
||||||
|
@ -294,6 +294,11 @@ HAL_StatusTypeDef amsClearFlag() {
|
|||||||
|
|
||||||
HAL_StatusTypeDef amsClearAux() { return writeCMD(CLRAUX, CMD_EMPTY_BUFFER, 0); }
|
HAL_StatusTypeDef amsClearAux() { return writeCMD(CLRAUX, CMD_EMPTY_BUFFER, 0); }
|
||||||
|
|
||||||
|
HAL_StatusTypeDef amsClearOVUV() {
|
||||||
|
uint8_t buffer[CMD_BUFFER_SIZE(6)] = {[0 ... CMD_BUFFER_SIZE(6) - 1] = 0xFF};
|
||||||
|
return writeCMD(CLOVUV, buffer, 6);
|
||||||
|
}
|
||||||
|
|
||||||
HAL_StatusTypeDef amsReadCellVoltages(Cell_Module (*module)[N_BMS]) {
|
HAL_StatusTypeDef amsReadCellVoltages(Cell_Module (*module)[N_BMS]) {
|
||||||
uint8_t rxbuffer[CMD_BUFFER_SIZE(CV_GROUP_A_SIZE)] = {};
|
uint8_t rxbuffer[CMD_BUFFER_SIZE(CV_GROUP_A_SIZE)] = {};
|
||||||
|
|
||||||
|
@ -99,10 +99,12 @@ ADBMS_DetailedStatus AMS_Idle_Loop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ((match = any(module.overVoltage))) {
|
if ((match = any(module.overVoltage))) {
|
||||||
|
amsClearOVUV();
|
||||||
return (ADBMS_DetailedStatus){ADBMS_OVERVOLT, match - 1};
|
return (ADBMS_DetailedStatus){ADBMS_OVERVOLT, match - 1};
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((match = any(module.underVoltage))) {
|
if ((match = any(module.underVoltage))) {
|
||||||
|
amsClearOVUV();
|
||||||
return (ADBMS_DetailedStatus){ADBMS_UNDERVOLT, match - 1};
|
return (ADBMS_DetailedStatus){ADBMS_UNDERVOLT, match - 1};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user