REWORK README WIP
This commit is contained in:
parent
e845555063
commit
820e4af1a9
296
README.md
296
README.md
@ -1,149 +1,195 @@
|
|||||||
A Raspberry Pi-compatible PCB that extends the GPIO header with protected I/O, relays, and various features for versatile use in prototyping and project development.
|
# Raspberry Pi Extension board
|
||||||
|
|
||||||
|
A custom PLC-like system based on the Raspberry Pi.
|
||||||
|
With a custom interface board a raspberry pi is extended with protected I/O, bus systems, analog inputs and Relay or PWM outputs. All components including a display are housed in a custom designed enclosure.
|
||||||
|
|
||||||
|
The project is intended for versatile use in prototyping and project development.
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
# Notes
|
|
||||||
|
|
||||||
## interface-board issues noticed when soldering
|
### Photo of all hardware components
|
||||||
- [x] digital in TVS diode footprint: dia is larger -> rotate one/space + 1.5mm drill
|
<p align="center">
|
||||||
- [x] make diodes pwm larger hole
|
<img src="doc/photos/all-components.jpg" alt="All Components (Disassembled)" width="75%"/>
|
||||||
- [x] make pitch buzzer larger
|
</p>
|
||||||
-
|
|
||||||
|
|
||||||
## interface-board issues at first test
|
|
||||||
- analog leds vs terminal: CH0 and CH1 swapped (first, second terminal)
|
|
||||||
-> renamed nets and added notes
|
|
||||||
- analog leds vs terminal: CH2 and CH3 swapped (third fourth terminal)
|
|
||||||
-
|
|
||||||
- CH1 and CH7 led on
|
|
||||||
|
|
||||||
|
|
||||||
## Power supply board
|
---
|
||||||
FIXME: barrel-connector wrong polarity
|
|
||||||
-> change housing (connected via wires)
|
|
||||||
-> fix layout, schematic
|
|
||||||
|
|
||||||
|
|
||||||
|
# Repository Content
|
||||||
# RPI Specs (Zero, 3+)
|
- **KiCad Projects**: 3 KiCad projects with schematics and PCB layouts for the custom pcbs created.
|
||||||
- Available (old) Pi: Raspberry Pi 2 Model B v1.1
|
- **Housing**: Custom enclosure design for PCBs and Raspberry Pi created in FreeCAD.
|
||||||
- GPIO
|
- **Software/Firmware**: Python scripts for operating and testing the PCB features (WIP).
|
||||||
- Low: 0.9V
|
|
||||||
- High: 1.6V
|
|
||||||
- Input current: 5uA
|
|
||||||
- Input capacitance: 5pF
|
|
||||||
- Output Current +-17mA
|
|
||||||
- Pullup / Pulldown 50-65k
|
|
||||||
- EEPROM GPIO0 GPIO1, leave unused
|
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
# Feature Ideas
|
|
||||||
- [x] Temperature control
|
|
||||||
- fan
|
|
||||||
- auto turn on
|
|
||||||
- temp sensor
|
|
||||||
- ~~turn on via gpio~~
|
|
||||||
|
|
||||||
|
|
||||||
## Supply
|
# Features Overview
|
||||||
- Input protection
|
This project provides:
|
||||||
- [x] TVS
|
- Protected GPIO I/O for Raspberry Pi.
|
||||||
- [x] reverse polarity (polyfuse will trigger)
|
- Various analog inputs
|
||||||
- [x] Fuse (5A polyfuse)
|
- Flexible power supply options. (3.3 V, 5 V, -5 V, 12 V, 24 V outputs)
|
||||||
- [x] buffer
|
- Relay and MOSFET control.
|
||||||
- [x] Pass through power supply
|
- Integrated LEDs for status indication.
|
||||||
- [x] 3.3V, 5V, 12V, 24V Regulator
|
- RS485, I2C, SPI, and UART bus communication.
|
||||||
|
|
||||||
- [x] power by barrel connector (24V 5A)
|
Detailed features of each PCB are described in the respective sections below.
|
||||||
- ~~power by usb~~ [not allowed]
|
|
||||||
- ~~Switch between power by USB or power supply?~~
|
---
|
||||||
- ~~power by battery~~ [dropped]
|
|
||||||
- liion cell connector
|
# Designed PCBs
|
||||||
- BMS / charge controller
|
|
||||||
- measure battery voltage
|
## 1. **Raspberry Pi Interface Board**
|
||||||
- USB charging port
|
This board connects to the Raspberry Pi via a 40-pin ribbon cable and provides protected GPIO extensions and versatile input/output features.
|
||||||
|
|
||||||
|
### Photo
|
||||||
|
<img src="doc/photos/rpi-interface-board.jpg" alt="Raspberry Pi Interface Board" width="60%"/>
|
||||||
|
|
||||||
|
### Features
|
||||||
|
**Inputs**:
|
||||||
|
- **8x Digital Inputs**:
|
||||||
|
- Wide continous voltage range (-1.7V to 120V), idea: compatible with 3V and 24V devices.
|
||||||
|
- TVS diodes for ESD and spike protection.
|
||||||
|
- Reverse polarity protection
|
||||||
|
- Isolated with optocouplers.
|
||||||
|
- Optional low-pass filters (toggle via DIP switches).
|
||||||
|
|
||||||
|
- **8x Analog Inputs
|
||||||
|
- Different fixed range inputs:
|
||||||
|
- 2x 0 - 3.3 V
|
||||||
|
- 2x 0 - 5 V
|
||||||
|
- 1x 0 - 12 V
|
||||||
|
- 1x 0 - 24 V
|
||||||
|
- 2x 0 - 20 mA
|
||||||
|
- Overvoltage protection with clamping diodes.
|
||||||
|
- Optional low-pass filters (toggle via DIP switches).
|
||||||
|
|
||||||
|
**Outputs**:
|
||||||
|
- 1x onboard buzzer.
|
||||||
|
- 2x 16A relays.
|
||||||
|
- 2x high-power MOSFETs (N-channel, max 55V, 33A continuous, 160A pulsed).
|
||||||
|
- 8x digital outputs (via shift register):
|
||||||
|
- Low-power (30mA push-pull) and high-power (500mA open-drain) outputs.
|
||||||
|
- Buzzer and relays connected to channels 6-8, with enable/disable switches.
|
||||||
|
- Note: Outputs are **not short-circuit proof**.
|
||||||
|
|
||||||
|
**General**:
|
||||||
|
- WAGO spring-loaded terminals for easy wiring.
|
||||||
|
- JST connectors for external LEDs for all inputs and outputs indicate the current pin state.
|
||||||
|
|
||||||
|
**Bus Communication**:
|
||||||
|
- RS485 (TVS protection, idle pullup/pulldown, 120Ω terminator).
|
||||||
|
- UART (unprotected).
|
||||||
|
- I2C (TVS diodes, 2.2k pullups).
|
||||||
|
- SPI (unprotected).
|
||||||
|
Note: Either RS485 or UART can be used at the same time (select with jumpers)
|
||||||
|
|
||||||
|
### Schematic and Layout
|
||||||
|
<p align="center">
|
||||||
|
<a href="pi-interface-board_v1.0/export/schematic_interface-board.pdf">
|
||||||
|
<img src="pi-interface-board_v1.0/export/schematic_interface-board.svg" width="49%" alt="Schematic"/>
|
||||||
|
</a>
|
||||||
|
<img src="pi-interface-board_v1.0/export/layout_interface-board.png" width="49%" alt="PCB Layout"/>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
|
||||||
## IO
|
---
|
||||||
- Input
|
|
||||||
- GPIO
|
|
||||||
- [x] wide voltage range (-1.7 to 120V)
|
|
||||||
- [x] TVS
|
|
||||||
- [x] reverse polarity (-1.73V max)
|
|
||||||
- [x] Low pass filter
|
|
||||||
- [x] Optocoupler input
|
|
||||||
- [x] ADC
|
|
||||||
- external IC
|
|
||||||
- ~~multiplexer?~~
|
|
||||||
- protection
|
|
||||||
- scale input voltage
|
|
||||||
- fixed inputs: 24V 12V 5V 3.3V
|
|
||||||
- 20mA input
|
|
||||||
- ~~trim potentiometer?~~
|
|
||||||
- Output
|
|
||||||
- [x] Relay
|
|
||||||
- [x] Mosfet
|
|
||||||
- [x] Optocoupler output
|
|
||||||
- [ ] GPIO with over current protection
|
|
||||||
- [ ] GPIO level shift (24V output)
|
|
||||||
- [x] PWM pins
|
|
||||||
- [x] shift register
|
|
||||||
- [ ] DAC
|
|
||||||
|
|
||||||
- [x] LEDS indicate I/O state
|
|
||||||
- [ ] Testpoints
|
|
||||||
- [x] ESD protection (tvs diodes uart, i2c...)
|
|
||||||
|
|
||||||
|
|
||||||
## Bus
|
## 2. **Power Supply Board**
|
||||||
- [x] UART/RS485
|
Creates different voltages from supplied 24V. Supply for the rpi interface board as well as several terminals for variable use (connect sensors, devices etc to the housing)
|
||||||
- [ ] RS232 Connector
|
|
||||||
- [x] I2C Pullup
|
### Photo
|
||||||
- [x] SPI
|
<img src="doc/photos/power-supply-board.jpg" alt="Power Supply Board" width="50%"/>
|
||||||
- [ ] CAN
|
|
||||||
- ~~Serial to usb (if Arduino)~~
|
### Features
|
||||||
- ~~OWB default GPIO4~~
|
**Input**:
|
||||||
|
- 24V 5A barrel plug.
|
||||||
|
- 5A self-resetting polyfuse.
|
||||||
|
- Reverse polarity protection.
|
||||||
|
|
||||||
|
**Output**:
|
||||||
|
- 3.3V, 3A (buck converter).
|
||||||
|
- 5V, 5A (buck converter).
|
||||||
|
- -5V, 20mA (charge pump).
|
||||||
|
- 12V, 3A (buck converter).
|
||||||
|
- 24V (supply voltage filtered).
|
||||||
|
|
||||||
|
**Fan Control:**
|
||||||
|
- 2x connector for 10k NTC.
|
||||||
|
- Threshold adjustable (trim poti).
|
||||||
|
- Hysteresis adjustable (trim poti).
|
||||||
|
- select between 5V or 12V Fan.
|
||||||
|
|
||||||
|
**General**:
|
||||||
|
- Spring-loaded terminals for each voltage.
|
||||||
|
- Combined internal terminals for all voltages.
|
||||||
|
|
||||||
|
### Schematic and Layout
|
||||||
|
<p align="center">
|
||||||
|
<a href="power-supply-board_v1.0/export/schematic_power-supply.pdf">
|
||||||
|
<img src="power-supply-board_v1.0/export/schematic_power-supply.svg" width="55%" alt="Schematic"/>
|
||||||
|
</a>
|
||||||
|
<img src="power-supply-board_v1.0/export/layout_power-supply.png" width="44%" alt="PCB Layout"/>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 3. **LED Boards**
|
||||||
|
Small PCBs with LEDs, resistors, and mounting holes for housing indicators.
|
||||||
|
|
||||||
|
### Photo
|
||||||
|
<img src="doc/photos/led-boards.jpg" alt="LED Boards" width="60%"/>
|
||||||
|
|
||||||
|
### Boards
|
||||||
|
1. 2x 5mm LEDs for relays.
|
||||||
|
2. 2x 5mm LEDs for PWM outputs.
|
||||||
|
3. 8x 3mm yellow LEDs for analog inputs.
|
||||||
|
4. 8x 3mm orange LEDs for digital inputs.
|
||||||
|
5. 8x 3mm red LEDs for digital outputs.
|
||||||
|
|
||||||
|
### Schematic and Layout
|
||||||
|
<p align="center">
|
||||||
|
<a href="led-boards_v0.1/export/schematic_led-boards.pdf">
|
||||||
|
<img src="led-boards_v0.1/export/schematic_led-boards.svg" width="48%" alt="Schematic"/>
|
||||||
|
</a>
|
||||||
|
<img src="led-boards_v0.1/export/layout_led-boards.png" width="51%" alt="PCB Layout"/>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
|
||||||
## UI
|
---
|
||||||
- Input [dropped]
|
|
||||||
- Buttons
|
|
||||||
- DIP switches?
|
|
||||||
- Temperature sensor
|
|
||||||
- Encoder
|
|
||||||
- Potentiometer
|
|
||||||
- Output
|
|
||||||
- [ ] Display [RPI display pending]
|
|
||||||
- [x] Buzzer
|
|
||||||
- [x] LEDS
|
|
||||||
|
|
||||||
|
|
||||||
## Mechanical
|
# Software/Firmware
|
||||||
- [x] Barrel plug (24V 3A supply)
|
Python code for operating the extension PCBs (e.g., GPIO pins, shift registers, ADC, and bus communication). This section is a work in progress (WIP), and example scripts will be added as development continues.
|
||||||
- ~~Screw terminals~~
|
|
||||||
- [x] spring loaded?
|
|
||||||
- ~~pass through all pins?~~
|
|
||||||
|
|
||||||
## Housing
|
|
||||||
- RPI ports
|
|
||||||
- banana sockets for power out
|
|
||||||
- screw terminal exposed
|
|
||||||
- buttons, leds: need to open up?
|
|
||||||
- BNC? []
|
|
||||||
|
|
||||||
|
|
||||||
## Other
|
---
|
||||||
- Extension board with multiplexer
|
|
||||||
- Breadboard compatible?
|
|
||||||
- SD Card
|
|
||||||
- ~~Onboard MCU for standalone use?~~
|
|
||||||
- ~~separate bought MCU via i2c for additional GPIO, DAC, ADC in one~~
|
|
||||||
|
|
||||||
|
|
||||||
## Questions
|
# Housing
|
||||||
- what analog input ranges (Voltage, Count)
|
Custom-designed enclosure includes:
|
||||||
- RS232 RS485 SPI, IIC actually necessary? examples
|
- Ports for Raspberry Pi.
|
||||||
- CAN to second SPI?
|
- Banana sockets for power outputs.
|
||||||
- 8x shift register outputs, 0.5A open drain or 7mA tristate
|
- Exposed screw terminals.
|
||||||
- 2x PWM 30A enough?
|
- Openings for buttons and LEDs.
|
||||||
- max used PWM freq? (drop opto if >80khz)
|
- Mounts for all PCBs and wiring.
|
||||||
|
|
||||||
|
<img src="doc/images/3d-model_housing.png" width="51%" alt="3d-model"/>
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
# Dropped Features
|
||||||
|
The following ideas were considered but not implemented:
|
||||||
|
- UI Input Elements:
|
||||||
|
- Buttons, DIP switches, temperature sensors, encoders, or potentiometers.
|
||||||
|
- USB or battery-powered operation:
|
||||||
|
- Battery packs with BMS and voltage measurement.
|
||||||
|
- Li-ion cell holders.
|
||||||
|
|
||||||
|
---
|
||||||
|
Loading…
x
Reference in New Issue
Block a user