2020-08-23 09:00:17 -04:00
|
|
|
#
|
|
|
|
# This file is part of LiteX-Boards.
|
|
|
|
#
|
|
|
|
# Copyright (c) 2019 David Shah <dave@ds0.me>
|
|
|
|
# SPDX-License-Identifier: BSD-2-Clause
|
2019-07-09 10:50:26 -04:00
|
|
|
|
|
|
|
from litex.build.generic_platform import *
|
2022-11-05 03:07:14 -04:00
|
|
|
from litex.build.lattice import LatticeECP5Platform
|
2020-05-05 07:16:02 -04:00
|
|
|
from litex.build.lattice.programmer import OpenOCDJTAGProgrammer
|
2019-07-09 10:50:26 -04:00
|
|
|
|
|
|
|
# IOs ----------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
_io = [
|
2020-11-03 04:48:41 -05:00
|
|
|
# Clk / Rst
|
2019-07-09 10:50:26 -04:00
|
|
|
("clk100", 0, Pins("B29"), IOStandard("LVDS")), # [broken on rev1.0 (non diff pair)]
|
2020-04-09 14:02:02 -04:00
|
|
|
("clk12", 0, Pins("B3"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
("clkref", 0, Pins("E17"), IOStandard("LVCMOS33")),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# Leds
|
|
|
|
("user_led", 0, Pins("C26"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 1, Pins("D26"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 2, Pins("A28"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 3, Pins("A29"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 4, Pins("A30"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 5, Pins("AK29"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 6, Pins("AH32"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 7, Pins("AH30"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 8, Pins("AH28"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 9, Pins("AG30"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 10, Pins("AG29"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
("user_led", 11, Pins("AK30"), IOStandard("LVCMOS33"), Misc("PULLMODE=NONE")),
|
|
|
|
|
|
|
|
# Buttons
|
2020-04-09 14:02:02 -04:00
|
|
|
("user_btn", 0, Pins("Y32"), IOStandard("SSTL135_I")),
|
|
|
|
("user_btn", 1, Pins("W31"), IOStandard("SSTL135_I")),
|
2019-07-09 10:50:26 -04:00
|
|
|
("user_btn", 2, Pins("AD30"), IOStandard("SSTL135_I")),
|
|
|
|
("user_btn", 3, Pins("AD29"), IOStandard("SSTL135_I")),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# Switches
|
2019-07-09 10:50:26 -04:00
|
|
|
("user_dip", 0, Pins("AE31"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 1, Pins("AE32"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 2, Pins("AD32"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 3, Pins("AC32"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 4, Pins("AB32"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 5, Pins("AB31"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 6, Pins("AC31"), IOStandard("SSTL135_I")),
|
|
|
|
("user_dip", 7, Pins("AC30"), IOStandard("SSTL135_I")),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# Serial
|
2019-07-09 10:50:26 -04:00
|
|
|
("serial", 0,
|
|
|
|
Subsignal("rx", Pins("AM28"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("tx", Pins("AL28"), IOStandard("LVCMOS33")),
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# USB FIFO
|
|
|
|
("usb_fifo", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("dq", Pins("AM28 AL28 AM29 AK28 AK32 AM30 AJ32 AL30"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("txe_n", Pins("AM31"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("rxf_n", Pins("AJ31"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("rd_n", Pins("AL32"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("wr_n", Pins("AG28"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("siwu_n", Pins("AJ28"), IOStandard("LVCMOS33")),
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# DDR3 SDRAM
|
2020-07-17 06:03:37 -04:00
|
|
|
("dram_vtt_en", 0, Pins("E25"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
("ddram", 0,
|
|
|
|
Subsignal("a", Pins(
|
|
|
|
"E30 F28 C32 E29 F32 D30 E32 D29",
|
|
|
|
"D32 C31 H32 F31 F29 B32 D31"),
|
|
|
|
IOStandard("SSTL135_I")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("ba", Pins("H31 H30 J30"), IOStandard("SSTL135_I")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("ras_n", Pins("K31"), IOStandard("SSTL135_I")),
|
|
|
|
Subsignal("cas_n", Pins("K30"), IOStandard("SSTL135_I")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("we_n", Pins("J32"), IOStandard("SSTL135_I")),
|
|
|
|
Subsignal("cs_n", Pins("K29"), IOStandard("SSTL135_I")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("dm", Pins("R26 L27 Y27 U31"), IOStandard("SSTL135_I")),
|
|
|
|
Subsignal("dq", Pins(
|
|
|
|
" V26 R27 V27 T26 U28 T27 T29 U26",
|
|
|
|
" P27 K28 P26 L26 K27 N26 L29 K26",
|
|
|
|
"AC27 W28 AC26 Y26 AB26 W29 AD26 Y28",
|
|
|
|
" T32 U32 P31 V32 P32 W32 N32 U30"),
|
|
|
|
IOStandard("SSTL135_I"),
|
|
|
|
Misc("TERMINATION=75")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("dqs_p", Pins("R29 N30 AB28 R32"), IOStandard("SSTL135D_I"),
|
|
|
|
Misc("TERMINATION=OFF"),
|
|
|
|
Misc("DIFFRESISTOR=100")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("clk_p", Pins("L31"), IOStandard("SSTL135D_I")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("cke", Pins("K32"), IOStandard("SSTL135_I")),
|
|
|
|
Subsignal("odt", Pins("J29"), IOStandard("SSTL135_I")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("reset_n", Pins("L32"), IOStandard("SSTL135_I")),
|
|
|
|
Misc("SLEWRATE=FAST"),
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# RGMII Ethernet
|
2019-07-09 10:50:26 -04:00
|
|
|
("eth_clocks", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("tx", Pins("A15")),
|
|
|
|
Subsignal("rx", Pins("C17")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("ref", Pins("A17")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
|
|
|
("eth", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("rst_n", Pins("D16")),
|
|
|
|
Subsignal("int_n", Pins("E16")),
|
|
|
|
Subsignal("mdio", Pins("F17")),
|
|
|
|
Subsignal("mdc", Pins("B17")),
|
|
|
|
Subsignal("rx_ctl", Pins("A16")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("rx_data", Pins("C16 B16 B14 F16")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("tx_ctl", Pins("D15")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("tx_data", Pins("A14 F15 C15 C14")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# I2C Clock Generator
|
2019-07-09 10:50:26 -04:00
|
|
|
("clkgen", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("sda", Pins("C22")),
|
|
|
|
Subsignal("scl", Pins("A22")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("sd_oe", Pins("A2")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# PCIe
|
2019-07-09 10:50:26 -04:00
|
|
|
("pcie_x2", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("clk_p", Pins("AM14")),
|
|
|
|
Subsignal("clk_n", Pins("AM15")),
|
|
|
|
Subsignal("rx_p", Pins("AM8 AK12")),
|
|
|
|
Subsignal("rx_n", Pins("AM9 AK13")),
|
|
|
|
Subsignal("tx_p", Pins("AK9 AM11")),
|
|
|
|
Subsignal("tx_n", Pins("AK10 AM12")),
|
|
|
|
Subsignal("perst", Pins("D22"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("wake_n", Pins("A23"), IOStandard("LVCMOS33")),
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# M2
|
2019-07-09 10:50:26 -04:00
|
|
|
("m2", 0,
|
|
|
|
Subsignal("clk_p", Pins("AM23")),
|
|
|
|
Subsignal("clk_n", Pins("AM24")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("rx_p", Pins("AM17 AK21")),
|
|
|
|
Subsignal("rx_n", Pins("AM18 AK22")),
|
|
|
|
Subsignal("tx_p", Pins("AK18 AM20")),
|
|
|
|
Subsignal("tx_n", Pins("AK19 AM21")),
|
2019-07-09 10:50:26 -04:00
|
|
|
|
|
|
|
Subsignal("clksel", Pins("N3"), IOStandard("LVCMOS33")),
|
|
|
|
|
|
|
|
Subsignal("sdio_clk", Pins("L4"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("sdio_cmd", Pins("K4"), IOStandard("LVCMOS33")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("sdio_dq", Pins("L7 N4 L6 N6"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("uart_tx", Pins("P6"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("uart_rx", Pins("K5"), IOStandard("LVCMOS33")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("uart_rts_n", Pins("N7"), IOStandard("LVCMOS33")),
|
|
|
|
Subsignal("uart_cts_n", Pins("P7"), IOStandard("LVCMOS33"))
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# SDCard
|
2020-03-19 09:53:09 -04:00
|
|
|
("spisdcard", 0,
|
|
|
|
Subsignal("clk", Pins("AK3")),
|
|
|
|
Subsignal("mosi", Pins("AH3"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("cs_n", Pins("AK1"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("miso", Pins("AG1"), Misc("PULLMODE=UP")),
|
2020-07-21 09:23:08 -04:00
|
|
|
Misc("SLEWRATE=FAST"),
|
2020-04-09 14:02:02 -04:00
|
|
|
IOStandard("LVCMOS33"),
|
2020-03-19 09:53:09 -04:00
|
|
|
),
|
2019-07-09 10:50:26 -04:00
|
|
|
("sdcard", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("clk", Pins("AK3")),
|
|
|
|
Subsignal("cmd", Pins("AH3"), Misc("PULLMODE=UP")),
|
2020-03-19 09:53:09 -04:00
|
|
|
Subsignal("data", Pins("AG1 AJ1 AH1 AK1"), Misc("PULLMODE=UP")),
|
2020-07-21 09:23:08 -04:00
|
|
|
Misc("SLEWRATE=FAST"),
|
|
|
|
IOStandard("LVCMOS33"),
|
2019-07-09 10:50:26 -04:00
|
|
|
),
|
|
|
|
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# SPIFlash
|
2019-07-09 10:50:26 -04:00
|
|
|
("spiflash", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("clk", Pins("AM3")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("cs_n", Pins("AJ3")),
|
|
|
|
Subsignal("mosi", Pins("AK2")),
|
|
|
|
Subsignal("miso", Pins("AJ2")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("wp", Pins("AM2")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("hold", Pins("AL1")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
2020-11-03 04:48:41 -05:00
|
|
|
("spiflash4x", 0,
|
|
|
|
Subsignal("clk", Pins("AM3")),
|
|
|
|
Subsignal("cs_n", Pins("AJ3")),
|
|
|
|
Subsignal("dq", Pins("AK2 AJ2 AM2 AL1")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
2019-07-09 10:50:26 -04:00
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# USB ULPI
|
2019-07-09 10:50:26 -04:00
|
|
|
("ulpi", 0,
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("clk", Pins("A18")),
|
|
|
|
Subsignal("stp", Pins("D18")),
|
|
|
|
Subsignal("dir", Pins("C18")),
|
|
|
|
Subsignal("nxt", Pins("F18")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("reset", Pins("D17")),
|
2020-04-09 14:02:02 -04:00
|
|
|
Subsignal("data", Pins("C20 C19 E19 D20 A20 B19 D19 A19")),
|
2019-07-09 10:50:26 -04:00
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
|
|
|
|
2020-11-03 04:48:41 -05:00
|
|
|
# HDMI
|
2019-07-09 10:50:26 -04:00
|
|
|
("hdmi", 0,
|
2022-02-02 03:51:51 -05:00
|
|
|
Subsignal("r", Pins("F10 F9 D9 D8 C7 F8 E8 D11")),
|
|
|
|
Subsignal("g", Pins("B8 A7 C8 C9 F11 E11 E10 D10")),
|
|
|
|
Subsignal("b", Pins("C11 A11 B11 A10 B10 C10 A8 B7")),
|
|
|
|
Subsignal("de", Pins("F14")),
|
|
|
|
Subsignal("clk", Pins("A9")),
|
|
|
|
Subsignal("vsync_n", Pins("E14")),
|
|
|
|
Subsignal("hsync_n", Pins("F13")),
|
2019-07-09 10:50:26 -04:00
|
|
|
Subsignal("sda", Pins("D13")),
|
|
|
|
Subsignal("scl", Pins("C13")),
|
|
|
|
IOStandard("LVCMOS33")
|
|
|
|
),
|
|
|
|
]
|
|
|
|
|
2020-05-05 03:47:55 -04:00
|
|
|
# Connectors ---------------------------------------------------------------------------------------
|
|
|
|
|
2019-07-09 10:50:26 -04:00
|
|
|
_connectors = [
|
|
|
|
("pmoda", "F19 F20 B22 C23 D14 A13 E22 D23"),
|
|
|
|
("pmodb", "C25 A26 F23 F25 B25 D25 F22 F24"),
|
|
|
|
("pmodx", "A24 C24 D24 B23 D23 A25"),
|
|
|
|
|
|
|
|
("ext0", "T1 U1 AE5 AE4 AB5 AB6 Y5 W5 W2 Y1 AB7 AC6 AB3 AB4 AD3 AE3 AB1 AC1 AD1 AE1 AD6 AE6 AC7 AD7"),
|
|
|
|
("ext1", "P5 P4 R7 T7 R6 T6 U6 U7 R4 T5 T4 U5 U4 V4 V6 V7 P2 P3 R3 T3 N1 P1 U2 U3"),
|
|
|
|
("ext2", "K6 K7 J7 J6 H6 H5 F4 F5 F3 E3 C4 C3 C5 D5 D3 D2 H2 H3 J3 K3 B1 C2 F1 H1")
|
2020-07-29 03:07:44 -04:00
|
|
|
]
|
|
|
|
|
2019-07-09 10:50:26 -04:00
|
|
|
|
2020-07-29 03:07:44 -04:00
|
|
|
# PMODS --------------------------------------------------------------------------------------------
|
|
|
|
|
2021-10-11 05:33:13 -04:00
|
|
|
def raw_pmod_io(pmod):
|
|
|
|
return [(pmod, 0, Pins(" ".join([f"{pmod}:{i:d}" for i in range(8)])), IOStandard("LVCMOS33"))]
|
|
|
|
|
2020-07-29 03:07:44 -04:00
|
|
|
def sdcard_pmod_io(pmod):
|
|
|
|
return [
|
|
|
|
# SDCard PMOD:
|
|
|
|
# - https://store.digilentinc.com/pmod-microsd-microsd-card-slot/
|
|
|
|
# - https://github.com/antmicro/arty-expansion-board
|
|
|
|
("spisdcard", 0,
|
|
|
|
Subsignal("clk", Pins(f"{pmod}:3")),
|
|
|
|
Subsignal("mosi", Pins(f"{pmod}:1"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("cs_n", Pins(f"{pmod}:0"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("miso", Pins(f"{pmod}:2"), Misc("PULLMODE=UP")),
|
|
|
|
Misc("SLEWRATE=FAST"),
|
|
|
|
IOStandard("LVCMOS33"),
|
|
|
|
),
|
|
|
|
("sdcard", 0,
|
|
|
|
Subsignal("data", Pins(f"{pmod}:2 {pmod}:4 {pmod}:5 {pmod}:0"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("cmd", Pins(f"{pmod}:1"), Misc("PULLMODE=UP")),
|
|
|
|
Subsignal("clk", Pins(f"{pmod}:3")),
|
|
|
|
Subsignal("cd", Pins(f"{pmod}:6")),
|
|
|
|
Misc("SLEWRATE=FAST"),
|
|
|
|
IOStandard("LVCMOS33"),
|
|
|
|
),
|
2019-07-09 10:50:26 -04:00
|
|
|
]
|
2020-07-29 03:07:44 -04:00
|
|
|
_sdcard_pmod_io = sdcard_pmod_io("pmoda") # SDCARD PMOD on PMODA.
|
2019-07-09 10:50:26 -04:00
|
|
|
|
|
|
|
# Platform -----------------------------------------------------------------------------------------
|
|
|
|
|
2022-11-05 03:07:14 -04:00
|
|
|
class Platform(LatticeECP5Platform):
|
2020-04-09 14:02:02 -04:00
|
|
|
default_clk_name = "clk12"
|
2020-01-09 13:28:50 -05:00
|
|
|
default_clk_period = 1e9/12e6
|
2019-07-09 10:50:26 -04:00
|
|
|
|
2020-11-12 07:33:30 -05:00
|
|
|
def __init__(self, toolchain="trellis", **kwargs):
|
2022-11-05 03:07:14 -04:00
|
|
|
LatticeECP5Platform.__init__(self, "LFE5UM5G-85F-8BG756C", _io, _connectors, toolchain=toolchain, **kwargs)
|
2019-07-09 10:50:26 -04:00
|
|
|
|
2020-05-05 07:16:02 -04:00
|
|
|
def create_programmer(self):
|
|
|
|
return OpenOCDJTAGProgrammer("openocd_trellisboard.cfg")
|
|
|
|
|
2019-07-09 10:50:26 -04:00
|
|
|
def do_finalize(self, fragment):
|
2022-11-05 03:07:14 -04:00
|
|
|
LatticeECP5Platform.do_finalize(self, fragment)
|
2020-05-05 05:45:41 -04:00
|
|
|
self.add_period_constraint(self.lookup_request("clk100", loose=True), 1e9/100e6)
|
|
|
|
self.add_period_constraint(self.lookup_request("clk12", loose=True), 1e9/12e6)
|
|
|
|
self.add_period_constraint(self.lookup_request("eth_clocks:rx", loose=True), 1e9/125e6)
|