This repo contains all of the hardware for PILOT Drive - mainly KiCad schematic + PCB files, and the code used for the ATtiny85 functionality.
(TLDR) The features of the HAT are:
- Optocouplers to isolate & read the ACC +12v & Headlight 12v+ lines
- Via I2C the Raspberry Pi communicates with the ATtiny85 to set the shutdown time
- When there is no ACC +12v detected from the Pi or the ATtiny, the Pi begins a safe shutdown and the ATtiny begins a countdown (Longer than it would take the Pi to shutdown) to kill the power to the BAT +12v.
- The headlight detection optocoupler is connected to the RPi's GPIO pins
- An I2C connected RTC is included to allow the Pi to keep time without network connectivity.
- Input for general purpose external buttons
- (Mostly) Conforms to the standards of the Raspberry Pi HAT specifications, as it includes an ID EEPROM and follows most design specs, but more needs to be implemented
The original MKI HAT came & went. I would call it about 50% functional - as it kept time well and provided for a clean way to route power to the Pi, along with interface with buttons. It didn't work for it's original purpose though. This was due to a few reasons:
- Using tantalum caps instead of electrolytic for the power supply
- Needed decoupling caps!
- Switching the entire ground via an N-FET. Speaks for itself.
- Needed TVS diodes!
The MKII prototype was fab'd by PCBWay, and so far has proven to be fully functional! The new improvements did volumes for the usablity, debugging, and protection of the circuit & the Pi. If you're interested, come see it's debut at the 2023 Syracuse Maker Faire on April 1st!
Found in the "firmware" folder, the current C code is based on the ATtiny85 & it's Universal Serial Interface (USI). Using I2C, the Pi can communicate the the ATtiny (default slave address is 0x20) to send a one byte integer (<= 255). This single integer represents the time to wait before the ATtiny pulls the power on the entire circuit after it detects the vehicle power off.
As always the firmware is a WIP, and the C version isn't fully functional. I can't quite clamp why, but at the time of writing the second ACK from the ATtiny (after the one byte int) always fails. Addressing works & ACKS, the ATtiny recieves the timeout number and functions with it, but the master sees it as a failed transmission. I feel like I'm close to a fix, but stuck now.
The original firmware was written in Arduino with TinyWireS, but I believed getting a little more "bare metal" would've allowed for a lot more (needed) C & embedded learning, and allowing for quick speeds. That code can be found under "legacy" in the "firmware" folder for use until the C version is completed & smoothed over.
This firmware requires the avrdude toolchain to flash the ATtiny. With avrdude installed and an ICSP programmer connected to your ATtiny & computer, the only step left is to configure the following Makefile variables:
PORT
: The serial port the ICSP device is connected to, defaults to/dev/ttyUSB0
AVRDUDE_CONF
: The path to your avrdude config, defauls to/etc/avrdude/avrdude.conf
CLK_SPEED
: Only configure if using an ATtiny85 clock speed other than 8 MHz.
This will be integrated in the PILOT Drive software, but an extremely simple Python script can be made to send the required timeout to a specified address, as can be seen in the example below (tested on an RPi 4):
import smbus
addr = 0x20 # Send to address 0x20
time = 15 # A timeout of 15 seconds
bus = smbus.SMBus(1)
bus.write_byte(addr, time)
At the time of writing, this script will seemingly fail, as it can't recieve a proper ACK from the ATtiny. Regardless, the ATtiny will recieve the time and respond accordingly.
NOTE: This guide assumes I2C has been enabled via sudo raspi-config
To connect the Raspberry Pi to the HAT's I2C RTC, execute the following commands on the Pi:
echo -e "\n# Configure the DS1307 PILOT Drive HAT\ndtoverlay=i2c-rtc,ds1307" | sudo tee -a /boot/config.txt
sudo reboot
After reboot, continue with the following:
# Ensure a "UU" appears
sudo i2cdetect -y 1
# Remove fake-hwclock
sudo apt -y remove fake-hwclock
sudo update-rc.d -f fake-hwclock remove
In /lib/udev/hwclock-set
, comment out the following lines:
if [ -e /run/systemd/system ] ; then
exit 0
fi
Write to the hardware clock:
# Ensure date/time is correct
date
# Write to the RTC
sudo hwclock -w
# Ensure hardware clock is correct
sudo hwclock -r
- If building the HAT, "ID EEPROM" is recommended by Raspberry Pi Hat Standards but aren't required to make the circuit function.
- The schematic's +5v screw terminal in refers to an external 12v to 5v buck converter.
- KiCad library files are coming, along with 3D files for the components.
- If you're building this HAT or something similar, reach out! Would love to hear your stories.