Add 10ms delay after closing relays
This commit is contained in:
parent
8b0ca85f3d
commit
e3a226be54
@ -12,6 +12,7 @@
|
|||||||
|
|
||||||
#include "stm32g441xx.h"
|
#include "stm32g441xx.h"
|
||||||
#include "stm32g4xx_hal.h"
|
#include "stm32g4xx_hal.h"
|
||||||
|
#include "stm32g4xx_hal_gpio.h"
|
||||||
|
|
||||||
#define TS_INACTIVE 0
|
#define TS_INACTIVE 0
|
||||||
#define TS_PRECHARGE 2
|
#define TS_PRECHARGE 2
|
||||||
@ -51,4 +52,8 @@ void AIR_Discharge_Position();
|
|||||||
void AIR_Active_Position();
|
void AIR_Active_Position();
|
||||||
void AIR_Error_Position();
|
void AIR_Error_Position();
|
||||||
|
|
||||||
|
typedef enum { RELAY_AIR_NEG, RELAY_AIR_POS, RELAY_PRECHARGE } Relay;
|
||||||
|
|
||||||
|
void Set_Relay_Position(Relay relay, GPIO_PinState position);
|
||||||
|
|
||||||
#endif /* INC_AIR_STATE_MASCHINE_H_ */
|
#endif /* INC_AIR_STATE_MASCHINE_H_ */
|
||||||
|
@ -7,7 +7,10 @@
|
|||||||
|
|
||||||
#include "AIR_State_Maschine.h"
|
#include "AIR_State_Maschine.h"
|
||||||
|
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
#include "stm32g4xx_hal.h"
|
#include "stm32g4xx_hal.h"
|
||||||
|
#include "stm32g4xx_hal_gpio.h"
|
||||||
|
|
||||||
DMA_HandleTypeDef* air_current_dma = {0};
|
DMA_HandleTypeDef* air_current_dma = {0};
|
||||||
DMA_HandleTypeDef* sdc_voltage_dma = {0};
|
DMA_HandleTypeDef* sdc_voltage_dma = {0};
|
||||||
@ -178,48 +181,67 @@ void Deactivate_TS(AIRStateHandler* airstate) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void AIR_Precharge_Position() {
|
void AIR_Precharge_Position() {
|
||||||
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
Set_Relay_Position(RELAY_PRECHARGE, GPIO_PIN_SET);
|
||||||
GPIO_PIN_SET);
|
Set_Relay_Position(RELAY_AIR_NEG, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
Set_Relay_Position(RELAY_AIR_POS, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_SET);
|
|
||||||
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
|
||||||
GPIO_PIN_RESET);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AIR_Inactive_Position() {
|
void AIR_Inactive_Position() {
|
||||||
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
Set_Relay_Position(RELAY_PRECHARGE, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_RESET);
|
Set_Relay_Position(RELAY_AIR_NEG, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
Set_Relay_Position(RELAY_AIR_POS, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_RESET);
|
|
||||||
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
|
||||||
GPIO_PIN_RESET);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AIR_Discharge_Position() {
|
void AIR_Discharge_Position() {
|
||||||
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
Set_Relay_Position(RELAY_PRECHARGE, GPIO_PIN_SET);
|
||||||
GPIO_PIN_SET);
|
Set_Relay_Position(RELAY_AIR_NEG, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
Set_Relay_Position(RELAY_AIR_POS, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_SET);
|
|
||||||
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
|
||||||
GPIO_PIN_RESET);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AIR_Active_Position() // TODO Deactivate Precharge after a while to
|
void AIR_Active_Position() // TODO Deactivate Precharge after a while to
|
||||||
// decrease current Consumption
|
// decrease current Consumption
|
||||||
{
|
{
|
||||||
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
Set_Relay_Position(RELAY_PRECHARGE, GPIO_PIN_SET);
|
||||||
GPIO_PIN_SET);
|
Set_Relay_Position(RELAY_AIR_NEG, GPIO_PIN_SET);
|
||||||
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
Set_Relay_Position(RELAY_AIR_POS, GPIO_PIN_SET);
|
||||||
GPIO_PIN_SET);
|
|
||||||
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
|
||||||
GPIO_PIN_SET);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AIR_Error_Position() {
|
void AIR_Error_Position() {
|
||||||
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
Set_Relay_Position(RELAY_PRECHARGE, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_RESET);
|
Set_Relay_Position(RELAY_AIR_NEG, GPIO_PIN_RESET);
|
||||||
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
Set_Relay_Position(RELAY_AIR_POS, GPIO_PIN_RESET);
|
||||||
GPIO_PIN_RESET);
|
}
|
||||||
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
|
||||||
GPIO_PIN_RESET);
|
void Set_Relay_Position(Relay relay, GPIO_PinState position) {
|
||||||
|
static GPIO_PinState neg = 0;
|
||||||
|
static GPIO_PinState pos = 0;
|
||||||
|
static GPIO_PinState precharge = 0;
|
||||||
|
// Add a small delay after closing relays in order to not draw too much
|
||||||
|
// current
|
||||||
|
switch (relay) {
|
||||||
|
case RELAY_AIR_NEG:
|
||||||
|
HAL_GPIO_WritePin(AIR_negative_Control_GPIO_Port, AIR_negative_Control_Pin,
|
||||||
|
position);
|
||||||
|
if (position == GPIO_PIN_SET && neg == GPIO_PIN_RESET) {
|
||||||
|
HAL_Delay(10);
|
||||||
|
}
|
||||||
|
neg = position;
|
||||||
|
break;
|
||||||
|
case RELAY_AIR_POS:
|
||||||
|
HAL_GPIO_WritePin(AIR_Positive_Control_GPIO_Port, AIR_Positive_Control_Pin,
|
||||||
|
position);
|
||||||
|
if (position == GPIO_PIN_SET && pos == GPIO_PIN_RESET) {
|
||||||
|
HAL_Delay(10);
|
||||||
|
}
|
||||||
|
pos = position;
|
||||||
|
break;
|
||||||
|
case RELAY_PRECHARGE:
|
||||||
|
HAL_GPIO_WritePin(PreCharge_Control_GPIO_Port, PreCharge_Control_Pin,
|
||||||
|
position);
|
||||||
|
if (position == GPIO_PIN_SET && precharge == GPIO_PIN_RESET) {
|
||||||
|
HAL_Delay(10);
|
||||||
|
}
|
||||||
|
precharge = position;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user