From 5519c931f8657e15b92729159933cce6ad08ed78 Mon Sep 17 00:00:00 2001 From: Sergiu Mosanu Date: Mon, 12 Apr 2021 08:06:15 +0200 Subject: [PATCH] xilinx_alveo_u280: Fix DDR4 (tested with 8 modules on C0 and C1). --- litex_boards/platforms/xilinx_alveo_u280.py | 65 +++++++++++---------- litex_boards/targets/xilinx_alveo_u280.py | 6 +- 2 files changed, 37 insertions(+), 34 deletions(-) diff --git a/litex_boards/platforms/xilinx_alveo_u280.py b/litex_boards/platforms/xilinx_alveo_u280.py index e93e64c..345f359 100644 --- a/litex_boards/platforms/xilinx_alveo_u280.py +++ b/litex_boards/platforms/xilinx_alveo_u280.py @@ -13,14 +13,13 @@ from litex.build.xilinx import XilinxPlatform, VivadoProgrammer _io = [ # Clk / Rst ("sysclk", 0, - Subsignal("n", Pins("BJ44"), IOStandard("LVDS")), - Subsignal("p", Pins("BJ43"), IOStandard("LVDS")), + Subsignal("n", Pins("BJ44"), IOStandard("DIFF_SSTL12")), + Subsignal("p", Pins("BJ43"), IOStandard("DIFF_SSTL12")), ), ("sysclk", 1, - Subsignal("n", Pins("BJ6"), IOStandard("LVDS")), - Subsignal("p", Pins("BH6"), IOStandard("LVDS")), + Subsignal("n", Pins("BJ6"), IOStandard("DIFF_SSTL12")), + Subsignal("p", Pins("BH6"), IOStandard("DIFF_SSTL12")), ), - ("cpu_reset", 0, Pins("L30"), IOStandard("LVCMOS18")), # Leds @@ -46,16 +45,18 @@ _io = [ ("ddram", 0, Subsignal("a", Pins( "BF46 BG43 BK45 BF42 BL45 BF43 BG42 BL43", - "BK43 BM42 BG45 BD41 BL42 BE44"), + "BK43 BM42 BG45 BD41 BL42 BE44"), # we_n=BE43 cas_n=BL46 ras_n=BH44 IOStandard("SSTL12_DCI")), + Subsignal("we_n", Pins("BE43"), IOStandard("SSTL12_DCI")), # A14 + Subsignal("cas_n", Pins("BL46"), IOStandard("SSTL12_DCI")), # A15 + Subsignal("ras_n", Pins("BH44"), IOStandard("SSTL12_DCI")), # A16 Subsignal("act_n", Pins("BH41"), IOStandard("SSTL12_DCI")), Subsignal("ba", Pins("BH45 BM47"), IOStandard("SSTL12_DCI")), Subsignal("bg", Pins("BF41 BE41"), IOStandard("SSTL12_DCI")), - Subsignal("cas_n", Pins("BL46"), IOStandard("SSTL12_DCI")), # A15 Subsignal("cke", Pins("BH42"), IOStandard("SSTL12_DCI")), Subsignal("clk_n", Pins("BJ46"), IOStandard("DIFF_SSTL12_DCI")), Subsignal("clk_p", Pins("BH46"), IOStandard("DIFF_SSTL12_DCI")), - Subsignal("cs_n", Pins("BK46"), IOStandard("SSTL12_DCI")), + Subsignal("cs_n", Pins("BK46"), IOStandard("SSTL12_DCI")), Subsignal("dq", Pins( "BN32 BP32 BL30 BM30 BP29 BP28 BP31 BN31", "BJ31 BH31 BF32 BF33 BH29 BH30 BF31 BG32", @@ -65,40 +66,42 @@ _io = [ "BE50 BE49 BE51 BD51 BF52 BF51 BG50 BF50", "BH50 BJ51 BH51 BH49 BK50 BK51 BJ49 BJ48", "BN44 BN45 BM44 BM45 BP43 BP44 BN47 BP47"), + # ECC excluded 8 pins + # "BG54 BG53 BE53 BE54 BH52 BG52 BK54 BK53" IOStandard("POD12_DCI"), Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_n", Pins( "BN30 BM29 BK30 BG30 BM35 BN35 BK35 BJ32", "BM50 BP49 BF48 BG49 BJ47 BK49 BP46 BP42"), #"BJ54 BJ53" - IOStandard("DIFF_POD12"), + IOStandard("DIFF_POD12"), # DIFF_POD12_DCI Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_p", Pins( "BN29 BM28 BJ29 BG29 BL35 BM34 BK34 BH32", "BM49 BP48 BF47 BG48 BH47 BK48 BN46 BN42"), #"BH54 BJ52" - IOStandard("DIFF_POD12"), + IOStandard("DIFF_POD12"), # DIFF_POD12_DCI Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("odt", Pins("BG44"), IOStandard("SSTL12_DCI")), - Subsignal("ras_n", Pins("BH44"), IOStandard("SSTL12_DCI")), # A16 Subsignal("reset_n", Pins("BG33"), IOStandard("LVCMOS12")), - Subsignal("we_n", Pins("BE43"), IOStandard("SSTL12_DCI")), # A14 Misc("SLEW=FAST") ), ("ddram", 1, Subsignal("a", Pins( "BF7 BK1 BF6 BF5 BE3 BE6 BE5 BG7", - "BJ1 BG2 BJ8 BE4 BL2 BK5"), # BK8 BJ4 BF8 + "BJ1 BG2 BJ8 BE4 BL2 BK5"), # we_n=BK8 cas_n=BJ4 ras_n=BF8 IOStandard("SSTL12_DCI")), + Subsignal("we_n", Pins("BK8"), IOStandard("SSTL12_DCI")), # A14 + Subsignal("cas_n", Pins("BJ4"), IOStandard("SSTL12_DCI")), # A15 + Subsignal("ras_n", Pins("BF8"), IOStandard("SSTL12_DCI")), # A16 Subsignal("act_n", Pins("BG3"), IOStandard("SSTL12_DCI")), Subsignal("ba", Pins("BG8 BK4"), IOStandard("SSTL12_DCI")), Subsignal("bg", Pins("BF3 BF2"), IOStandard("SSTL12_DCI")), - Subsignal("cas_n", Pins("BJ4"), IOStandard("SSTL12_DCI")), # A15 Subsignal("cke", Pins("BE1"), IOStandard("SSTL12_DCI")), Subsignal("clk_n", Pins("BJ2"), IOStandard("DIFF_SSTL12_DCI")), Subsignal("clk_p", Pins("BJ3"), IOStandard("DIFF_SSTL12_DCI")), - Subsignal("cs_n", Pins("BL3"), IOStandard("SSTL12_DCI")), + Subsignal("cs_n", Pins("BL3"), IOStandard("SSTL12_DCI")), Subsignal("dq", Pins( "A11 A10 A9 A8 B12 B10 C12 B11", "E11 D11 E12 F11 F10 E9 F9 G11", @@ -108,25 +111,25 @@ _io = [ "BJ9 BK9 BK10 BL10 BM9 BN9 BN10 BM10", "BM15 BM14 BL15 BM13 BN12 BM12 BP13 BP14", "BJ13 BJ12 BH15 BH14 BK14 BK15 BL12 BL13"), + # ECC excluded 8 pins + # "BE9 BE10 BF10 BE11 BG13 BG12 BG9 BG10" IOStandard("POD12_DCI"), Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_n", Pins( - "A13 D9 G15 D14 BM7 BM8 BN14 BK13", - "BF11 C9 G10 K13 D12 BP6 BP8 BP11"), # "BK11 BH9" - IOStandard("DIFF_POD12"), + "A13 C9 D9 G10 G15 K13 D14 D12", + "BM7 BP6 BM8 BP8 BN14 BP11 BK13 BK11"), #"BF11 BH9" + IOStandard("DIFF_POD12"), # DIFF_POD12_DCI Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("dqs_p", Pins( "B13 C10 D10 H10 H15 K14 D15 E13", - "BL7 BP7 BL8 BP9 BN15 BP12 BJ14 BJ11"), #"BH54 BJ52" - IOStandard("DIFF_POD12"), + "BL7 BP7 BL8 BP9 BN15 BP12 BJ14 BJ11"), #"BF12 BH10" + IOStandard("DIFF_POD12"), # DIFF_POD12_DCI Misc("PRE_EMPHASIS=RDRV_240"), Misc("EQUALIZATION=EQ_LEVEL2")), Subsignal("odt", Pins("BH2"), IOStandard("SSTL12_DCI")), - Subsignal("ras_n", Pins("BF8"), IOStandard("SSTL12_DCI")), # A16 Subsignal("reset_n", Pins("BH12"), IOStandard("LVCMOS12")), - Subsignal("we_n", Pins("BK8"), IOStandard("SSTL12_DCI")), # A14 Misc("SLEW=FAST") ), ] @@ -166,12 +169,12 @@ class Platform(XilinxPlatform): self.add_platform_command("set_property INTERNAL_VREF 0.84 [get_iobanks 70]") # Other suggested configurations - self.add_platform_command("set_property CONFIG_VOLTAGE 1.8 [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.CONFIGFALLBACK Enable [current_design]") - self.add_platform_command("set_property CONFIG_MODE SPIx4 [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.CONFIGRATE 85.0 [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.EXTMASTERCCLK_EN disable [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_FALL_EDGE YES [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.UNUSEDPIN Pullup [current_design]") - self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_32BIT_ADDR Yes [current_design]") \ No newline at end of file + # self.add_platform_command("set_property CONFIG_VOLTAGE 1.8 [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.CONFIGFALLBACK Enable [current_design]") + # self.add_platform_command("set_property CONFIG_MODE SPIx4 [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.CONFIGRATE 85.0 [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.EXTMASTERCCLK_EN disable [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_FALL_EDGE YES [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.UNUSEDPIN Pullup [current_design]") + # self.add_platform_command("set_property BITSTREAM.CONFIG.SPI_32BIT_ADDR Yes [current_design]") \ No newline at end of file diff --git a/litex_boards/targets/xilinx_alveo_u280.py b/litex_boards/targets/xilinx_alveo_u280.py index 2a63afc..11ffee3 100755 --- a/litex_boards/targets/xilinx_alveo_u280.py +++ b/litex_boards/targets/xilinx_alveo_u280.py @@ -41,7 +41,7 @@ class _CRG(Module): self.comb += pll.reset.eq(self.rst) pll.register_clkin(platform.request("sysclk", ddram_channel), 100e6) pll.create_clkout(self.cd_pll4x, sys_clk_freq*4, buf=None, with_reset=False) - pll.create_clkout(self.cd_idelay, 500e6) + pll.create_clkout(self.cd_idelay, 600e6, with_reset=False) platform.add_false_path_constraints(self.cd_sys.clk, pll.clkin) # Ignore sys_clk to pll.clkin path created by SoC's rst. self.specials += [ @@ -57,7 +57,7 @@ class _CRG(Module): # BaseSoC ------------------------------------------------------------------------------------------ class BaseSoC(SoCCore): - def __init__(self, sys_clk_freq=int(125e6), ddram_channel=0, with_pcie=False, **kwargs): + def __init__(self, sys_clk_freq=int(150e6), ddram_channel=0, with_pcie=False, **kwargs): platform = alveo_u280.Platform() # SoCCore ---------------------------------------------------------------------------------- @@ -104,7 +104,7 @@ def main(): parser = argparse.ArgumentParser(description="LiteX SoC on Alveo U280") parser.add_argument("--build", action="store_true", help="Build bitstream") parser.add_argument("--load", action="store_true", help="Load bitstream") - parser.add_argument("--sys-clk-freq", default=125e6, help="System clock frequency (default: 125MHz)") + parser.add_argument("--sys-clk-freq", default=150e6, help="System clock frequency (default: 150MHz)") parser.add_argument("--ddram-channel",default="0", help="DDRAM channel (default: 0)") parser.add_argument("--with-pcie", action="store_true", help="Enable PCIe support") parser.add_argument("--driver", action="store_true", help="Generate PCIe driver")