Lights Control Software
The purpose of lights control boards is to receive instructions from the driver controls board through a CAN message and take action accordingly. There are two lights boards on the car. One board is located at the front and one at the back. The boards will use the same software. Thus, software needs to determine which board it's being operated on. The responsibilities of each board is as follows:
Front Board:
Front board controls the following peripherals:
- High Beams: Tesla headlights
- Low Beams:
- Left/Right Turn Indicators (Signals): Signals on the Tesla headlights.
- Side Left/Right Turn Indicators (Signals): Signal lights on the sides of the car
- Daytime Running Lights: These lights are on as long as the car is turned on.
- Horn
Rear Board:
As for the rear board:
- Brake Lights: There's a centre brake light, and a pair of brake lights on each side.
- Strobe Light: Blink the strobe light in case of emergency.
- Left/Right Turn Indicators (Signals): Inside of each pair of brake lights, is the signals.
Functional Block Diagram:
Modules:
- lights_can:
- Receive can messages
- Raise events.
- Has information about the type of board (Front or Rear).
- Sends sync message (only rear board).
- main: This module only contains a main loop where it gets the raised events from lights_can and passes them to the next three modules: strobe, simple_peripherals, and signals_fsm. Every module checks if it owns the event that is passed to it and processes it. If the event is not related to the module, the module ignores it.
- lights_simple_peripherals: Used for all the peripherals which have a simple on, or off state. These peripherals are: horn, high/low beams, and brake lights.
- lights_strobe: Uses a blinker object to blink the strobe light.
- lights_signals_fsm: Contains the FSM of the signals. Every often calls send_sync from lights_can to sync the two boards. Uses blinker for blinking the signals.
- lights_blinker: Basically handles all the overhead related to using soft timers.
- lights_gpio:
- Is the only module that knows about all the addresses.
- Can be thought of the only part where the boards actually take action?!
- strobe, signals_fsm, and simple_peripherals all call its lights_gpio_set() function to change the state of the lights.
Front Board GPIO Ports:
Light | Address | Type |
---|---|---|
Side Right Indicator | PB12 | |
Side Left Indicator | PB14 | |
Horn | PB11 | |
Right Turn | PB10 | |
Left Turn | PA9 | |
Right Low Beam | PB2 | |
Left Low Beam | PA8 | |
Right High Beam | PB1 | |
Left High Beam | PB15 | |
Right DRL (Daytime Running Light) | PB0 | |
Left DRL | PA10 | |
Front (if it's on) | PB13 | |
CAN RX | ||
CAN TX |
Rear Board GPIO Ports:
Light | Address | Type |
---|---|---|
Centre Brake | PB14 | |
Strobe Light | PB11 | |
Right Rear Brake | PB1 | |
Right Rear Outer Brake | PB2 | |
Right Rear Turn | PB10 | |
Right Rear Outer Turn | PB0 | |
Left Rear Brake | PB15 | |
Left Rear Outer Brake | PA8 | |
Left Rear Turn | PA9 | |
Left Rear Outer Turn | PA10 | |
Back (if it's off) | PB13 | |
CAN RX | ||
CAN TX |
Challenges:
Description | Solution |
---|---|
How to detect whether it's the front board or the rear board? | There will possibly be a gpio address that we'll be able to read from. |
How to sync both the front and the back board when blinking? The timer on both boards will not be identical so some communication needs to happen between the boards to make sure they're both blinking at the same time. | Implementation of this solution should be a module that's independent from the rest of the program. e.g: The state machine logic for signals and hazard should simply make function calls and not worry about keeping the boards in sync. One board probably will need to send a can message to the other board, and both boards will reset their timers. This doesn't have to happen too frequently, probably every couple seconds. |
Need to know which ones are active high/low | |
DRL vs low beam? (what's the difference? where does the message come from?) | |
Do I have to turn DRL on whenever my board turns on? | |
Do we have event for Reversing? | |
Each peripheral is active high/low? |