PCB for ULX3S FPGA R&D board. Fork Sand fork of https://github.com/emard/ulx3s https://www.forksand.com/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Emard 6b61c63c66
gerbers update
8 years ago
doc SD card slot info 8 years ago
footprints 32768Hz crystal ABS25 footprint now correct 8 years ago
pic update jpegs 8 years ago
plot gerbers update 8 years ago
spice SPICE: increasing RC load constants to simulate delayed response 8 years ago
.gitignore use new footprint for crystal oscillator 9 years ago
README.md USB move 0.635 mm up 8 years ago
analog.bak 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
analog.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
blinkey.bak DIP switch moved to the right, near RAM. 8 years ago
blinkey.sch buttons footprints correct now 8 years ago
flash.bak 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
flash.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
fp-lib-table use new footprint for crystal oscillator 9 years ago
gpdi.bak buttons footprints correct now 8 years ago
gpdi.sch Fab layer, moving values to avoid overlap writings 8 years ago
gpio.bak FPGA direct-to-pin Hackish USB transciver 27 ohm + 3.6 V zener 8 years ago
gpio.sch DIP switch moved to the right, near RAM. 8 years ago
power.bak buttons footprints correct now 8 years ago
power.sch buttons footprints correct now 8 years ago
ram.bak 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
ram.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
sdcard.bak 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
sdcard.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
ulx3s-cache.lib Fab layer, moving values to avoid overlap writings 8 years ago
ulx3s-rescue.lib DIP switch moved to the right, near RAM. 8 years ago
ulx3s.bak schematic symbol for ADC MAX11123 8 years ago
ulx3s.kicad_pcb USB move 0.635 mm up 8 years ago
ulx3s.kicad_pcb-bak USB move 0.635 mm up 8 years ago
ulx3s.pro DIP switch moved to the right, near RAM. 8 years ago
ulx3s.sch schematic symbol for ADC MAX11123 8 years ago
usb.bak Fab layer, moving values to avoid overlap writings 8 years ago
usb.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
wifi.bak 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago
wifi.sch 433 MHz onboard antenna (need to uncover copper infill layers) 8 years ago

README.md

ULX3S PCB

This is work-in-progress place for putting some wishes of a small (94x51 mm) FPGA board.

Instead of describing in written, it is better explained when drawn in kicad:

kicad ulx3s.pro

Schematics is mostly complete. PCB routing is mostly complete too.

3D preview

TOP BOTTOM

Features

FPGA: Lattice ECP5 LFE5U-25F-6BG381C

USB: FTDI FT231XS (1Mbit JTAG and 3Mbit usbserial)

GPIO: All differential, PMOD-friendly

RAM: 32MB SDRAM MT48LC16M16

Flash: 8MB SPI flash S25FL164 for FPGA config

Storage: Micro-SD slot

LEDs: 10 (8 blink-LEDs, 2 USB leds)

Buttons: 6 (4 direction and 2 fire buttons)

Audio: 3.5 mm stereo jack

Video: GPDI connector with 3.3V-5V I2C bidirectional level shifter

Display: placeholder for 0.96-1.3" SPI OLED COLOR or B/W

WiFi+bluetooth: placeholder for ESP-32 (JTAG and serial over WiFi possible)

ADC: 8 channels, 12 bit, 1 MSa/s MAX11123

Power: 3 Switching voltage regulators: 1.2V, 2.5V, 3.3V

Clock: 25 MHz onboard, external differential clock input

Low power sleep: RTC clock wakeup, quartz and battery

GPDI is General Purpose Differential Interface, Electrically LVDS, mostly TMDS tolerant female receptacle more-or-less compatible with digital monitors/TVs

Todo

Make the prototype.

[x] Silkscreen Double outline for BGA chip
[ ] Silkscreen do not write over the solder pads
[ ] Silkscreen BGA names on ESP32 placeholder and 2.54 mm headers
[x] Silkscreen JTAG signal names on 6-pin 2.54 mm header
[x] Silkscreen remove OLED outline
[x] Solder stop mask must go inbetween all SMD chip pads
[x] External differential clock input at J1_33 +/-
[ ] Thinner copper, more spacing to SDRAM-FPGA
[ ] physically sprinkle VCC blocator capacitors under BGA
[ ] Values on silkscreen
[ ] Dedicated antenna pin
[ ] onboard 433 antenna (lower side, remove GND infill)
[x] Resistors for LEDs
[x] Move USB LEDs from bottom to top side
[ ] Improve SDRAM routing - use VIAs for closest pins
[x] Increase thickness of power lines (5V, 3.3V, 2.5V)
[x] Compile a f32c bitstream using the schematics
[x] Compile differential GPDI output
[x] Connect more lines from ESP-32 to FPGA
[x] Connect FPGA USB D+/D- with 1.5k pullup in USB 1.1 (full speed) mode
[x] FPGA USB add 27 ohm + 3.6 V zener
[x] Symmetrically place USB connectors left-right 
[ ] Jumpers to switch 2.5V/3.3V for left IO banks
[x] External JTAG header
[ ] Move JTAG 2.54 mm left
[ ] Move WiFi Disable jumper above the buttons
[x] Sprinkle 2.2uF capacitors on power lines
[ ] Spice simulation of power-up/shutdown network
[x] 27ohm D+/D- to FT231XS
[x] DIP switch (4 switches)
[x] MAX11123 ADC SPI
[x] I2C for RTC
[x] main usb connector on top side 
[ ] space screw to other parts
[x] move battery away from screw hole
[x] top layer GND fill
[x] R25 move away from oled screw hole
[ ] board cut off nothches inisde for space saving
[x] DIP switch to the right near RAM
[x] Move HDMI a bit closer to OLED
[x] 32768Hz oscillator footprint
[ ] SD card footprint wrong
[x] move USB 0.5-1mm more out
[ ] DIP SW PADS too narrow
[x] AUDIO jack footprint fits
[ ] AUDIO jack pin 4 not connected
[x] BTN footprint too small