diff --git a/litex_boards/platforms/alveo_u280.py b/litex_boards/platforms/alveo_u280.py index 776d666..5f4de70 100644 --- a/litex_boards/platforms/alveo_u280.py +++ b/litex_boards/platforms/alveo_u280.py @@ -3,13 +3,15 @@ # # Copyright (c) 2020 David Shah <dave@ds0.me> # Copyright (c) 2020 Florent Kermarrec <florent@enjoy-digital.fr> -# Modified for Alveo U280 by Sergiu Mosanu based on XCU1525 # SPDX-License-Identifier: BSD-2-Clause +# Modified for Alveo U280 by Sergiu Mosanu based on XCU1525 and Alveo U250 + + from litex.build.generic_platform import Pins, Subsignal, IOStandard, Misc from litex.build.xilinx import XilinxPlatform, VivadoProgrammer -# IOs ---------------------------------------------------------------------------------------------- +# IOs ----------------------------------------------------------------------------------------------- _io = [ # Clk / Rst @@ -21,28 +23,56 @@ _io = [ Subsignal("n", Pins("BJ6"), IOStandard("LVDS")), Subsignal("p", Pins("BH6"), IOStandard("LVDS")), ), + + + + + + + + ("cpu_reset", 0, Pins("L30"), IOStandard("LVCMOS18")), + # Leds + ("gpio_led", 0, Pins("C32"), IOStandard("LVCMOS18")), + ("gpio_led", 1, Pins("D32"), IOStandard("LVCMOS18")), + ("gpio_led", 2, Pins("D31"), IOStandard("LVCMOS18")), + + # Switches + + ("gpio_sw", 0, Pins("J30"), IOStandard("LVCMOS18")), + ("gpio_sw", 1, Pins("J32"), IOStandard("LVCMOS18")), + ("gpio_sw", 2, Pins("K32"), IOStandard("LVCMOS18")), + ("gpio_sw", 3, Pins("K31"), IOStandard("LVCMOS18")), + + + + + + + # Serial ("serial", 0, Subsignal("rx", Pins("A28"), IOStandard("LVCMOS18")), Subsignal("tx", Pins("B33"), IOStandard("LVCMOS18")), ), + + + + # DDR4 SDRAM - #("ddram_reset_gate", 0, Pins("AU21"), IOStandard("LVCMOS12")), + #("ddram_reset_gate", 0, Pins(""), IOStandard("LVCMOS12")),??? ("ddram", 0, Subsignal("a", Pins( "BF46 BG43 BK45 BF42 BL45 BF43 BG42 BL43", - "BK43 BM42 BG45 BD41 BL42 BE44"), #"BE43 BL46 BH44" + "BK43 BM42 BG45 BD41 BL42 BE44"), IOStandard("SSTL12_DCI")), 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("ras_n", Pins("BH44"), IOStandard("SSTL12_DCI")), # A16 + 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("we_n", Pins("BE43"), IOStandard("SSTL12_DCI")), # A14 - Subsignal("cke", Pins("BH42"), IOStandard("SSTL12_DCI")), + 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")), @@ -56,28 +86,26 @@ _io = [ "BH50 BJ51 BH51 BH49 BK50 BK51 BJ49 BJ48", "BN44 BN45 BM44 BM45 BP43 BP44 BN47 BP47"), IOStandard("POD12_DCI"), - # Misc("OUTPUT_IMPEDANCE=RDRV_40_40"), 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"), - # Misc("OUTPUT_IMPEDANCE=RDRV_40_40"), 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"), - # Misc("OUTPUT_IMPEDANCE=RDRV_40_40"), 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") ), - ] # Connectors --------------------------------------------------------------------------------------- @@ -100,10 +128,29 @@ class Platform(XilinxPlatform): XilinxPlatform.do_finalize(self, fragment) self.add_period_constraint(self.lookup_request("sysclk", 0, loose=True), 1e9/100e6) self.add_period_constraint(self.lookup_request("sysclk", 1, loose=True), 1e9/100e6) + + # For passively cooled boards, overheating is a significant risk if airflow isn't sufficient self.add_platform_command("set_property BITSTREAM.CONFIG.OVERTEMPSHUTDOWN ENABLE [current_design]") # Reduce programming time self.add_platform_command("set_property BITSTREAM.GENERAL.COMPRESS TRUE [current_design]") + + + + + + + + + + + + + + + + + # 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]") diff --git a/litex_boards/targets/alveo_u280.py b/litex_boards/targets/alveo_u280.py index 9821c3b..2dbbd96 100755 --- a/litex_boards/targets/alveo_u280.py +++ b/litex_boards/targets/alveo_u280.py @@ -3,12 +3,13 @@ # # This file is part of LiteX-Boards. # +# Copyright (c) 2020 Fei Gao <feig@princeton.edu> # Copyright (c) 2020 Florent Kermarrec <florent@enjoy-digital.fr> -# Modified for Alveo U280 by Sergiu Mosanu based on XCU1525 +# Copyright (c) 2020 David Shah <dave@ds0.me> +# Modified for Alveo U280 by Sergiu Mosanu based on XCU1525 and Alveo U250 # SPDX-License-Identifier: BSD-2-Clause -import os -import argparse +import argparse, os from migen import * from migen.genlib.resetsync import AsyncResetSynchronizer @@ -29,7 +30,7 @@ from litepcie.software import generate_litepcie_software # CRG ---------------------------------------------------------------------------------------------- class _CRG(Module): - def __init__(self, platform, sys_clk_freq, ddram_channel): + def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.clock_domains.cd_sys = ClockDomain() self.clock_domains.cd_sys4x = ClockDomain(reset_less=True) @@ -40,8 +41,7 @@ class _CRG(Module): self.submodules.pll = pll = USMMCM(speedgrade=-2) self.comb += pll.reset.eq(self.rst) - #pll.register_clkin(platform.request("clk300", ddram_channel), 300e6) - pll.register_clkin(platform.request("sysclk", ddram_channel), 100e6) + pll.register_clkin(platform.request("sysclk", 0), 100e6) pll.create_clkout(self.cd_pll4x, sys_clk_freq*4, buf=None, with_reset=False) pll.create_clkout(self.cd_idelay, 500e6, 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. @@ -60,22 +60,22 @@ 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(125e6), with_pcie=False, **kwargs): platform = alveo_u280.Platform() # SoCCore ---------------------------------------------------------------------------------- SoCCore.__init__(self, platform, sys_clk_freq, ident = "LiteX SoC on Alveo U280", ident_version = True, + # bus_standard = "axi-lite", # **kwargs) # CRG -------------------------------------------------------------------------------------- - self.submodules.crg = _CRG(platform, sys_clk_freq, ddram_channel) + self.submodules.crg = _CRG(platform, sys_clk_freq) # DDR4 SDRAM ------------------------------------------------------------------------------- if not self.integrated_main_ram_size: - self.submodules.ddrphy = usddrphy.USPDDRPHY( - pads = platform.request("ddram", ddram_channel), + self.submodules.ddrphy = usddrphy.USPDDRPHY(platform.request("ddram"), memtype = "DDR4", sys_clk_freq = sys_clk_freq, iodelay_clk_freq = 500e6, @@ -106,20 +106,18 @@ class BaseSoC(SoCCore): 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("--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") + 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("--with-pcie", action="store_true", help="Enable PCIe support") + parser.add_argument("--driver", action="store_true", help="Generate PCIe driver") builder_args(parser) soc_sdram_args(parser) args = parser.parse_args() soc = BaseSoC( - sys_clk_freq = int(float(args.sys_clk_freq)), - ddram_channel = int(args.ddram_channel, 0), - with_pcie = args.with_pcie, + sys_clk_freq = int(float(args.sys_clk_freq)), + with_pcie = args.with_pcie, **soc_sdram_argdict(args) ) builder = Builder(soc, **builder_argdict(args))