# # This file is part of LiteX-Boards. # # Copyright (c) 2023 Hans Baier # SPDX-License-Identifier: BSD-2-Clause from litex.build.generic_platform import Subsignal, Pins, IOStandard, Misc class EnclustraST1: """ the ST1 baseboard contains standard peripherals and can be used with a number of different FPGA core boards the default VCCIO values are from the jumper positions from the example design in the manual """ def __init__(self, vccio_a="1.8V", vccio_b="1.8V", vccio_c="1.8V") -> None: def strip_v(s, is_a = False): assert s in [ "1.2V" if not is_a else None, "1.8V", # VCC_OUT_B "2.5V", # VCC_OUT_A "3.3V" ] return s.replace(".", "").replace("V", "") vccio_a = strip_v(vccio_a) # Bank 12, 14 vccio_b = strip_v(vccio_b) # Bank 15, 16 vccio_c = strip_v(vccio_c) # Bank 13 self.io = [ ("clk_ref", 0, Subsignal("p", Pins("C:7"), IOStandard("LVDS")), Subsignal("n", Pins("C:9"), IOStandard("LVDS")) ), ("clk_ref0", 0, Subsignal("p", Pins("B:3"), IOStandard("LVDS")), Subsignal("n", Pins("B:5"), IOStandard("LVDS")) ), ("clk_ref1", 0, Subsignal("p", Pins("C:10"), IOStandard("LVDS")), Subsignal("n", Pins("C:12"), IOStandard("LVDS")) ), ("clk_ref2", 0, Subsignal("p", Pins("C:3"), IOStandard("LVDS")), Subsignal("n", Pins("C:5"), IOStandard("LVDS")) ), # daughterboard LEDs ("user_led", 4, Pins("C:142"), IOStandard("LVCMOS" + vccio_c), Misc("SLEW=SLOW")), ("user_led", 5, Pins("C:144"), IOStandard("LVCMOS" + vccio_c), Misc("SLEW=SLOW")), ("i2c", 0, Subsignal("scl", Pins("A:111"), Misc("SLEW=SLOW")), Subsignal("sda", Pins("A:113"), Misc("SLEW=SLOW")), Subsignal("int_n", Pins("A:115"), Misc("SLEW=SLOW")), IOStandard("LVCMOS" + vccio_a) ), ("i2c_fpga", 0, Subsignal("scl", Pins("A:55"), Misc("SLEW=SLOW")), Subsignal("sda", Pins("A:57"), Misc("SLEW=SLOW")), IOStandard("LVCMOS" + vccio_a) ), ("i2c_mipi_sel", 0, Pins("A63"), IOStandard("LVCMOS" + vccio_a)), # HDMI Bus ("hdmi", 0, Subsignal("clk_p", Pins("C:139")), Subsignal("clk_n", Pins("C:141")), Subsignal("data0_p", Pins("C:45")), Subsignal("data0_n", Pins("C:47")), Subsignal("data1_p", Pins("C:51")), Subsignal("data1_n", Pins("C:53")), Subsignal("data2_p", Pins("C:57")), Subsignal("data2_n", Pins("C:59")), Subsignal("hpd", Pins("A:61")), IOStandard("TMDS_33") ), ("sfp_tx", 0, # SFP A Subsignal("p", Pins("C:63")), Subsignal("n", Pins("C:65")) ), ("sfp_rx", 0, # SFP A Subsignal("p", Pins("C:66")), Subsignal("n", Pins("C:68")) ), ("usb3", 0, Subsignal("tx_p", Pins("B:29")), Subsignal("tx_n", Pins("B:33")), Subsignal("rx_p", Pins("B:32")), Subsignal("rx_n", Pins("B:36")), ), ("usb3", 1, Subsignal("tx_p", Pins("B:37")), Subsignal("tx_n", Pins("B:41")), Subsignal("rx_p", Pins("B:40")), Subsignal("rx_n", Pins("B:44")), ), ("displayport", 0, Subsignal("aux_in", Pins("A:88")), Subsignal("aux_out", Pins("A:90")), Subsignal("aux_oe", Pins("A:92")), Subsignal("hpd", Pins("A:94")), Subsignal("lanes_p", Pins("B:21 B:13 B:16 B:24")), Subsignal("lanes_n", Pins("B:25 B:17 B:20 B:28")), ), ("mipi", 0, Subsignal("clkp", Pins("C:151")), Subsignal("clkn", Pins("C:153")), Subsignal("clk_d0lp_p", Pins("C:160")), Subsignal("clk_d0lp_n", Pins("C:162")), Subsignal("dp", Pins("C:145 C:154")), Subsignal("dn", Pins("C:147 C:156")), IOStandard("MIPI_DPHY") ), ("mipi", 1, Subsignal("clkp", Pins("C:148")), Subsignal("clkn", Pins("C:150")), Subsignal("clk_d0lp_p", Pins("C:161")), Subsignal("clk_d0lp_n", Pins("C:163")), Subsignal("dp", Pins("C:164 C:157")), Subsignal("dn", Pins("C:166 C:159")), IOStandard("MIPI_DPHY") ), ] connectors = [ ("FMC", { "DP0_C2M_P": "B:45", "DP0_C2M_N": "B:47", "DP1_C2M_P": "B:51", "DP1_C2M_N": "B:53", "CLK1_M2C_P": "B:57", "CLK1_M2C_N": "B:59", "DP2_C2M_P": "B:63", "DP2_C2M_N": "B:65", "DP3_C2M_P": "B:69", "DP3_C2M_N": "B:71", "LA33_P": "B:75", "LA33_N": "B:77", "LA32_P": "B:81", "LA32_N": "B:83", "LA31_P": "B:87", "LA31_N": "B:89", "LA30_P": "B:91", "LA30_N": "B:93", "LA29_P": "B:97", "LA29_N": "B:99", "LA28_P": "B:101", "LA28_N": "B:103", "LA27_P": "B:107", "LA27_N": "B:109", "LA26_P": "B:111", "LA26_N": "B:113", "LA25_P": "B:117", "LA25_N": "B:119", "LA18_CC_P": "B:123", "LA18_CC_N": "B:125", "LA24_P": "B:129", "LA24_N": "B:131", "LA23_P": "B:133", "LA23_N": "B:135", "LA22_P": "B:139", "LA22_N": "B:141", "LA21_P": "B:145", "LA21_N": "B:147", "LA17_CC_P": "B:151", "LA17_CC_N": "B:153", "LA20_P": "B:157", "LA20_N": "B:159", "LA19_P": "B:163", "LA19_N": "B:165", "DP0_M2C_P": "B:48", "DP0_M2C_N": "B:50", "DP1_M2C_P": "B:54", "DP1_M2C_N": "B:56", "DP2_M2C_P": "B:60", "DP2_M2C_N": "B:62", "DP3_M2C_P": "B:66", "DP3_M2C_N": "B:68", "LA16_P": "B:72", "LA16_N": "B:74", "CLK0_M2C_P": "B:78", "CLK0_M2C_N": "B:80", "LA15_P": "B:84", "LA15_N": "B:86", "LA14_P": "B:90", "LA14_N": "B:92", "LA13_P": "B:94", "LA13_N": "B:96", "LA12_P": "B:100", "LA12_N": "B:102", "LA11_P": "B:104", "LA11_N": "B:106", "LA10_P": "B:110", "LA10_N": "B:112", "LA09_P": "B:114", "LA09_N": "B:116", "LA08_P": "B:120", "LA08_N": "B:122", "LA07_P": "B:124", "LA07_N": "B:126", "LA01_CC_P": "B:130", "LA01_CC_N": "B:132", "LA06_P": "B:136", "LA06_N": "B:138", "LA05_P": "B:142", "LA05_N": "B:144", "LA04_P": "B:148", "LA04_N": "B:150", "LA00_CC_P": "B:154", "LA00_CC_N": "B:156", "LA03_P": "B:160", "LA03_N": "B:162", "LA02_P": "B:164", "LA02_N": "B:166", "DP4_C2M_P": "C:13", "DP4_C2M_N": "C:17", "DP5_C2M_P": "C:21", "DP5_C2M_N": "C:25", "DP6_C2M_P": "C:29", "DP6_C2M_N": "C:33", "DP7_C2M_P": "C:37", "DP7_C2M_N": "C:41", "HA13_P": "C:69", "HA13_N": "C:71", "HA11_P": "C:75", "HA11_N": "C:77", "HA09_P": "C:79", "HA09_N": "C:81", "HA07_P": "C:85", "HA07_N": "C:87", "HA01_CC_P": "C:89", "HA01_CC_N": "C:91", "HA04_P": "C:95", "HA04_N": "C:97", "HA02_P": "C:99", "HA02_N": "C:101", "HA17_P": "C:135", "HA17_N": "C:137", "GCLK1_M2C_P": "C:4", "GCLK1_M2C_N": "C:6", "DP4_M2C_P": "C:16", "DP4_M2C_N": "C:20", "DP5_M2C_P": "C:24", "DP5_M2C_N": "C:28", "DP6_M2C_P": "C:32", "DP6_M2C_N": "C:36", "DP7_M2C_P": "C:40", "DP7_M2C_N": "C:44", "HA16_P": "C:48", "HA16_N": "C:50", "HA15_P": "C:54", "HA15_N": "C:56", "HA14_P": "C:60", "HA14_N": "C:62", "HA12_P": "C:72", "HA12_N": "C:74", "HA10_P": "C:78", "HA10_N": "C:80", "HA08_P": "C:82", "HA08_N": "C:84", "HA00_CC_P": "C:88", "HA00_CC_N": "C:90", "HA06_P": "C:92", "HA06_N": "C:94", "HA05_P": "C:98", "HA05_N": "C:100", "HA03_P": "C:102", "HA03_N": "C:104", }), ("IO1", { "CLK_P": "C:122", "CLK_N": "C:124", "D0_P": "C:115", "D1_N": "C:117", "D2_P": "C:129", "D3_N": "C:131", "D4_P": "C:125", "D5_N": "C:127", "D6_P": "C:119", "D7_N": "C:121", "D8_P": "C:109", "D9_N": "C:111", "D10_P": "C:105", "D11_N": "C:107", "D12_P": "C:138", "D13_N": "C:140", "D14_P": "C:132", "D15_N": "C:134", "D16_P": "C:128", "D17_N": "C:130", "D18_P": "C:118", "D19_N": "C:120", "D20_P": "C:112", "D21_N": "C:114", "D22_P": "C:108", "D23_N": "C:110", }),]