Purpose (from IV):
A power distribution board is necessary to supply power to the various subsystems in the vehicle, including other microcontrollers. This board performs distribution, startup, shutdown and emergency shutdown as required in regulations. In addition to supporting powering the boards, it also powers components directly, such as telemetry, the horn, camera and others.The current electrical system design requires two instances of Power Distribution boards, a front PD and a rear PD. In MSXIV, the same firmware was flashed to both boards, with a startup condition used to determine which configuration was to be processed.
Essentially, power distribution has a set of outputs which it can turn on or off based on the state of the system. These outputs include:
Driver Lights and Indicators:
Right/left signal lights (located on front, side and rear of the car)
Hazard lights (same as those used for right/left)
BPS Fault strobe (Front PD only)
Part of driver display, if BPS fault occurs must pulse at 60-120hz
Horn (Front PD only)
Daytime running lights (Front PD only)
Brake lights (Rear PD only)
Cameras/Displays
Fans for driver ventilation
MCU Power - powers our boards:
Front PD:
Centre Console
Pedal
Steering
Rear PD
BMS
MCI
Solar Sense
Updated Output list (Jul 4, 2023)
Code Block |
---|
typedef enum {
// Outputs for power distribution
// Dual LS per pair
FRONT_OUTPUT_CENTRE_CONSOLE = 0,
REAR_OUTPUT_SOLAR_SENSE,
FRONT_OUTPUT_PEDAL,
FRONT_OUTPUT_STEERING,
FRONT_OUTPUT_LEFT_FRONT_TURN_LIGHT,
FRONT_OUTPUT_RIGHT_FRONT_TURN_LIGHT,
FRONT_OUTPUT_DAYTIME_RUNNING_LIGHTS,
REAR_OUTPUT_BRAKE_LIGHT,
REAR_OUTPUT_BPS_STROBE_LIGHT,
REAR_OUTPUT_FAN_1,
// Dual LS per each, 3x spares
REAR_OUTPUT_BMS,
REAR_OUTPUT_MCI,
FRONT_OUTPUT_CAMERA_DISPLAY,
NUM_OUTPUTS,
} Output; |
SW Components:
Modules
Master Task
Lights FSM task
Power Sequence FSM task
Gpio Output controller/configs
Periodic Current read (TBD)
BPS_watcher
Master Task
Responsible for handling:
CAN functionality
FSM Cycles
Horn (Front PD only) - Triggered on Horn event over can from steering*
Brake lights (Rear PD only) - Triggered on brake event from pedal*
*NOTE: Brake and horn could be moved to power FSM, but makes sense to have them in main loop as they will always need to work, and this will make them extra responsiveIt maintains a power state, regulated by the power FSM which takes one of two states:
POWER_OFF
This is the first state of the car, when the AUX battery is initially connected. We must power:
Power distribution (this is on by default, we don’t have to use the board to power itself on)
BMS (DCDC enable only)
Centre console
POWER_ON
In this state the relays are closed and the main batteries are connected. The motors are not connected so we are not able to drive. We transition to this state upon receiving a message from centre console with a POWER_EVENT_BTN or POWER_EVENT_BRAKE_AND_BTN. This state is mainly used for charging
We must power:
BMS (DCDC Enable + Aux Enable)
Centre console
Pedal (for brake readings)
Steering (for indicators)
Solar 1 and 2
POWER_DRIVE
In this state, we complete MCI precharge, connect the motors, and indicate we are ready to drive:
We must power (in addition to the board above):
BMS (DCDC Enable + Aux Enable)
Pedal (for brake readings)
Steering (for indicators)
Solar 1 and 2
MCI
DRL lights
Camera
RPI Display
Driver Fans
Telemetry
POWER_FAULT
Must have BMS relays (BMS_AUX_EN) disabled, and MCI turned off. We should have access to our indicators and brake lights:
BMS (DCDC Enable)
Centre console
Pedal (for brake readings)
Steering (for indicators)
Additionally PD controls a few other outputs separate from the main power states:
Left/right turn signals:
Monitors steering messages and centre console message for turn signals and hazard indicator
Brake Light
On when brake reading from pedal > 0
BPS Fault Indicator
When BPS Fault occurs
Lights FSM
The lights FSM is responsible for handling the indicator light functionality for the turn signals, hazard lights and the fault indicators. Its inputs are steering eventsindicator states, received in CAN messages from the steering board, as well as BPS fault indicatorshazard value from Centre console. It has the following state diagram:
Note: The BPS fault indicator is no longer handled by Lights FSM
Transition events:
Left signal event (OFF/ON)
Triggered by left turn indicator on steering
Right Signal event (OFF/ON)
Triggered by Right turn indicator on steering
Hazard Event (OFF/ON)
Triggered by hazard button on steering
BPS Fault Event
Triggered by receiving a BPS_HEARTBEAT message with fault condition
Triggered if we don’t receive BPS Heartbeat after a predetermined amount of time (Comms failure)
Centre Console
States:
Init State
FSM is initialized into this state, and it it the default state of operation
It does not transition unless it received a steering event or a fault event
Left Signal
Periodically toggle left signal output light
Right Signal
Periodically toggle right signal output light
Hazard
Periodically toggle both right and left signal output lights
BPS Fault
Strobe BPS fault indicator
Trigger Hazard lights (toggle both right/left signals lights)
Signal power sequence FSM to begin shutdown
(No Longer Handled in lights FSM)
Power Sequence FSM
The Power Sequence FSM is responsible for handling what gets power in different power states of the car. Based on inputs from the rest of the system, and state changes from power select, it will alter the source of power and be responsible for turning on and off different boards as needed. It receives as inputs CAN messages which indicate power events
State Diagram:
Transition events (Received over CAN from Center Console):
Power Main Driver BMS
First iteration of power on, only key indicators enabled
May be removed, as we no longer have a driver display
Power Main Everything on
Turn on all boards, enable the system
Power Aux Everything on
On BPS fault, we need to switch from main power to aux power
Enable only necessary systems
Power Everything Off
BPS Fault Event
Triggered by receiving a BPS_HEARTBEAT message with fault condition
Triggered if we don’t receive BPS Heartbeat after a predetermined amount of time (Comms failure)
States:
Init State
Only Centre console and pedal are on
Driver Controls
Turns on all displays
TBD - May be able to remove
Activated if power pressed w/o brake
Power Main Everything on
Powers on all systems (boards, cameras, Daytime running lights (Front PD only))
Main Operation
State of normal operation. Will execute output function every iteration as long as no other state change has occurred
Responsible for
Fan Control - front and rear PD
Checking for state change
General Master task format:
Code Block |
---|
MasterTask() {
init_fsm(lights);
init_fsm(power_sequence);
while(true) {
run_can_rx_cycle();
update_horn();
update_brake_lights;
run_lights_cycle();
run_power_sequence_cycle();
run_can_tx_cycle();
}
} |
Broadcaster
Module to broadcast relevant information from power distribution to the rest of the system
Expand
title | MSXIV Design Notes (Ignore unless you’re mitchell): |
---|
Module Seperation:
bps_watcher - Watches for the BPS_HEARTBEAT to make sure that no fault has occured
can_rx_event_mapper_config - Standard configurations for can_rx_event_mapper
can_rx_event_mapper - Maps CAN messages to power distribution events
current_measurement_config - Standard configurations for current_measurement
current_measurement - Periodically reads current from load switches and exposes global storage
front_uv_detector - Checks if undervoltage cutoff has occurred on front PD and sends a CAN message-Own board in MSXVmain - Initializes all other modules
output_config - Standard configurations for output
output - General-purpose module for manipulating the outputs that power distribution controls
pd_fan_ctrl - Control fans for front and rear power distro via ADT7476A
pd_gpio_config - Standard configurations for pd_gpio
pd_gpio - Receive events and set the PCA9539R GPIO pin states as specified
publish_data_config - Standard configurations for publish_data
publish_data - Publishes current measurements over CAN as generated by current_measurement
rear_strobe_blinker - Blinks the strobe light, controlled by PD_STROBE_EVENT
Main Functionality
BPS Watcher
Need to have timeout for BPS Heartbeat message
Unpack CAN, check for error - If a fault has occurred, we need to enter the Fault state, and go to aux power
Can Rx Events
Will be receiving messages in the main loop/parse inputs in FSM
Needs to act on messages and execute functionality
Current Measurement
Periodically read from load switches/analog inputs, act based on this
Output
Abstraction over all outputs that are connected to PD
Items can be turned off/on, and some provide current draw measurements
Fan Control
Drive fans based on potentiometers/thermistors
PD Gpio
Writes Gpio states based on received events
Publish Data
Puts necessary messages on CAN BUS
Rear Strobe Blinker
CAN Rx messages
Front:
MESSAGE_LIGHTS
EE_LIGHT_TYPE_DRL
EE_LIGHT_TYPE_SIGNAL_RIGHT
EE_LIGHT_TYPE_SIGNAL_LEFT
EE_LIGHT_TYPE_SIGNAL_HAZARD
POWER_ON_MAIN_SEQUENCE
EE_POWER_MAIN_SEQUENCE_TURN_ON_DRIVER_BMS
PD_POWER_MAIN_SEQUENCE_EVENT_TURN_ON_EVERYTHING
POWER_ON_AUX_SEQUENCE
EE_POWER_AUX_SEQUENCE_TURN_ON_EVERYTHING
SYSTEM_CAN_MESSAGE_POWER_OFF_SEQUENCE
EE_POWER_OFF_SEQUENCE_TURN_OFF_EVERYTHING
Rear:
MESSAGE_LIGHTS
EE_LIGHT_TYPE_BRAKES
EE_LIGHT_TYPE_STROBE
EE_LIGHT_TYPE_SIGNAL_RIGHT
EE_LIGHT_TYPE_SIGNAL_LEFT
EE_LIGHT_TYPE_SIGNAL_HAZARD
POWER_ON_MAIN_SEQUENCE
EE_POWER_MAIN_SEQUENCE_TURN_ON_DRIVER_BMS
PD_POWER_MAIN_SEQUENCE_EVENT_TURN_ON_EVERYTHING
POWER_ON_AUX_SEQUENCE
EE_POWER_AUX_SEQUENCE_TURN_ON_EVERYTHING
SYSTEM_CAN_MESSAGE_POWER_OFF_SEQUENCE
EE_POWER_OFF_SEQUENCE_TURN_OFF_EVERYTHING
PD Events to outputs:
GPIO:
DRIVER_DISPLAY
STEERING,
CENTRE_CONSOLE,
DRL,
PEDAL,
HORN,
BRAKE_LIGHT,
STROBE,
SIGNAL_LEFT,
SIGNAL_RIGHT,
SIGNAL_HAZARD,
NUM_PD_GPIO_EVENTS,
Rear Strobe Blinker:
STROBE
Lights FSM
SIGNAL_LEFT
SIGNAL_RIGHT
SIGNAL_HAZARD
SYNC_EVENT_LIGHTS
Power Main sequence (also handled by gpio
MAIN_TURN_ON_DRIVER_DISPLAY_BMS
MAIN_TURN_ON_EVERYTHING
AUX_TURN_ON_EVERYTHING
POWER_OFF_TURN_OFF_EVERYTHING
ICs:
BTS7040
Front Power Distribution Powers:
Steering
Centre Console
Pedal
Front Lights
Dashboard Indicator
Horn
Code Block |
---|
enum {
POWER_OFF,
TRANSMIT_BMS_CLOSE_RELAYS
POWER_ON,
TURN_ON_DRIVE_OUTPUTS,
POWER_DRIVE,
} PowerFSMState; |
Fault Conditions
We can enter a fault under 3 conditions, and we should be checking these conditions in every state:
Loss of communication with BMS
Receive a non-zero fault value from BMS
Soft-Short Fault
Current values received from BMS/MCI/Solar do not match within ~2A
In a fault condition, we need to
Cut the power to the BMS relays (turning off BMS_AUX_EN)
Make sure MCI is off
Turn on the BPS fault indicator
State Diagram
POWER_OFF:
Output:
Update power state CAN message
Set Output State to be POWER_OFF (only BMS + Centre Console Powered)
Cut power to BMS relays (BMS_AUX_ENABLE not enabled), which is handled by above
Input:
Check for the following Transition Criteria
POWER_BTN or POWER_BTN_AND_BRAKE event received from Centre console
TRANSMIT_BMS_CLOSE_RELAYS
Output:
Sets Output Group to POWER_ON
Connects power to BMS relays (Enables BMS_AUX_EN) so that bms can close them
Update power state CAN message, which BMS will use to update the relay state
Input:
Waits for reply message from BMS with relay state closed, times out if not received
If above message received, confirm that power distribution is now using DCDC supply from batteries, if correct, transition, otherwise go back to POWER_OFF
POWER_ON
Output:
Sets Output Group to POWER_ON (if we’ve transitioned from POWER_DRIVE or TURN_ON_DRIVE_OUTPUTS)
Update power state CAN message
Input:
Checks for POWER_BTN_AND_BRAKE event to start transition to POWER_MAIN
Checks for POWER_BTN event to transition back to OFF
TURN_ON_DRIVE_OUTPUTS
Output:
Turns on the output group for POWER_DRIVE, namely MCI
Input:
Waits for a response back from MCI with a relay state == Closed, times out if it doesn’t arrive
On receiving power, MCI will begin precharge and close relays, and send a CAN message with the relay state
POWER_DRIVE:
Output:
Updates drive state in output CAN message
Input:
if (POWER_BTN or POWER_BTN_AND_BRAKE) transition back to POWER_ON
FAULT:
Output:
Disable BMS Relays
Set Output Group POWER_ON
Namely, this will disable MCI and other unecessary inputs
Start BPS Strobe
Broadcaster
Module to broadcast relevant information from power distribution to Centre Console for error tracking
TBD