# # This file is part of LiteX-Boards. # # Copyright (c) 2023-2024 Florent Kermarrec # SPDX-License-Identifier: BSD-2-Clause from litex.build.generic_platform import * from litex.build.xilinx import XilinxUSPPlatform from litex.build.openfpgaloader import OpenFPGALoader # IOs ---------------------------------------------------------------------------------------------- _io = [ # Clk / Rst. ("clk33", 0, Pins("P19"), IOStandard("SSTL12")), ("clk100", 0, Subsignal("n", Pins("AJ6"), IOStandard("DIFF_SSTL12_DCI")), Subsignal("p", Pins("AH6"), IOStandard("DIFF_SSTL12_DCI")), ), # Leds. ("user_led", 0, Pins("AF13"), IOStandard("LVCMOS12")), # Serial. ("serial", 0, Subsignal("tx", Pins("C14")), # ANIO IO_D22_P. Subsignal("rx", Pins("B14")), # ANIO IO_D23_N. IOStandard("LVCMOS18") ), ("debug", 0, Pins("G13"), IOStandard("LVCMOS18")), ("debug", 0, Pins("F13"), IOStandard("LVCMOS18")), # I2C. ("i2c_user", 0, Subsignal("scl", Pins("K15"), Misc("PULLUP=True")), Subsignal("sda", Pins("K14"), Misc("PULLUP=True")), IOStandard("LVCMOS12") ), ("i2c_mgmt", 0, Subsignal("scl", Pins("AB13"), Misc("PULLUP=True")), Subsignal("sda", Pins("AH13"), Misc("PULLUP=True")), IOStandard("LVCMOS12") ), # PCIe. ("pcie_x4", 0, # GTH Bank 227. Subsignal("rst_n", Pins("AF2"), IOStandard("LVCMOS12"), Misc("PULLUP=TRUE")), Subsignal("clk_p", Pins("B10")), Subsignal("clk_n", Pins("B9")), Subsignal("rx_p", Pins("D2 C4 B2 A4")), Subsignal("rx_n", Pins("D1 C3 B1 A3")), Subsignal("tx_p", Pins("D6 C8 B6 A8")), Subsignal("tx_n", Pins("D5 C7 B5 A7")), ), ("pcie_x8", 0, # GTH Bank 227 and 226. Subsignal("rst_n", Pins("AF2"), IOStandard("LVCMOS12"), Misc("PULLUP=TRUE")), Subsignal("clk_p", Pins("B10")), Subsignal("clk_n", Pins("B9")), Subsignal("rx_p", Pins("D2 C4 B2 A4 H2 G4 F2 E4")), Subsignal("rx_n", Pins("D1 C3 B1 A3 H1 G3 F1 E3")), Subsignal("tx_p", Pins("D6 C8 B6 A8 H6 G8 F6 E8")), Subsignal("tx_n", Pins("D5 C7 B5 A7 H5 G7 F5 E7")), ), # DDR4 SDRAM. ("ddram", 0, Subsignal("a", Pins( "AG6 AG5 AK7 AK6 AJ4 AK4 AF6 AF5", "AH4 AK3 AK2 AJ2 AJ1 AH3"), IOStandard("SSTL12_DCI")), Subsignal("we_n", Pins("AH2"), IOStandard("SSTL12_DCI")), # A14 Subsignal("cas_n", Pins("AG4"), IOStandard("SSTL12_DCI")), # A15 Subsignal("ras_n", Pins("AG3"), IOStandard("SSTL12_DCI")), # A16 Subsignal("ba", Pins("AH1 AF3"), IOStandard("SSTL12_DCI")), Subsignal("bg", Pins("AF8 AF7"), IOStandard("SSTL12_DCI")), Subsignal("cs_n", Pins("AE9"), IOStandard("SSTL12_DCI")), Subsignal("act_n", Pins("AG1"), IOStandard("SSTL12_DCI")), Subsignal("dm", Pins("AA13 AG13 AF16 AG16"), IOStandard("POD12_DCI")), Subsignal("dq", Pins( "AB15 AE15 AD15 AE14 AC14 AD14 AA15 AE13", "AH14 AK13 AG15 AK12 AG14 AK14 AF15 AJ14", "AC16 AE19 AD17 AD19 AC17 AE17 AC18 AD16", "AE18 AK16 AG18 AJ17 AH17 AH18 AJ16 AF18"), IOStandard("POD12_DCI"), Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_p", Pins("AA14 AJ15 AA16 AK17"), IOStandard("DIFF_POD12_DCI"), Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_n", Pins("AB14 AK15 AB16 AK18"), IOStandard("DIFF_POD12_DCI"), Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("clk_p", Pins("AJ5"), IOStandard("DIFF_SSTL12_DCI")), Subsignal("clk_n", Pins("AK5"), IOStandard("DIFF_SSTL12_DCI")), Subsignal("cke", Pins("AE8"), IOStandard("SSTL12_DCI")), Subsignal("odt", Pins("AF1"), IOStandard("SSTL12_DCI")), Subsignal("reset_n", Pins("AG9"), IOStandard("LVCMOS12")), Misc("SLEW=FAST"), ), ] # Connectors --------------------------------------------------------------------------------------- def j800_io(n): return { 15 : "C14", 16 : "G13", 17 : "B14", 18 : "F13", 19 : "K13", 21 : "J12", 22 : "H13", 24 : "H12", 25 : "H14", 27 : "G14", 28 : "D12", 30 : "C12", 31 : "C17", 33 : "B16", 34 : "A14", 36 : "A13", 37 : "F12", 39 : "E12", 40 : "B12", 42 : "A12", 43 : "E14", 45 : "E13", 46 : "D14", 48 : "C13", 49 : "G16", 51 : "G15", 52 : "F16", 54 : "F15", 55 : "K15", 57 : "K14", 58 : "K12", 60 : "K11", 61 : "J16", 63 : "H16", 64 : "J15", 66 : "J14", 67 : "D16", 69 : "C16", 70 : "L15", 72 : "L14", 73 : "B15", 75 : "A15", 76 : "E15", 78 : "D15", 79 : "A17", 81 : "A16", 85 : "E17", 87 : "D17", 88 : "AF17", 90 : "AC19", 92 : "AH16", 94 : "AG19", 111 : "AB13", 113 : "AH13", }[n] def j801_io(n): return { 3 : "B10" , 4 : "M23", 5 : "B9" , 6 : "M24" , 7 : "L25", 9 : "L26", 10 : "D10" , 12 : "D9" , 13 : "M27" , 16 : "L29", 17 : "M28" , 20 : "L30" , 21 : "K27", 24 : "J29", 25 : "K28" , 28 : "J30" , 29 : "J25" , 32 : "H27", 33 : "J26" , 36 : "H28" , 37 : "G25", 40 : "G29", 41 : "G26" , 44 : "G30" , 45 : "D6" , 47 : "D5" , 48 : "D2" , 50 : "D1" , 51 : "C8" , 53 : "C7" , 54 : "C4" , 56 : "C3" , 60 : "B2" , 62 : "B1" , 63 : "B6" , 65 : "B5" , 66 : "A4" , 68 : "A3" , 69 : "A8" , 71 : "A7" , 72 : "AB1" , 74 : "AC1", 78 : "AC8" , 80 : "AC7" , 84 : "AD1", 86 : "AE1", 90 : "AA2" , 92 : "AA1" , 94 : "AD2" , 96 : "AE2", 100 : "AA3" , 102 : "AB3" , 104 : "AC3", 106 : "AC2", 110 : "AD4" , 112 : "AE4" , 114 : "AB4" , 116 : "AC4", 120 : "AD5" , 122 : "AE5" , 124 : "AA6", 126 : "AA5", 129 : "AE3" , 130 : "AB6" , 131 : "Y1" , 132 : "AB5", 133 : "AD11", 135 : "AD10", 136 : "AC6", 138 : "AD6", 139 : "Y10" , 141 : "AA10", 142 : "Y7" , 144 : "AA7", 145 : "AA12", 147 : "AA11", 148 : "W8" , 150 : "Y8" , 151 : "AD7" , 153 : "AE7" , 154 : "AA8" , 156 : "AB8", 157 : "AB11", 159 : "AC11", 160 : "AC9", 162 : "AD9", 163 : "AC12", 164 : "AB10", 165 : "AD12", 166 : "AB9", }[n] def j900_io(n): return { 3 : "L8" , 4 : "H10" , 5 : "L7" , 6 : "H9" , 7 : "J8", 9 : "J7", 10 : "F10", 12 : "F9", 13 : "H6" , 16 : "H2" , 17 : "H5" , 20 : "H1" , 21 : "G8", 24 : "G4", 25 : "G7", 28 : "G3", 29 : "F6" , 32 : "F2" , 33 : "F5" , 36 : "F1" , 37 : "E8", 40 : "E4", 41 : "E7", 44 : "E3", 45 : "P6" , 47 : "P5" , 48 : "N4" , 50 : "N3" , 51 : "M6", 53 : "M5", 54 : "M2", 56 : "M1", 57 : "L4" , 59 : "L3" , 60 : "K2" , 62 : "K1" , 63 : "K6", 65 : "K5", 66 : "J4", 68 : "J3", 69 : "N8" , 71 : "N7" , 72 : "R8" , 74 : "R7" , 75 : "W4", 77 : "W3", 78 : "V2", 79 : "V6", 80 : "V1" , 81 : "V5" , 82 : "U4" , 84 : "U3" , 85 : "T6", 87 : "T5", 88 : "T2", 89 : "R4", 90 : "T1" , 91 : "R3" , 92 : "P2" , 94 : "P1" , 139 : "AH9", 141 : "AJ9", 142 : "AK9", 144 : "AK8", 145 : "AF12", 147 : "AF11", 148 : "AH7" , 150 : "AJ7" , 151 : "AG8", 153 : "AH8", 154 : "AG11", 156 : "AH11", 157 : "AF10", 159 : "AG10", 160 : "AH12", 161 : "AJ11", 162 : "AJ12", 163 : "AK11", 164 : "AJ10", 166 : "AK10", }[n] _connectors = [ ("HPC", { "DP1_M2C_P" : "M2", "DP1_M2C_N" : "M1", "DP2_M2C_P" : "K2", "DP2_M2C_N" : "K1", "DP3_M2C_P" : "J4", "DP3_M2C_N" : "J3", "DP1_C2M_P" : "M6", "DP1_C2M_N" : "M5", "DP2_C2M_P" : "L4", "DP2_C2M_N" : "L3", "DP3_C2M_P" : "K6", "DP3_C2M_N" : "K5", "DP0_C2M_P" : "P6", "DP0_C2M_N" : "P5", "DP0_M2C_P" : "N4", "DP0_M2C_N" : "N3", "LA06_P" : j801_io(136), "LA06_N" : j801_io(138), "LA10_P" : j801_io(110), "LA10_N" : j801_io(112), "LA14_P" : j801_io( 90), "LA14_N" : j801_io( 92), #"LA18_CC_P" : j801_io(123), #"LA18_CC_N" : j801_io(125), #"LA27_P" : j801_io(107), #"LA27_N" : j801_io(109), "HA01_CC_P" : j900_io(151), "HA01_CC_N" : j900_io(153), "HA05_P" : j900_io(157), "HA05_N" : j900_io(159), "HA09_P" : j900_io(139), "HA09_N" : j900_io(141), #"HA13_P" : j900_io(129), #"HA13_N" : j900_io(131), #"HA16_P" : j900_io(118), #"HA16_N" : j900_io(120), #"HA20_P" : j900_io(112), #"HA20_N" : j900_io(114), #"CLK1_M2C_P" : j801_io( 57), #"CLK1_M2C_N" : j801_io( 59), "LA00_CC_P" : j801_io(154), "LA00_CC_N" : j801_io(156), "LA03_P" : j801_io(160), "LA03_N" : j801_io(162), "LA08_P" : j801_io(120), "LA08_N" : j801_io(122), "LA12_P" : j801_io(100), "LA12_N" : j801_io(102), "LA16_P" : j801_io( 72), "LA16_N" : j801_io( 74), "LA20_P" : j801_io(157), "LA20_N" : j801_io(159), "LA22_P" : j801_io(139), "LA22_N" : j801_io(141), #"LA25_P" : j801_io(117), #"LA25_N" : j801_io(119), #"LA29_P" : j801_io( 97), #"LA29_N" : j801_io( 99), #"LA31_P" : j801_io( 87), #"LA31_N" : j801_io( 89), #"LA33_P" : j801_io( 75), #"LA33_N" : j801_io( 77), "HA03_P" : j900_io(161), "HA03_N" : j900_io(163), "HA07_P" : j900_io(145), "HA07_N" : j900_io(147), #"HA11_P" : j900_io(135), #"HA11_N" : j900_io(137), #"HA14_P" : j900_io(128), #"HA14_N" : j900_io(130), #"HA18_P" : j900_io(115), #"HA18_N" : j900_io(117), #"HA22_P" : j900_io(108), #"HA22_N" : j900_io(110), #"GBTCLK1_M2C_P" : "X", #"GBTCLK1_M2C_N" : "X", "GBTCLK0_M2C_P" : "L8", # refclk7 "GBTCLK0_M2C_N" : "L7", # refclk7 "LA01_CC_P" : j801_io(130), "LA01_CC_N" : j801_io(132), "LA05_P" : j801_io(142), "LA05_N" : j801_io(144), "LA09_P" : j801_io(114), "LA09_N" : j801_io(116), "LA13_P" : j801_io( 94), "LA13_N" : j801_io( 96), "LA17_CC_P" : j801_io(151), "LA17_CC_N" : j801_io(153), "LA23_P" : j801_io(133), "LA23_N" : j801_io(135), #"LA26_P" : j801_io(111), #"LA26_N" : j801_io(113), #"PG_M2C" : "", "HA00_CC_P" : j900_io(148), "HA00_CC_N" : j900_io(150), "HA04_P" : j900_io(160), "HA04_N" : j900_io(162), "HA08_P" : j900_io(142), "HA08_N" : j900_io(144), #"HA12_P" : j900_io(132), #"HA12_N" : j900_io(134), #"HA15_P" : j900_io(125), #"HA15_N" : j900_io(127), #"HA19_P" : j900_io(119), #"HA19_N" : j900_io(121), "PRSNT_M2C_B" : "", "CLK0_M2C_P" : j801_io( 78), "CLK0_M2C_N" : j801_io( 80), "LA02_P" : j801_io(164), "LA02_N" : j801_io(166), "LA04_P" : j801_io(148), "LA04_N" : j801_io(150), "LA07_P" : j801_io(124), "LA07_N" : j801_io(126), "LA11_P" : j801_io(104), "LA11_N" : j801_io(106), "LA15_P" : j801_io( 84), "LA15_N" : j801_io( 86), "LA19_P" : j801_io(163), "LA19_N" : j801_io(165), "LA21_P" : j801_io(145), "LA21_N" : j801_io(147), "LA24_P" : j801_io(129), "LA24_N" : j801_io(131), #"LA28_P" : j801_io(101), #"LA28_N" : j801_io(103), #"LA30_P" : j801_io( 91), #"LA30_N" : j801_io( 93), #"LA32_P" : j801_io( 81), #"LA32_N" : j801_io( 83), "HA02_P" : j900_io(164), "HA02_N" : j900_io(166), "HA06_P" : j900_io(154), "HA06_N" : j900_io(156), #"HA10_P" : j900_io(138), #"HA10_N" : j900_io(140), #"HA17_CC_P" : j900_io(122), #"HA17_CC_N" : j900_io(124), #"HA21_P" : j900_io(109), #"HA21_N" : j900_io(111), #"HA23_P" : j900_io(105), #"HA23_N" : j900_io(107), }) ] # Platform ----------------------------------------------------------------------------------------- class Platform(XilinxUSPPlatform): default_clk_name = "clk100" default_clk_period = 1e9/100e6 def __init__(self, toolchain="vivado"): XilinxUSPPlatform.__init__(self, "xczu7ev-fbvb900-2-i", _io, _connectors, toolchain=toolchain) def create_programmer(self): return OpenFPGALoader(fpga_part="xczu7ev", cable="ft2232") def do_finalize(self, fragment): XilinxUSPPlatform.do_finalize(self, fragment) self.add_period_constraint(self.lookup_request("clk100", loose=True), 1e9/100e6) self.add_period_constraint(self.lookup_request("clk33", loose=True), 1e9/33e6) self.add_platform_command("set_property BITSTREAM.CONFIG.OVERTEMPSHUTDOWN ENABLE [current_design]") self.add_platform_command("set_property BITSTREAM.CONFIG.UNUSEDPIN PULLNONE [current_design]") self.add_platform_command("set_property INTERNAL_VREF 0.600 [get_iobanks 64]")