boards/platforms: cleanup pass to uniformize comments/separators/orders.
This commit is contained in:
parent
b63e2d3b94
commit
9d94bcdef7
|
@ -12,6 +12,12 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk100", 0, Pins("E3"), IOStandard("LVCMOS33")),
|
||||
("cpu_reset", 0, Pins("C2"), IOStandard("LVCMOS33")),
|
||||
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("H5"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("J5"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("T9"), IOStandard("LVCMOS33")),
|
||||
|
@ -23,21 +29,18 @@ _io = [
|
|||
Subsignal("b", Pins("E1")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("rgb_led", 1,
|
||||
Subsignal("r", Pins("G3")),
|
||||
Subsignal("g", Pins("J4")),
|
||||
Subsignal("b", Pins("G4")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("rgb_led", 2,
|
||||
Subsignal("r", Pins("J3")),
|
||||
Subsignal("g", Pins("J2")),
|
||||
Subsignal("b", Pins("H4")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("rgb_led", 3,
|
||||
Subsignal("r", Pins("K1")),
|
||||
Subsignal("g", Pins("H6")),
|
||||
|
@ -45,26 +48,26 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("A8"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 1, Pins("C11"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 2, Pins("C10"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 3, Pins("A10"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Buttons
|
||||
("user_btn", 0, Pins("D9"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 1, Pins("C9"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 2, Pins("B9"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 3, Pins("B8"), IOStandard("LVCMOS33")),
|
||||
|
||||
("clk100", 0, Pins("E3"), IOStandard("LVCMOS33")),
|
||||
|
||||
("cpu_reset", 0, Pins("C2"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("D10")),
|
||||
Subsignal("rx", Pins("A9")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# SPI
|
||||
("spi", 0,
|
||||
Subsignal("clk", Pins("F1")),
|
||||
Subsignal("cs_n", Pins("C1")),
|
||||
|
@ -73,6 +76,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# I2C
|
||||
("i2c", 0,
|
||||
Subsignal("scl", Pins("L18")),
|
||||
Subsignal("sda", Pins("M18")),
|
||||
|
@ -81,12 +85,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("spiflash4x", 0,
|
||||
Subsignal("cs_n", Pins("L13")),
|
||||
Subsignal("clk", Pins("L16")),
|
||||
Subsignal("dq", Pins("K17", "K18", "L14", "M14")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("cs_n", Pins("L13")),
|
||||
Subsignal("clk", Pins("L16")),
|
||||
|
@ -96,7 +95,14 @@ _io = [
|
|||
Subsignal("hold", Pins("M14")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
("spiflash4x", 0,
|
||||
Subsignal("cs_n", Pins("L13")),
|
||||
Subsignal("clk", Pins("L16")),
|
||||
Subsignal("dq", Pins("K17", "K18", "L14", "M14")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"R2 M6 N4 T1 N6 R7 V6 U7",
|
||||
|
@ -127,6 +133,7 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
),
|
||||
|
||||
# MII Ethernet
|
||||
("eth_ref_clk", 0, Pins("G18"), IOStandard("LVCMOS33")),
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("H16")),
|
||||
|
|
|
@ -10,31 +10,29 @@ from litex.build.microsemi import MicrosemiPlatform
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk50", 0, Pins("R1"), IOStandard("LVCMOS25")),
|
||||
("clk50", 1, Pins("J3"), IOStandard("LVCMOS25")),
|
||||
|
||||
("rst_n", 0, Pins("F5"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("D6"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("D7"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("D8"), IOStandard("LVCMOS33")),
|
||||
("user_led", 3, Pins("D9"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Buttons
|
||||
("user_btn", 0, Pins("E13"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 1, Pins("E14"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("F17")),
|
||||
Subsignal("rx", Pins("F16")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
("spiflash4x", 0,
|
||||
Subsignal("clk", Pins("J1")),
|
||||
Subsignal("cs_n", Pins("H1")),
|
||||
Subsignal("dq", Pins("F2 F1 M7 M8")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("clk", Pins("J1")),
|
||||
Subsignal("cs_n", Pins("H1")),
|
||||
|
@ -44,7 +42,14 @@ _io = [
|
|||
Subsignal("hold", Pins("M8")),
|
||||
IOStandard("LVCMOS25"),
|
||||
),
|
||||
("spiflash4x", 0,
|
||||
Subsignal("clk", Pins("J1")),
|
||||
Subsignal("cs_n", Pins("H1")),
|
||||
Subsignal("dq", Pins("F2 F1 M7 M8")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"U5 U4 V4 W3 V5 W4 Y3 AA3",
|
||||
|
@ -69,6 +74,7 @@ _io = [
|
|||
Subsignal("reset_n", Pins("AB7"), IOStandard("SSTL15II")),
|
||||
),
|
||||
|
||||
# Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("J8")),
|
||||
Subsignal("rx", Pins("K3")),
|
||||
|
|
|
@ -11,8 +11,10 @@ from litex.build.altera.programmer import USBBlaster
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk
|
||||
("clk50", 0, Pins("R8"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("A15"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 1, Pins("A13"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 2, Pins("B13"), IOStandard("3.3-V LVTTL")),
|
||||
|
@ -22,14 +24,17 @@ _io = [
|
|||
("user_led", 6, Pins("B1"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 7, Pins("L3"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Button
|
||||
("key", 0, Pins("J15"), IOStandard("3.3-V LVTTL")),
|
||||
("key", 1, Pins("E1"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Switches
|
||||
("sw", 0, Pins("M1"), IOStandard("3.3-V LVTTL")),
|
||||
("sw", 1, Pins("T8"), IOStandard("3.3-V LVTTL")),
|
||||
("sw", 2, Pins("B9"), IOStandard("3.3-V LVTTL")),
|
||||
("sw", 3, Pins("M15"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
# Compatible with cheap FT232 based cables (ex: Gaoominy 6Pin Ftdi Ft232Rl Ft232)
|
||||
# GND on JP1 Pin 12.
|
||||
|
@ -37,6 +42,7 @@ _io = [
|
|||
Subsignal("rx", Pins("B4"), IOStandard("3.3-V LVTTL")) # GPIO_05 (JP1 Pin 8)
|
||||
),
|
||||
|
||||
# SDR SDRAM
|
||||
("sdram_clock", 0, Pins("R4"), IOStandard("3.3-V LVTTL")),
|
||||
("sdram", 0,
|
||||
Subsignal("a", Pins(
|
||||
|
@ -55,6 +61,7 @@ _io = [
|
|||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# ECPS
|
||||
("epcs", 0,
|
||||
Subsignal("data0", Pins("H2")),
|
||||
Subsignal("dclk", Pins("H1")),
|
||||
|
@ -63,18 +70,21 @@ _io = [
|
|||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# I2C
|
||||
("i2c", 0,
|
||||
Subsignal("sclk", Pins("F2")),
|
||||
Subsignal("sdat", Pins("F1")),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
("g_sensor", 0,
|
||||
# Accelerometer
|
||||
("acc", 0,
|
||||
Subsignal("cs_n", Pins("G5")),
|
||||
Subsignal("int", Pins("M2")),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# ADC
|
||||
("adc", 0,
|
||||
Subsignal("cs_n", Pins("A10")),
|
||||
Subsignal("saddr", Pins("B10")),
|
||||
|
@ -83,6 +93,7 @@ _io = [
|
|||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# GPIOs
|
||||
("gpio_0", 0, Pins(
|
||||
"D3 C3 A2 A3 B3 B4 A4 B5",
|
||||
"A5 D5 B6 A6 B7 D6 A7 C6",
|
||||
|
|
|
@ -11,6 +11,14 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk200", 0,
|
||||
Subsignal("p", Pins("AD12"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("AD11"), IOStandard("LVDS"))
|
||||
),
|
||||
("cpu_reset_n", 0, Pins("R19"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("T28"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("V19"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("U30"), IOStandard("LVCMOS33")),
|
||||
|
@ -20,14 +28,14 @@ _io = [
|
|||
("user_led", 6, Pins("W24"), IOStandard("LVCMOS33")),
|
||||
("user_led", 7, Pins("W23"), IOStandard("LVCMOS33")),
|
||||
|
||||
("cpu_reset_n", 0, Pins("R19"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Buttons
|
||||
("user_btn_c", 0, Pins("E18"), IOStandard("LVCMOS33")),
|
||||
("user_btn_d", 0, Pins("M19"), IOStandard("LVCMOS33")),
|
||||
("user_btn_l", 0, Pins("M20"), IOStandard("LVCMOS33")),
|
||||
("user_btn_r", 0, Pins("C19"), IOStandard("LVCMOS33")),
|
||||
("user_btn_u", 0, Pins("B19"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("G19"), IOStandard("LVCMOS12")),
|
||||
("user_sw", 1, Pins("G25"), IOStandard("LVCMOS12")),
|
||||
("user_sw", 2, Pins("H24"), IOStandard("LVCMOS12")),
|
||||
|
@ -37,17 +45,14 @@ _io = [
|
|||
("user_sw", 6, Pins("P26"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 7, Pins("P27"), IOStandard("LVCMOS33")),
|
||||
|
||||
("clk200", 0,
|
||||
Subsignal("p", Pins("AD12"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("AD11"), IOStandard("LVDS"))
|
||||
),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("Y23")),
|
||||
Subsignal("rx", Pins("Y20")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# USB FIFO
|
||||
("usb_fifo", 0, # Can be used when FT2232H's Channel A configured to ASYNC FIFO 245 mode
|
||||
Subsignal("data", Pins("AD27 W27 W28 W29 Y29 Y28 AA28 AA26")),
|
||||
Subsignal("rxf_n", Pins("AB29")),
|
||||
|
@ -61,14 +66,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("R28")),
|
||||
Subsignal("cmd", Pins("R29"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("R26 R30 P29 T30"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("R28")),
|
||||
Subsignal("cs_n", Pins("T30")),
|
||||
|
@ -77,7 +75,16 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("R28")),
|
||||
Subsignal("cmd", Pins("R29"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("R26 R30 P29 T30"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"AC12 AE8 AD8 AC10 AD9 AA13 AA10 AA11",
|
||||
|
@ -109,6 +116,7 @@ _io = [
|
|||
Misc("VCCAUX_IO=HIGH")
|
||||
),
|
||||
|
||||
# RGMII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("AE10")),
|
||||
Subsignal("rx", Pins("AG10")),
|
||||
|
|
|
@ -16,19 +16,27 @@ from litex.build.lattice.programmer import IceStormProgrammer
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk12", 0, Pins("35"), IOStandard("LVCMOS33"))
|
||||
|
||||
# Leds
|
||||
("user_led_n", 0, Pins("11"), IOStandard("LVCMOS33")),
|
||||
("user_led_n", 1, Pins("37"), IOStandard("LVCMOS33")),
|
||||
# Color-specific aliases
|
||||
("user_ledr_n", 0, Pins("11"), IOStandard("LVCMOS33")),
|
||||
("user_ledg_n", 0, Pins("37"), IOStandard("LVCMOS33")),
|
||||
|
||||
("user_ledr_n", 0, Pins("11"), IOStandard("LVCMOS33")), # Color-specific alias
|
||||
("user_ledg_n", 0, Pins("37"), IOStandard("LVCMOS33")), # Color-specific alias
|
||||
|
||||
# Button
|
||||
("user_btn_n", 0, Pins("10"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("rx", Pins("6")),
|
||||
Subsignal("tx", Pins("9"), Misc("PULLUP")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("cs_n", Pins("16"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("15"), IOStandard("LVCMOS33")),
|
||||
|
@ -37,14 +45,11 @@ _io = [
|
|||
Subsignal("wp", Pins("12"), IOStandard("LVCMOS33")),
|
||||
Subsignal("hold", Pins("13"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
("spiflash4x", 0,
|
||||
Subsignal("cs_n", Pins("16"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("15"), IOStandard("LVCMOS33")),
|
||||
Subsignal("dq", Pins("14 17 12 13"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
("clk12", 0, Pins("35"), IOStandard("LVCMOS33"))
|
||||
]
|
||||
|
||||
# Connectors ---------------------------------------------------------------------------------------
|
||||
|
|
|
@ -13,40 +13,7 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
("user_led", 0, Pins("AB8"), IOStandard("LVCMOS15")),
|
||||
("user_led", 1, Pins("AA8"), IOStandard("LVCMOS15")),
|
||||
("user_led", 2, Pins("AC9"), IOStandard("LVCMOS15")),
|
||||
("user_led", 3, Pins("AB9"), IOStandard("LVCMOS15")),
|
||||
("user_led", 4, Pins("AE26"), IOStandard("LVCMOS25")),
|
||||
("user_led", 5, Pins("G19"), IOStandard("LVCMOS25")),
|
||||
("user_led", 6, Pins("E18"), IOStandard("LVCMOS25")),
|
||||
("user_led", 7, Pins("F16"), IOStandard("LVCMOS25")),
|
||||
|
||||
("cpu_reset", 0, Pins("AB7"), IOStandard("LVCMOS15")),
|
||||
|
||||
("user_btn_c", 0, Pins("G12"), IOStandard("LVCMOS25")),
|
||||
("user_btn_n", 0, Pins("AA12"), IOStandard("LVCMOS15")),
|
||||
("user_btn_s", 0, Pins("AB12"), IOStandard("LVCMOS15")),
|
||||
("user_btn_w", 0, Pins("AC6"), IOStandard("LVCMOS15")),
|
||||
("user_btn_e", 0, Pins("AG5"), IOStandard("LVCMOS15")),
|
||||
|
||||
("user_dip_btn", 0, Pins("Y29"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 1, Pins("W29"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 2, Pins("AA28"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 3, Pins("Y28"), IOStandard("LVCMOS25")),
|
||||
|
||||
("user_sma_clock", 0,
|
||||
Subsignal("p", Pins("L25"), IOStandard("LVDS_25"),
|
||||
Misc("DIFF_TERM=TRUE")),
|
||||
Subsignal("n", Pins("K25"), IOStandard("LVDS_25"),
|
||||
Misc("DIFF_TERM=TRUE"))
|
||||
),
|
||||
("user_sma_clock_p", 0, Pins("L25"), IOStandard("LVCMOS25")),
|
||||
("user_sma_clock_n", 0, Pins("K25"), IOStandard("LVCMOS25")),
|
||||
|
||||
("user_sma_gpio_p", 0, Pins("Y23"), IOStandard("LVCMOS25")),
|
||||
("user_sma_gpio_n", 0, Pins("Y24"), IOStandard("LVCMOS25")),
|
||||
|
||||
# Clk / Rst
|
||||
("clk200", 0,
|
||||
Subsignal("p", Pins("AD12"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("AD11"), IOStandard("LVDS"))
|
||||
|
@ -56,12 +23,50 @@ _io = [
|
|||
Subsignal("p", Pins("K28"), IOStandard("LVDS_25")),
|
||||
Subsignal("n", Pins("K29"), IOStandard("LVDS_25"))
|
||||
),
|
||||
("cpu_reset", 0, Pins("AB7"), IOStandard("LVCMOS15")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("AB8"), IOStandard("LVCMOS15")),
|
||||
("user_led", 1, Pins("AA8"), IOStandard("LVCMOS15")),
|
||||
("user_led", 2, Pins("AC9"), IOStandard("LVCMOS15")),
|
||||
("user_led", 3, Pins("AB9"), IOStandard("LVCMOS15")),
|
||||
("user_led", 4, Pins("AE26"), IOStandard("LVCMOS25")),
|
||||
("user_led", 5, Pins("G19"), IOStandard("LVCMOS25")),
|
||||
("user_led", 6, Pins("E18"), IOStandard("LVCMOS25")),
|
||||
("user_led", 7, Pins("F16"), IOStandard("LVCMOS25")),
|
||||
|
||||
# Buttons
|
||||
("user_btn_c", 0, Pins("G12"), IOStandard("LVCMOS25")),
|
||||
("user_btn_n", 0, Pins("AA12"), IOStandard("LVCMOS15")),
|
||||
("user_btn_s", 0, Pins("AB12"), IOStandard("LVCMOS15")),
|
||||
("user_btn_w", 0, Pins("AC6"), IOStandard("LVCMOS15")),
|
||||
("user_btn_e", 0, Pins("AG5"), IOStandard("LVCMOS15")),
|
||||
|
||||
# Switches
|
||||
("user_dip_btn", 0, Pins("Y29"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 1, Pins("W29"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 2, Pins("AA28"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 3, Pins("Y28"), IOStandard("LVCMOS25")),
|
||||
|
||||
# SMA
|
||||
("user_sma_clock", 0,
|
||||
Subsignal("p", Pins("L25"), IOStandard("LVDS_25"),
|
||||
Misc("DIFF_TERM=TRUE")),
|
||||
Subsignal("n", Pins("K25"), IOStandard("LVDS_25"),
|
||||
Misc("DIFF_TERM=TRUE"))
|
||||
),
|
||||
("user_sma_clock_p", 0, Pins("L25"), IOStandard("LVCMOS25")),
|
||||
("user_sma_clock_n", 0, Pins("K25"), IOStandard("LVCMOS25")),
|
||||
("user_sma_gpio_p", 0, Pins("Y23"), IOStandard("LVCMOS25")),
|
||||
("user_sma_gpio_n", 0, Pins("Y24"), IOStandard("LVCMOS25")),
|
||||
|
||||
# I2C
|
||||
("i2c", 0,
|
||||
Subsignal("scl", Pins("K21")),
|
||||
Subsignal("sda", Pins("L21")),
|
||||
IOStandard("LVCMOS25")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("cts", Pins("L27")),
|
||||
Subsignal("rts", Pins("K23")),
|
||||
|
@ -70,56 +75,7 @@ _io = [
|
|||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("spiflash", 0, # clock needs to be accessed through STARTUPE2
|
||||
Subsignal("cs_n", Pins("U19")),
|
||||
Subsignal("dq", Pins("P24", "R25", "R20", "R21")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("AB23")),
|
||||
Subsignal("cmd", Pins("AB22"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("AC20 AA23 AA22 AC21"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("AB23")),
|
||||
Subsignal("cs_n", Pins("AC21")),
|
||||
Subsignal("mosi", Pins("AB22"), Misc("PULLUP")),
|
||||
Subsignal("miso", Pins("AC20"), Misc("PULLUP")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("lcd", 0,
|
||||
Subsignal("db", Pins("AA13 AA10 AA11 Y10")),
|
||||
Subsignal("e", Pins("AB10")),
|
||||
Subsignal("rs", Pins("Y11")),
|
||||
Subsignal("rw", Pins("AB13")),
|
||||
IOStandard("LVCMOS15")),
|
||||
|
||||
("rotary", 0,
|
||||
Subsignal("a", Pins("Y26")),
|
||||
Subsignal("b", Pins("Y25")),
|
||||
Subsignal("push", Pins("AA26")),
|
||||
IOStandard("LVCMOS25")),
|
||||
|
||||
("hdmi", 0,
|
||||
Subsignal("d", Pins(
|
||||
"B23 A23 E23 D23 F25 E25 E24 D24",
|
||||
"F26 E26 G23 G24 J19 H19 L17 L18",
|
||||
"K19 K20")),
|
||||
Subsignal("de", Pins("H17")),
|
||||
Subsignal("clk", Pins("K18")),
|
||||
Subsignal("vsync", Pins("H20")),
|
||||
Subsignal("hsync", Pins("J18")),
|
||||
Subsignal("int", Pins("AH24")),
|
||||
Subsignal("spdif", Pins("J17")),
|
||||
Subsignal("spdif_out", Pins("G20")),
|
||||
IOStandard("LVCMOS25")),
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"AH12 AG13 AG12 AF12 AJ12 AJ13 AJ14 AH14",
|
||||
|
@ -156,42 +112,31 @@ _io = [
|
|||
Misc("VCCAUX_IO=HIGH")
|
||||
),
|
||||
|
||||
("ddram_dual_rank", 0,
|
||||
Subsignal("a", Pins(
|
||||
"AH12 AG13 AG12 AF12 AJ12 AJ13 AJ14 AH14",
|
||||
"AK13 AK14 AF13 AE13 AJ11 AH11 AK10 AK11"),
|
||||
IOStandard("SSTL15")),
|
||||
Subsignal("ba", Pins("AH9 AG9 AK9"), IOStandard("SSTL15")),
|
||||
Subsignal("ras_n", Pins("AD9"), IOStandard("SSTL15")),
|
||||
Subsignal("cas_n", Pins("AC11"), IOStandard("SSTL15")),
|
||||
Subsignal("we_n", Pins("AE9"), IOStandard("SSTL15")),
|
||||
Subsignal("cs_n", Pins("AC12 AE8"), IOStandard("SSTL15")),
|
||||
Subsignal("dm", Pins(
|
||||
"Y16 AB17 AF17 AE16 AK5 AJ3 AF6 AC7"),
|
||||
IOStandard("SSTL15")),
|
||||
Subsignal("dq", Pins(
|
||||
"AA15 AA16 AC14 AD14 AA17 AB15 AE15 Y15",
|
||||
"AB19 AD16 AC19 AD17 AA18 AB18 AE18 AD18",
|
||||
"AG19 AK19 AG18 AF18 AH19 AJ19 AE19 AD19",
|
||||
"AK16 AJ17 AG15 AF15 AH17 AG14 AH15 AK15",
|
||||
"AK8 AK6 AG7 AF7 AF8 AK4 AJ8 AJ6",
|
||||
"AH5 AH6 AJ2 AH2 AH4 AJ4 AK1 AJ1",
|
||||
"AF1 AF2 AE4 AE3 AF3 AF5 AE1 AE5",
|
||||
"AC1 AD3 AC4 AC5 AE6 AD6 AC2 AD4"),
|
||||
IOStandard("SSTL15_T_DCI")),
|
||||
Subsignal("dqs_p", Pins("AC16 Y19 AJ18 AH16 AH7 AG2 AG4 AD2"),
|
||||
IOStandard("DIFF_SSTL15")),
|
||||
Subsignal("dqs_n", Pins("AC15 Y18 AK18 AJ16 AJ7 AH1 AG3 AD1"),
|
||||
IOStandard("DIFF_SSTL15")),
|
||||
Subsignal("clk_p", Pins("AG10 AE11"), IOStandard("DIFF_SSTL15")),
|
||||
Subsignal("clk_n", Pins("AH10 AF11"), IOStandard("DIFF_SSTL15")),
|
||||
Subsignal("cke", Pins("AF10 AE10"), IOStandard("SSTL15")),
|
||||
Subsignal("odt", Pins("AD8 AC10"), IOStandard("SSTL15")),
|
||||
Subsignal("reset_n", Pins("AK3"), IOStandard("LVCMOS15")),
|
||||
Misc("SLEW=FAST"),
|
||||
Misc("VCCAUX_IO=HIGH")
|
||||
# SPIFlash
|
||||
("spiflash", 0, # clock needs to be accessed through STARTUPE2
|
||||
Subsignal("cs_n", Pins("U19")),
|
||||
Subsignal("dq", Pins("P24", "R25", "R20", "R21")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("AB23")),
|
||||
Subsignal("cs_n", Pins("AC21")),
|
||||
Subsignal("mosi", Pins("AB22"), Misc("PULLUP")),
|
||||
Subsignal("miso", Pins("AC20"), Misc("PULLUP")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("AB23")),
|
||||
Subsignal("cmd", Pins("AB22"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("AC20 AA23 AA22 AC21"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# GMII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("M28")),
|
||||
Subsignal("gtx", Pins("K30")),
|
||||
|
@ -214,6 +159,40 @@ _io = [
|
|||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# LCD
|
||||
("lcd", 0,
|
||||
Subsignal("db", Pins("AA13 AA10 AA11 Y10")),
|
||||
Subsignal("e", Pins("AB10")),
|
||||
Subsignal("rs", Pins("Y11")),
|
||||
Subsignal("rw", Pins("AB13")),
|
||||
IOStandard("LVCMOS15")
|
||||
),
|
||||
|
||||
# Rotary Encoder
|
||||
("rotary", 0,
|
||||
Subsignal("a", Pins("Y26")),
|
||||
Subsignal("b", Pins("Y25")),
|
||||
Subsignal("push", Pins("AA26")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# HDMI
|
||||
("hdmi", 0,
|
||||
Subsignal("d", Pins(
|
||||
"B23 A23 E23 D23 F25 E25 E24 D24",
|
||||
"F26 E26 G23 G24 J19 H19 L17 L18",
|
||||
"K19 K20")),
|
||||
Subsignal("de", Pins("H17")),
|
||||
Subsignal("clk", Pins("K18")),
|
||||
Subsignal("vsync", Pins("H20")),
|
||||
Subsignal("hsync", Pins("J18")),
|
||||
Subsignal("int", Pins("AH24")),
|
||||
Subsignal("spdif", Pins("J17")),
|
||||
Subsignal("spdif_out", Pins("G20")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# PCIe
|
||||
("pcie_x1", 0,
|
||||
Subsignal("rst_n", Pins("G25"), IOStandard("LVCMOS25")),
|
||||
Subsignal("clk_p", Pins("U8")),
|
||||
|
@ -251,13 +230,13 @@ _io = [
|
|||
Subsignal("tx_n", Pins("L3 M1 N3 P1 T1 U3 V1 Y1"))
|
||||
),
|
||||
|
||||
("vadj_on_b", 0, Pins("J27"), IOStandard("LVCMOS25")),
|
||||
|
||||
# SGMII Clk
|
||||
("sgmii_clock", 0,
|
||||
Subsignal("p", Pins("G8")),
|
||||
Subsignal("n", Pins("G7"))
|
||||
),
|
||||
|
||||
# SMA
|
||||
("user_sma_mgt_refclk", 0,
|
||||
Subsignal("p", Pins("J8")),
|
||||
Subsignal("n", Pins("J7"))
|
||||
|
@ -270,6 +249,8 @@ _io = [
|
|||
Subsignal("p", Pins("K6")),
|
||||
Subsignal("n", Pins("K5"))
|
||||
),
|
||||
|
||||
# SFP
|
||||
("sfp", 0, # inverted prior to HW rev 1.1
|
||||
Subsignal("txp", Pins("H2")),
|
||||
Subsignal("txn", Pins("H1")),
|
||||
|
@ -287,6 +268,7 @@ _io = [
|
|||
("sfp_tx_disable_n", 0, Pins("Y20"), IOStandard("LVCMOS25")),
|
||||
("sfp_rx_los", 0, Pins("P19"), IOStandard("LVCMOS25")),
|
||||
|
||||
# SI5324
|
||||
("si5324", 0,
|
||||
Subsignal("rst_n", Pins("AE20"), IOStandard("LVCMOS25")),
|
||||
Subsignal("int", Pins("AG24"), IOStandard("LVCMOS25"))
|
||||
|
@ -299,6 +281,9 @@ _io = [
|
|||
Subsignal("p", Pins("L8")),
|
||||
Subsignal("n", Pins("L7"))
|
||||
),
|
||||
|
||||
# Others
|
||||
("vadj_on_b", 0, Pins("J27"), IOStandard("LVCMOS25")),
|
||||
]
|
||||
|
||||
# Connectors ---------------------------------------------------------------------------------------
|
||||
|
|
|
@ -10,42 +10,7 @@ from litex.build.xilinx import XilinxPlatform, VivadoProgrammer
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
("user_led", 0, Pins("AP8"), IOStandard("LVCMOS18")),
|
||||
("user_led", 1, Pins("H23"), IOStandard("LVCMOS18")),
|
||||
("user_led", 2, Pins("P20"), IOStandard("LVCMOS18")),
|
||||
("user_led", 3, Pins("P21"), IOStandard("LVCMOS18")),
|
||||
("user_led", 4, Pins("N22"), IOStandard("LVCMOS18")),
|
||||
("user_led", 5, Pins("M22"), IOStandard("LVCMOS18")),
|
||||
("user_led", 6, Pins("R23"), IOStandard("LVCMOS18")),
|
||||
("user_led", 7, Pins("P23"), IOStandard("LVCMOS18")),
|
||||
|
||||
("cpu_reset", 0, Pins("AN8"), IOStandard("LVCMOS18")),
|
||||
|
||||
("user_btn_c", 0, Pins("AE10"), IOStandard("LVCMOS18")),
|
||||
("user_btn_n", 0, Pins("AD10"), IOStandard("LVCMOS18")),
|
||||
("user_btn_s", 0, Pins("AF8"), IOStandard("LVCMOS18")),
|
||||
("user_btn_w", 0, Pins("AF9"), IOStandard("LVCMOS18")),
|
||||
("user_btn_e", 0, Pins("AE8"), IOStandard("LVCMOS18")),
|
||||
|
||||
("user_dip_btn", 0, Pins("AN16"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 1, Pins("AN19"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 2, Pins("AP18"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 3, Pins("AN14"), IOStandard("LVCMOS12")),
|
||||
|
||||
("user_sma_clock", 0,
|
||||
Subsignal("p", Pins("D23"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("C23"), IOStandard("LVDS"))
|
||||
),
|
||||
("user_sma_clock_p", 0, Pins("D23"), IOStandard("LVCMOS18")),
|
||||
("user_sma_clock_n", 0, Pins("C23"), IOStandard("LVCMOS18")),
|
||||
|
||||
("user_sma_gpio", 0,
|
||||
Subsignal("p", Pins("H27"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("G27"), IOStandard("LVDS"))
|
||||
),
|
||||
("user_sma_gpio_p", 0, Pins("H27"), IOStandard("LVCMOS18")),
|
||||
("user_sma_gpio_n", 0, Pins("G27"), IOStandard("LVCMOS18")),
|
||||
|
||||
# Clk / Rst
|
||||
("clk125", 0,
|
||||
Subsignal("p", Pins("G10"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("F10"), IOStandard("LVDS"))
|
||||
|
@ -55,13 +20,53 @@ _io = [
|
|||
Subsignal("p", Pins("AK17"), IOStandard("DIFF_SSTL12")),
|
||||
Subsignal("n", Pins("AK16"), IOStandard("DIFF_SSTL12"))
|
||||
),
|
||||
("cpu_reset", 0, Pins("AN8"), IOStandard("LVCMOS18")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("AP8"), IOStandard("LVCMOS18")),
|
||||
("user_led", 1, Pins("H23"), IOStandard("LVCMOS18")),
|
||||
("user_led", 2, Pins("P20"), IOStandard("LVCMOS18")),
|
||||
("user_led", 3, Pins("P21"), IOStandard("LVCMOS18")),
|
||||
("user_led", 4, Pins("N22"), IOStandard("LVCMOS18")),
|
||||
("user_led", 5, Pins("M22"), IOStandard("LVCMOS18")),
|
||||
("user_led", 6, Pins("R23"), IOStandard("LVCMOS18")),
|
||||
("user_led", 7, Pins("P23"), IOStandard("LVCMOS18")),
|
||||
|
||||
# Buttons
|
||||
("user_btn_c", 0, Pins("AE10"), IOStandard("LVCMOS18")),
|
||||
("user_btn_n", 0, Pins("AD10"), IOStandard("LVCMOS18")),
|
||||
("user_btn_s", 0, Pins("AF8"), IOStandard("LVCMOS18")),
|
||||
("user_btn_w", 0, Pins("AF9"), IOStandard("LVCMOS18")),
|
||||
("user_btn_e", 0, Pins("AE8"), IOStandard("LVCMOS18")),
|
||||
|
||||
# Switches
|
||||
("user_dip_btn", 0, Pins("AN16"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 1, Pins("AN19"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 2, Pins("AP18"), IOStandard("LVCMOS12")),
|
||||
("user_dip_btn", 3, Pins("AN14"), IOStandard("LVCMOS12")),
|
||||
|
||||
# SMA
|
||||
("user_sma_clock", 0,
|
||||
Subsignal("p", Pins("D23"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("C23"), IOStandard("LVDS"))
|
||||
),
|
||||
("user_sma_clock_p", 0, Pins("D23"), IOStandard("LVCMOS18")),
|
||||
("user_sma_clock_n", 0, Pins("C23"), IOStandard("LVCMOS18")),
|
||||
("user_sma_gpio", 0,
|
||||
Subsignal("p", Pins("H27"), IOStandard("LVDS")),
|
||||
Subsignal("n", Pins("G27"), IOStandard("LVDS"))
|
||||
),
|
||||
("user_sma_gpio_p", 0, Pins("H27"), IOStandard("LVCMOS18")),
|
||||
("user_sma_gpio_n", 0, Pins("G27"), IOStandard("LVCMOS18")),
|
||||
|
||||
# I2C
|
||||
("i2c", 0,
|
||||
Subsignal("scl", Pins("J24")),
|
||||
Subsignal("sda", Pins("J25")),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("cts", Pins("L23")),
|
||||
Subsignal("rts", Pins("K27")),
|
||||
|
@ -70,26 +75,19 @@ _io = [
|
|||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# SPIFlash
|
||||
("spiflash", 0, # clock needs to be accessed through primitive
|
||||
Subsignal("cs_n", Pins("U7")),
|
||||
Subsignal("dq", Pins("AC7 AB7 AA7 Y7")),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
("spiflash", 1, # clock needs to be accessed through primitive
|
||||
Subsignal("cs_n", Pins("G26")),
|
||||
Subsignal("dq", Pins("M20 L20 R21 R22")),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("AL10")),
|
||||
Subsignal("cmd", Pins("AD9"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("AP9 AN9 AH9 AH8"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("AL10")),
|
||||
Subsignal("cs_n", Pins("AH8")),
|
||||
|
@ -98,7 +96,15 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("AL10")),
|
||||
Subsignal("cmd", Pins("AD9"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("AP9 AN9 AH9 AH8"), Misc("PULLUP True")),
|
||||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# Rotary Encoder
|
||||
("rotary", 0,
|
||||
Subsignal("a", Pins("Y21")),
|
||||
Subsignal("b", Pins("AD26")),
|
||||
|
@ -106,6 +112,7 @@ _io = [
|
|||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# HDMI
|
||||
("hdmi", 0,
|
||||
Subsignal("d", Pins(
|
||||
"AK11 AP11 AP13 AN13 AN11 AM11 AN12 AM12",
|
||||
|
@ -120,6 +127,7 @@ _io = [
|
|||
IOStandard("LVCMOS18")
|
||||
),
|
||||
|
||||
# DDR4 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"AE17 AH17 AE18 AJ15 AG16 AL17 AK18 AG17",
|
||||
|
@ -165,6 +173,7 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
),
|
||||
|
||||
# PCIe
|
||||
("pcie_x1", 0,
|
||||
Subsignal("rst_n", Pins("K22"), IOStandard("LVCMOS18")),
|
||||
Subsignal("clk_p", Pins("AB6")),
|
||||
|
@ -174,7 +183,6 @@ _io = [
|
|||
Subsignal("tx_p", Pins("AC4")),
|
||||
Subsignal("tx_n", Pins("AC3"))
|
||||
),
|
||||
|
||||
("pcie_x2", 0,
|
||||
Subsignal("rst_n", Pins("K22"), IOStandard("LVCMOS18")),
|
||||
Subsignal("clk_p", Pins("AB6")),
|
||||
|
@ -184,7 +192,6 @@ _io = [
|
|||
Subsignal("tx_p", Pins("AC4 AE4")),
|
||||
Subsignal("tx_n", Pins("AC3 AE3"))
|
||||
),
|
||||
|
||||
("pcie_x4", 0,
|
||||
Subsignal("rst_n", Pins("K22"), IOStandard("LVCMOS18")),
|
||||
Subsignal("clk_p", Pins("AB6")),
|
||||
|
@ -194,7 +201,6 @@ _io = [
|
|||
Subsignal("tx_p", Pins("AC4 AE4 AG4 AH6")),
|
||||
Subsignal("tx_n", Pins("AC3 AE3 AG3 AH5"))
|
||||
),
|
||||
|
||||
("pcie_x8", 0,
|
||||
Subsignal("rst_n", Pins("K22"), IOStandard("LVCMOS18")),
|
||||
Subsignal("clk_p", Pins("AB6")),
|
||||
|
@ -205,16 +211,19 @@ _io = [
|
|||
Subsignal("tx_n", Pins("AC3 AE3 AG3 AH5 AK5 AL3 AM5 AN3"))
|
||||
),
|
||||
|
||||
# SGMII Clk
|
||||
("sgmii_clock", 0,
|
||||
Subsignal("p", Pins("P26"), IOStandard("LVDS_25")),
|
||||
Subsignal("n", Pins("N26"), IOStandard("LVDS_25"))
|
||||
),
|
||||
|
||||
# SI570
|
||||
("si570_refclk", 0,
|
||||
Subsignal("p", Pins("P6")),
|
||||
Subsignal("n", Pins("P5"))
|
||||
),
|
||||
|
||||
# SMA
|
||||
("user_sma_mgt_refclk", 0,
|
||||
Subsignal("p", Pins("V6")),
|
||||
Subsignal("n", Pins("V5"))
|
||||
|
@ -228,6 +237,7 @@ _io = [
|
|||
Subsignal("n", Pins("P1"))
|
||||
),
|
||||
|
||||
# SFP
|
||||
("sfp", 0,
|
||||
Subsignal("txp", Pins("U4")),
|
||||
Subsignal("txn", Pins("U3")),
|
||||
|
|
|
@ -11,9 +11,11 @@ from litex.build.lattice.programmer import LatticeProgrammer
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk12", 0, Pins("C8"), IOStandard("LVCMOS33")),
|
||||
("rst_n", 0, Pins("B3"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("H11"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("J13"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("J11"), IOStandard("LVCMOS33")),
|
||||
|
@ -23,11 +25,13 @@ _io = [
|
|||
("user_led", 6, Pins("N15"), IOStandard("LVCMOS33")),
|
||||
("user_led", 7, Pins("P16"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Switches
|
||||
("user_dip_btn", 0, Pins("N2"), IOStandard("LVCMOS33")),
|
||||
("user_dip_btn", 1, Pins("P1"), IOStandard("LVCMOS33")),
|
||||
("user_dip_btn", 2, Pins("M3"), IOStandard("LVCMOS33")),
|
||||
("user_dip_btn", 3, Pins("N1"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("C11"), IOStandard("LVCMOS33")),
|
||||
Subsignal("rx", Pins("A11"), IOStandard("LVCMOS33")),
|
||||
|
|
|
@ -11,6 +11,11 @@ from litex.build.xilinx.programmer import XC3SProg
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk32", 0, Pins("J4"), IOStandard("LVCMOS33")),
|
||||
("clk50", 0, Pins("K3"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("P11"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("N9"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("M9"), IOStandard("LVCMOS33")),
|
||||
|
@ -20,14 +25,14 @@ _io = [
|
|||
("user_led", 6, Pins("P8"), IOStandard("LVCMOS33")),
|
||||
("user_led", 7, Pins("P7"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("L1"), IOStandard("LVCMOS33"), Misc("PULLUP")),
|
||||
("user_sw", 1, Pins("L3"), IOStandard("LVCMOS33"), Misc("PULLUP")),
|
||||
("user_sw", 2, Pins("L4"), IOStandard("LVCMOS33"), Misc("PULLUP")),
|
||||
("user_sw", 3, Pins("L5"), IOStandard("LVCMOS33"), Misc("PULLUP")),
|
||||
|
||||
("clk32", 0, Pins("J4"), IOStandard("LVCMOS33")),
|
||||
("clk50", 0, Pins("K3"), IOStandard("LVCMOS33")),
|
||||
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("cs_n", Pins("T3"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("R11"), IOStandard("LVCMOS33")),
|
||||
|
@ -35,6 +40,26 @@ _io = [
|
|||
Subsignal("miso", Pins("P10"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("N6"), IOStandard("LVCMOS33")), # FTDI D1
|
||||
Subsignal("rx", Pins("M7"), IOStandard("LVCMOS33")) # FTDI D0
|
||||
),
|
||||
|
||||
# USB FIFO
|
||||
("usb_fifo", 0,
|
||||
Subsignal("data", Pins("M7 N6 M6 P5 N5 P4 P2 P1")),
|
||||
Subsignal("rxf_n", Pins("N3")),
|
||||
Subsignal("txe_n", Pins("N1")),
|
||||
Subsignal("rd_n", Pins("M1")),
|
||||
Subsignal("wr_n", Pins("M2")),
|
||||
Subsignal("siwua", Pins("M3")),
|
||||
Misc("SLEW=FAST"),
|
||||
Drive(8),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# ADC
|
||||
("adc", 0,
|
||||
Subsignal("cs_n", Pins("F6"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("G6"), IOStandard("LVCMOS33")),
|
||||
|
@ -42,16 +67,13 @@ _io = [
|
|||
Subsignal("miso", Pins("H5"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("N6"), IOStandard("LVCMOS33")), # FTDI D1
|
||||
Subsignal("rx", Pins("M7"), IOStandard("LVCMOS33")) # FTDI D0
|
||||
),
|
||||
|
||||
# Audio
|
||||
("audio", 0,
|
||||
Subsignal("a0", Pins("B8"), IOStandard("LVCMOS33")),
|
||||
Subsignal("a1", Pins("A8"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
# SDR SDRAM
|
||||
("sdram_clock", 0, Pins("G16"), IOStandard("LVCMOS33"), Misc("SLEW=FAST")),
|
||||
("sdram", 0,
|
||||
Subsignal("a", Pins(
|
||||
|
@ -71,18 +93,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("usb_fifo", 0,
|
||||
Subsignal("data", Pins("M7 N6 M6 P5 N5 P4 P2 P1")),
|
||||
Subsignal("rxf_n", Pins("N3")),
|
||||
Subsignal("txe_n", Pins("N1")),
|
||||
Subsignal("rd_n", Pins("M1")),
|
||||
Subsignal("wr_n", Pins("M2")),
|
||||
Subsignal("siwua", Pins("M3")),
|
||||
Misc("SLEW=FAST"),
|
||||
Drive(8),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("L12")),
|
||||
Subsignal("mosi", Pins("K11"), Misc("PULLUP")),
|
||||
|
@ -91,7 +102,6 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("data", Pins("M10 L10 J11 K12"), Misc("PULLUP")),
|
||||
Subsignal("cmd", Pins("K11"), Misc("PULLUP")),
|
||||
|
@ -100,6 +110,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# DVI In
|
||||
("dvi_in", 0,
|
||||
Subsignal("clk_p", Pins("C9"), IOStandard("TMDS_33")),
|
||||
Subsignal("clk_n", Pins("A9"), IOStandard("TMDS_33")),
|
||||
|
@ -109,6 +120,7 @@ _io = [
|
|||
Subsignal("sda", Pins("B1"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
# DVI Out
|
||||
("dvi_out", 0,
|
||||
Subsignal("clk_p", Pins("B14"), IOStandard("TMDS_33")),
|
||||
Subsignal("clk_n", Pins("A14"), IOStandard("TMDS_33")),
|
||||
|
|
|
@ -11,10 +11,10 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# clock
|
||||
# Clk / Rst
|
||||
("clk50", 0, Pins("J19"), IOStandard("LVCMOS33")),
|
||||
|
||||
# leds
|
||||
# Leds
|
||||
("user_led", 0, Pins("M21"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("N20"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("L21"), IOStandard("LVCMOS33")),
|
||||
|
@ -22,31 +22,29 @@ _io = [
|
|||
("user_led", 4, Pins("R19"), IOStandard("LVCMOS33")),
|
||||
("user_led", 5, Pins("M16"), IOStandard("LVCMOS33")),
|
||||
|
||||
# spiflash
|
||||
("flash", 0,
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("cs_n", Pins("T19")),
|
||||
Subsignal("mosi", Pins("P22")),
|
||||
Subsignal("miso", Pins("R22")),
|
||||
Subsignal("wp", Pins("P21")),
|
||||
Subsignal("vpp", Pins("P21")),
|
||||
Subsignal("hold", Pins("R21")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# spiflash4x
|
||||
("spiflash4x", 0,
|
||||
Subsignal("cs_n", Pins("T19")),
|
||||
Subsignal("dq", Pins("P22 R22 P21 R21")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# serial
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("E14")),
|
||||
Subsignal("rx", Pins("E13")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# dram
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"U6 V4 W5 V5 AA1 Y2 AB1 AB3",
|
||||
|
@ -75,7 +73,7 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
),
|
||||
|
||||
# pcie
|
||||
# PCIe
|
||||
("pcie_x1", 0,
|
||||
Subsignal("rst_n", Pins("E18"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk_p", Pins("F10")),
|
||||
|
@ -85,7 +83,6 @@ _io = [
|
|||
Subsignal("tx_p", Pins("D5")),
|
||||
Subsignal("tx_n", Pins("C5"))
|
||||
),
|
||||
|
||||
("pcie_x2", 0,
|
||||
Subsignal("rst_n", Pins("E18"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk_p", Pins("F10")),
|
||||
|
@ -95,7 +92,6 @@ _io = [
|
|||
Subsignal("tx_p", Pins("D5 B6")),
|
||||
Subsignal("tx_n", Pins("C5 A6"))
|
||||
),
|
||||
|
||||
("pcie_x4", 0,
|
||||
Subsignal("rst_n", Pins("E18"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk_p", Pins("F10")),
|
||||
|
@ -106,12 +102,11 @@ _io = [
|
|||
Subsignal("tx_n", Pins("C5 A6 C7 A4"))
|
||||
),
|
||||
|
||||
# ethernet
|
||||
# RMII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("ref_clk", Pins("D17")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("eth", 0,
|
||||
Subsignal("rst_n", Pins("F16")),
|
||||
Subsignal("rx_data", Pins("A20 B18")),
|
||||
|
@ -125,14 +120,7 @@ _io = [
|
|||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# sdcard
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("K18")),
|
||||
Subsignal("cmd", Pins("L13"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("L15 L16 K14 M13"), Misc("PULLUP True")),
|
||||
IOStandard("LVCMOS33"), Misc("SLEW=FAST")
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("K18")),
|
||||
Subsignal("cs_n", Pins("M13")),
|
||||
|
@ -141,8 +129,14 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("K18")),
|
||||
Subsignal("cmd", Pins("L13"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("L15 L16 K14 M13"), Misc("PULLUP True")),
|
||||
IOStandard("LVCMOS33"), Misc("SLEW=FAST")
|
||||
),
|
||||
|
||||
# hdmi in
|
||||
# HDMI In
|
||||
("hdmi_in", 0,
|
||||
Subsignal("clk_p", Pins("L19"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("clk_n", Pins("L20"), IOStandard("TMDS_33"), Inverted()),
|
||||
|
@ -152,12 +146,9 @@ _io = [
|
|||
Subsignal("data1_n", Pins("J21"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("data2_p", Pins("J22"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("data2_n", Pins("H22"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("scl", Pins("T18"), Inverted(), IOStandard("LVCMOS33")),
|
||||
Subsignal("sda", Pins("V18"), Inverted(), IOStandard("LVCMOS33")),
|
||||
Subsignal("sda_pu", Pins("G20"), IOStandard("LVCMOS33")),
|
||||
Subsignal("sda_pd", Pins("F20"), IOStandard("LVCMOS33")),
|
||||
Subsignal("scl", Pins("T18"), IOStandard("LVCMOS33")),
|
||||
Subsignal("sda", Pins("V18"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
("hdmi_in", 1,
|
||||
Subsignal("clk_p", Pins("Y18"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("clk_n", Pins("Y19"), IOStandard("TMDS_33"), Inverted()),
|
||||
|
@ -171,7 +162,7 @@ _io = [
|
|||
Subsignal("sda", Pins("R17"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
# hdmi out
|
||||
# HDMI Out
|
||||
("hdmi_out", 0,
|
||||
Subsignal("clk_p", Pins("W19"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("clk_n", Pins("W20"), IOStandard("TMDS_33"), Inverted()),
|
||||
|
@ -182,7 +173,6 @@ _io = [
|
|||
Subsignal("data2_p", Pins("T21"), IOStandard("TMDS_33")),
|
||||
Subsignal("data2_n", Pins("U21"), IOStandard("TMDS_33"))
|
||||
),
|
||||
|
||||
("hdmi_out", 1,
|
||||
Subsignal("clk_p", Pins("G21"), IOStandard("TMDS_33"), Inverted()),
|
||||
Subsignal("clk_n", Pins("G22"), IOStandard("TMDS_33"), Inverted()),
|
||||
|
|
|
@ -11,6 +11,11 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk100", 0, Pins("E3"), IOStandard("LVCMOS33")),
|
||||
("cpu_reset", 0, Pins("C12"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("H17"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("K15"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("J13"), IOStandard("LVCMOS33")),
|
||||
|
@ -28,6 +33,7 @@ _io = [
|
|||
("user_led", 14, Pins("V12"), IOStandard("LVCMOS33")),
|
||||
("user_led", 15, Pins("V11"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("J15"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 1, Pins("L16"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 2, Pins("M13"), IOStandard("LVCMOS33")),
|
||||
|
@ -45,22 +51,21 @@ _io = [
|
|||
("user_sw", 14, Pins("U11"), IOStandard("LVCMOS33")),
|
||||
("user_sw", 15, Pins("V10"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Buttons
|
||||
("user_btn", 0, Pins("N17"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 1, Pins("P18"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 2, Pins("P17"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 3, Pins("M17"), IOStandard("LVCMOS33")),
|
||||
("user_btn", 4, Pins("M18"), IOStandard("LVCMOS33")),
|
||||
|
||||
("clk100", 0, Pins("E3"), IOStandard("LVCMOS33")),
|
||||
|
||||
("cpu_reset", 0, Pins("C12"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("D4")),
|
||||
Subsignal("rx", Pins("C4")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("rst", Pins("E2")),
|
||||
Subsignal("clk", Pins("B1")),
|
||||
|
@ -70,7 +75,6 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("rst", Pins("E2"), Misc("PULLUP True")),
|
||||
Subsignal("data", Pins("C2 E1 F1 D2"), Misc("PULLUP True")),
|
||||
|
@ -81,6 +85,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# DDR2 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"M4 P4 M6 T1 L3 P5 M2 N1",
|
||||
|
@ -106,6 +111,7 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
),
|
||||
|
||||
# RMII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("ref_clk", Pins("D5")),
|
||||
IOStandard("LVCMOS33"),
|
||||
|
|
|
@ -11,10 +11,11 @@ from litex.build.openocd import OpenOCD
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk100", 0, Pins("R4"), IOStandard("LVCMOS33")),
|
||||
|
||||
("cpu_reset", 0, Pins("G4"), IOStandard("LVCMOS15")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("T14"), IOStandard("LVCMOS25")),
|
||||
("user_led", 1, Pins("T15"), IOStandard("LVCMOS25")),
|
||||
("user_led", 2, Pins("T16"), IOStandard("LVCMOS25")),
|
||||
|
@ -24,6 +25,7 @@ _io = [
|
|||
("user_led", 6, Pins("W15"), IOStandard("LVCMOS25")),
|
||||
("user_led", 7, Pins("Y13"), IOStandard("LVCMOS25")),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("E22"), IOStandard("LVCMOS25")),
|
||||
("user_sw", 1, Pins("F21"), IOStandard("LVCMOS25")),
|
||||
("user_sw", 2, Pins("G21"), IOStandard("LVCMOS25")),
|
||||
|
@ -33,7 +35,7 @@ _io = [
|
|||
("user_sw", 6, Pins("K13"), IOStandard("LVCMOS25")),
|
||||
("user_sw", 7, Pins("M17"), IOStandard("LVCMOS25")),
|
||||
|
||||
|
||||
# Buttons
|
||||
("user_btn", 0, Pins("B22"), IOStandard("LVCMOS25")),
|
||||
("user_btn", 1, Pins("D22"), IOStandard("LVCMOS25")),
|
||||
("user_btn", 2, Pins("C22"), IOStandard("LVCMOS25")),
|
||||
|
@ -41,8 +43,7 @@ _io = [
|
|||
("user_btn", 4, Pins("F15"), IOStandard("LVCMOS25")),
|
||||
("user_btn", 5, Pins("G4"), IOStandard("LVCMOS25")),
|
||||
|
||||
("vadj", 0, Pins("AA13 AB17"), IOStandard("LVCMOS25")),
|
||||
|
||||
# OLED
|
||||
("oled", 0,
|
||||
Subsignal("dc", Pins("W22")),
|
||||
Subsignal("res", Pins("U21")),
|
||||
|
@ -53,12 +54,14 @@ _io = [
|
|||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("AA19")),
|
||||
Subsignal("rx", Pins("V18")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# USB FIFO
|
||||
("usb_fifo", 0, # Can be used when FT2232H's Channel A configured to ASYNC FIFO 245 mode
|
||||
Subsignal("data", Pins("U20 P14 P15 U17 R17 P16 R18 N14")),
|
||||
Subsignal("rxf_n", Pins("N17")),
|
||||
|
@ -72,6 +75,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("rst", Pins("V20")),
|
||||
Subsignal("clk", Pins("W19")),
|
||||
|
@ -91,6 +95,7 @@ _io = [
|
|||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"M2 M5 M3 M1 L6 P1 N3 N2",
|
||||
|
@ -116,6 +121,7 @@ _io = [
|
|||
Misc("SLEW=FAST"),
|
||||
),
|
||||
|
||||
# MII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("AA14")),
|
||||
Subsignal("rx", Pins("V13")),
|
||||
|
@ -133,6 +139,7 @@ _io = [
|
|||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
# HDMI In
|
||||
("hdmi_in", 0,
|
||||
Subsignal("clk_p", Pins("V4"), IOStandard("TMDS_33")),
|
||||
Subsignal("clk_n", Pins("W4"), IOStandard("TMDS_33")),
|
||||
|
@ -149,6 +156,7 @@ _io = [
|
|||
Subsignal("txen", Pins("R3"), IOStandard("LVCMOS33")), # FIXME
|
||||
),
|
||||
|
||||
# HDMI Out
|
||||
("hdmi_out", 0,
|
||||
Subsignal("clk_p", Pins("T1"), IOStandard("TMDS_33")),
|
||||
Subsignal("clk_n", Pins("U1"), IOStandard("TMDS_33")),
|
||||
|
@ -163,6 +171,9 @@ _io = [
|
|||
Subsignal("cec", Pins("AA4"), IOStandard("LVCMOS33")), # FIXME
|
||||
Subsignal("hdp", Pins("AB13"), IOStandard("LVCMOS25")), # FIXME
|
||||
),
|
||||
|
||||
# Others
|
||||
("vadj", 0, Pins("AA13 AB17"), IOStandard("LVCMOS25")),
|
||||
]
|
||||
|
||||
# Connectors ---------------------------------------------------------------------------------------
|
||||
|
|
|
@ -12,8 +12,13 @@ from litex.build.lattice.programmer import TinyProgProgrammer
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk16", 0, Pins("B2"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("B3"), IOStandard("LVCMOS33")),
|
||||
|
||||
# USB
|
||||
("usb", 0,
|
||||
Subsignal("d_p", Pins("B4")),
|
||||
Subsignal("d_n", Pins("A4")),
|
||||
|
@ -21,6 +26,7 @@ _io = [
|
|||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# SPIFlash
|
||||
("spiflash", 0,
|
||||
Subsignal("cs_n", Pins("F7"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("G7"), IOStandard("LVCMOS33")),
|
||||
|
@ -29,14 +35,11 @@ _io = [
|
|||
Subsignal("wp", Pins("H4"), IOStandard("LVCMOS33")),
|
||||
Subsignal("hold", Pins("J8"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
("spiflash4x", 0,
|
||||
Subsignal("cs_n", Pins("F7"), IOStandard("LVCMOS33")),
|
||||
Subsignal("clk", Pins("G7"), IOStandard("LVCMOS33")),
|
||||
Subsignal("dq", Pins("G6 H7 H4 J8"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
("clk16", 0, Pins("B2"), IOStandard("LVCMOS33"))
|
||||
]
|
||||
|
||||
# Connectors ---------------------------------------------------------------------------------------
|
||||
|
|
|
@ -11,9 +11,11 @@ from litex.build.lattice.programmer import UJProg
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io_common = [
|
||||
# Clk / Rst
|
||||
("clk25", 0, Pins("G2"), IOStandard("LVCMOS33")),
|
||||
("rst", 0, Pins("R1"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("B2"), IOStandard("LVCMOS33")),
|
||||
("user_led", 1, Pins("C2"), IOStandard("LVCMOS33")),
|
||||
("user_led", 2, Pins("C1"), IOStandard("LVCMOS33")),
|
||||
|
@ -23,11 +25,13 @@ _io_common = [
|
|||
("user_led", 6, Pins("E1"), IOStandard("LVCMOS33")),
|
||||
("user_led", 7, Pins("H3"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("L4"), IOStandard("LVCMOS33")),
|
||||
Subsignal("rx", Pins("M1"), IOStandard("LVCMOS33"))
|
||||
),
|
||||
|
||||
# SDR SDRAM
|
||||
("sdram_clock", 0, Pins("F19"), IOStandard("LVCMOS33")),
|
||||
("sdram", 0,
|
||||
Subsignal("a", Pins(
|
||||
|
@ -47,11 +51,7 @@ _io_common = [
|
|||
Misc("SLEWRATE=FAST"),
|
||||
),
|
||||
|
||||
("wifi_gpio0", 0, Pins("L2"), IOStandard("LVCMOS33")),
|
||||
|
||||
("ext0p", 0, Pins("B11"), IOStandard("LVCMOS33")),
|
||||
("ext1p", 0, Pins("A10"), IOStandard("LVCMOS33")),
|
||||
|
||||
# GPIOs
|
||||
("gpio", 0,
|
||||
Subsignal("p", Pins("B11")),
|
||||
Subsignal("n", Pins("C11")),
|
||||
|
@ -73,12 +73,15 @@ _io_common = [
|
|||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# USB
|
||||
("usb", 0,
|
||||
Subsignal("d_p", Pins("D15")),
|
||||
Subsignal("d_n", Pins("E15")),
|
||||
Subsignal("pullup", Pins("B12 C12")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
# OLED
|
||||
("oled_spi", 0,
|
||||
Subsignal("clk", Pins("P4")),
|
||||
Subsignal("mosi", Pins("P3")),
|
||||
|
@ -90,9 +93,15 @@ _io_common = [
|
|||
Subsignal("csn", Pins("N2")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
# Others
|
||||
("wifi_gpio0", 0, Pins("L2"), IOStandard("LVCMOS33")),
|
||||
("ext0p", 0, Pins("B11"), IOStandard("LVCMOS33")),
|
||||
("ext1p", 0, Pins("A10"), IOStandard("LVCMOS33")),
|
||||
]
|
||||
|
||||
_io_1_7 = [
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("J1")),
|
||||
Subsignal("mosi", Pins("J3"), Misc("PULLMODE=UP")),
|
||||
|
@ -101,7 +110,6 @@ _io_1_7 = [
|
|||
Misc("SLEWRATE=FAST"),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("J1")),
|
||||
Subsignal("cmd", Pins("J3"), Misc("PULLMODE=UP")),
|
||||
|
@ -112,6 +120,7 @@ _io_1_7 = [
|
|||
]
|
||||
|
||||
_io_2_0 = [
|
||||
# SDCard
|
||||
("spisdcard", 0,
|
||||
Subsignal("clk", Pins("H2")),
|
||||
Subsignal("mosi", Pins("J1"), Misc("PULLMODE=UP")),
|
||||
|
@ -120,7 +129,6 @@ _io_2_0 = [
|
|||
Misc("SLEWRATE=FAST"),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("sdcard", 0,
|
||||
Subsignal("clk", Pins("H2")),
|
||||
Subsignal("cmd", Pins("J1"), Misc("PULLMODE=UP")),
|
||||
|
@ -139,7 +147,7 @@ class Platform(LatticePlatform):
|
|||
default_clk_period = 1e9/25e6
|
||||
|
||||
def __init__(self, device="LFE5U-45F", revision="2.0", **kwargs):
|
||||
assert device in ["LFE5U-25F", "LFE5U-45F", "LFE5U-85F"]
|
||||
assert device in ["LFE5U-12F", "LFE5U-25F", "LFE5U-45F", "LFE5U-85F"]
|
||||
assert revision in ["1.7", "2.0"]
|
||||
_io = _io_common + {"1.7": _io_1_7, "2.0": _io_2_0}[revision]
|
||||
LatticePlatform.__init__(self, device + "-6BG381C", _io, **kwargs)
|
||||
|
|
|
@ -12,9 +12,11 @@ from litex.build.lattice.programmer import OpenOCDJTAGProgrammer
|
|||
# IOs ----------------------------------------------------------------------------------------------
|
||||
|
||||
_io = [
|
||||
# Clk / Rst
|
||||
("clk100", 0, Pins("P3"), IOStandard("LVDS")),
|
||||
("rst_n", 0, Pins("T1"), IOStandard("LVCMOS33")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("E16"), IOStandard("LVCMOS25")),
|
||||
("user_led", 1, Pins("D17"), IOStandard("LVCMOS25")),
|
||||
("user_led", 2, Pins("D18"), IOStandard("LVCMOS25")),
|
||||
|
@ -24,6 +26,7 @@ _io = [
|
|||
("user_led", 6, Pins("E17"), IOStandard("LVCMOS25")),
|
||||
("user_led", 7, Pins("F16"), IOStandard("LVCMOS25")),
|
||||
|
||||
# Switches
|
||||
("user_dip_btn", 0, Pins("H2"), IOStandard("LVCMOS15")),
|
||||
("user_dip_btn", 1, Pins("K3"), IOStandard("LVCMOS15")),
|
||||
("user_dip_btn", 2, Pins("G3"), IOStandard("LVCMOS15")),
|
||||
|
@ -33,11 +36,13 @@ _io = [
|
|||
("user_dip_btn", 6, Pins("K19"), IOStandard("LVCMOS25")),
|
||||
("user_dip_btn", 7, Pins("K20"), IOStandard("LVCMOS25")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("rx", Pins("C11"), IOStandard("LVCMOS33")),
|
||||
Subsignal("tx", Pins("A11"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
# SPIFlash
|
||||
("spiflash", 0, # clock needs to be accessed through USRMCLK
|
||||
Subsignal("cs_n", Pins("R2")),
|
||||
Subsignal("mosi", Pins("W2")),
|
||||
|
@ -46,13 +51,14 @@ _io = [
|
|||
Subsignal("hold", Pins("W1")),
|
||||
IOStandard("LVCMOS33"),
|
||||
),
|
||||
|
||||
("spiflash4x", 0, # clock needs to be accessed through USRMCLK
|
||||
Subsignal("cs_n", Pins("R2")),
|
||||
Subsignal("dq", Pins("W2 V2 Y2 W1")),
|
||||
IOStandard("LVCMOS33")
|
||||
),
|
||||
|
||||
|
||||
# DDR3 SDRAM
|
||||
("ddram", 0,
|
||||
Subsignal("a", Pins(
|
||||
"P2 C4 E5 F5 B3 F4 B5 E4",
|
||||
|
@ -79,6 +85,7 @@ _io = [
|
|||
Misc("SLEWRATE=FAST"),
|
||||
),
|
||||
|
||||
# RGMII Ethernet
|
||||
("eth_clocks", 0,
|
||||
Subsignal("tx", Pins("P19")),
|
||||
Subsignal("rx", Pins("L20")),
|
||||
|
@ -94,7 +101,6 @@ _io = [
|
|||
Subsignal("tx_data", Pins("N19 N20 P18 P20")),
|
||||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("eth_clocks", 1,
|
||||
Subsignal("tx", Pins("C20")),
|
||||
Subsignal("rx", Pins("J19")),
|
||||
|
@ -111,12 +117,7 @@ _io = [
|
|||
IOStandard("LVCMOS25")
|
||||
),
|
||||
|
||||
("ext_clk", 0,
|
||||
Subsignal("p", Pins("A4")),
|
||||
Subsignal("n", Pins("A5")),
|
||||
IOStandard("LVDS")
|
||||
),
|
||||
|
||||
# PCIe
|
||||
("pcie_x1", 0,
|
||||
Subsignal("clk_p", Pins("Y11")),
|
||||
Subsignal("clk_n", Pins("Y12")),
|
||||
|
@ -127,6 +128,14 @@ _io = [
|
|||
Subsignal("perst", Pins("A6"), IOStandard("LVCMOS33")),
|
||||
),
|
||||
|
||||
# External Clock
|
||||
("ext_clk", 0,
|
||||
Subsignal("p", Pins("A4")),
|
||||
Subsignal("n", Pins("A5")),
|
||||
IOStandard("LVDS")
|
||||
),
|
||||
|
||||
# Ref Clock
|
||||
("refclk_en", 0, Pins("C12"), IOStandard("LVCMOS33")),
|
||||
("refclk_rst_n", 0, Pins("R1"), IOStandard("LVCMOS33")),
|
||||
("refclk", 0,
|
||||
|
@ -138,6 +147,7 @@ _io = [
|
|||
Subsignal("n", Pins("W20")),
|
||||
),
|
||||
|
||||
# SMA
|
||||
("sma_tx", 0,
|
||||
Subsignal("p", Pins("W8")),
|
||||
Subsignal("n", Pins("W9")),
|
||||
|
@ -148,6 +158,7 @@ _io = [
|
|||
),
|
||||
]
|
||||
|
||||
# ECP5-hat extension (https://github.com/daveshah1/ecp5-hat) ---------------------------------------
|
||||
|
||||
_ecp5_soc_hat_io = [
|
||||
("sdram_clock", 0, Pins("E14"), IOStandard("LVCMOS33")),
|
||||
|
|
Loading…
Reference in New Issue