boards: Xilinx ac701 dev board support

This commit is contained in:
Vamsi K Vytla 2019-04-23 09:48:16 +02:00 committed by Florent Kermarrec
parent 88b882c7e0
commit 89a590263f
2 changed files with 423 additions and 0 deletions

View file

@ -0,0 +1,224 @@
from litex.build.generic_platform import *
from litex.build.xilinx import XilinxPlatform, XC3SProg, VivadoProgrammer, iMPACT
from litex.build.xilinx.ise import XilinxISEToolchain
_io = [
("user_led", 0, Pins("M26"), IOStandard("LVCMOS33")),
("user_led", 1, Pins("T24"), IOStandard("LVCMOS33")),
("user_led", 2, Pins("T25"), IOStandard("LVCMOS33")),
("user_led", 3, Pins("R26"), IOStandard("LVCMOS33")),
("cpu_reset", 0, Pins("U4"), IOStandard("SSTL15")),
("clk200", 0,
Subsignal("p", Pins("R3"), IOStandard("DIFF_SSTL15")),
Subsignal("n", Pins("P3"), IOStandard("DIFF_SSTL15"))
),
("clk156", 0,
Subsignal("p", Pins("M21"), IOStandard("LVDS_25")),
Subsignal("n", Pins("M22"), IOStandard("LVDS_25"))
),
("serial", 0,
Subsignal("cts", Pins("V19")),
Subsignal("rts", Pins("W19")),
Subsignal("tx", Pins("U19")),
Subsignal("rx", Pins("T19")),
IOStandard("LVCMOS18")),
("eth_clocks", 0,
Subsignal("tx", Pins("U22")),
Subsignal("rx", Pins("U21")),
IOStandard("LVCMOS18")
),
("eth", 0,
Subsignal("rx_ctl", Pins("U14")),
Subsignal("rx_data", Pins("U17 V17 V16 V14")),
Subsignal("tx_ctl", Pins("T15")),
Subsignal("tx_data", Pins("U16 U15 T18 T17")),
Subsignal("rst_n", Pins("V18")),
Subsignal("mdc", Pins("W18")),
Subsignal("mdio", Pins("T14")),
IOStandard("LVCMOS18"), Misc("SLEW=FAST"), Drive(16)
),
("ddram", 0,
Subsignal("a", Pins(
"M4 J3 J1 L4 K5 M7 K1 M6",
"H1 K3 N7 L5 L7 N6 L3 K2"),
IOStandard("SSTL15")),
Subsignal("ba", Pins("N1 M1 H2"), IOStandard("SSTL15")),
Subsignal("ras_n", Pins("P1"), IOStandard("SSTL15")),
Subsignal("cas_n", Pins("T4"), IOStandard("SSTL15")),
Subsignal("we_n", Pins("R1"), IOStandard("SSTL15")),
Subsignal("cs_n", Pins("T3"), IOStandard("SSTL15")),
Subsignal("dm", Pins("AC6 AC4 AA3 U7 G1 F3 G5 H9"),
IOStandard("SSTL15")),
Subsignal("dq", Pins(
"AB6 AA8 Y8 AB5 AA5 Y5 Y6 Y7",
"AF4 AF5 AF3 AE3 AD3 AC3 AB4 AA4",
"AC2 AB2 AF2 AE2 Y1 Y2 AC1 AB1",
"Y3 W3 W6 V6 W4 W5 W1 V1",
"G2 D1 E1 E2 F2 A2 A3 C2",
"C3 D3 A4 B4 C4 D4 D5 E5",
"F4 G4 K6 K7 K8 L8 J5 J6",
"G6 H6 F7 F8 G8 H8 D6 E6"),
IOStandard("SSTL15")),
Subsignal("dqs_p", Pins("V8 AD5 AD1 V3 C1 B5 J4 H7"),
IOStandard("DIFF_SSTL15")),
Subsignal("dqs_n", Pins("W8 AE5 AE1 V2 B1 A5 H4 G7"),
IOStandard("DIFF_SSTL15")),
Subsignal("clk_p", Pins("M2"), IOStandard("DIFF_SSTL15")),
Subsignal("clk_n", Pins("L2"), IOStandard("DIFF_SSTL15")),
Subsignal("cke", Pins("P4"), IOStandard("SSTL15")),
Subsignal("odt", Pins("R2"), IOStandard("SSTL15")),
Subsignal("reset_n", Pins("N8"), IOStandard("LVCMOS15"))
),
("vadj_on_b", 0, Pins("R16"), IOStandard("LVCMOS25")),
("gtp_refclk", 0,
Subsignal("p", Pins("AA13")),
Subsignal("n", Pins("AB13"))
),
("sfp", 0,
Subsignal("txp", Pins("AC10")),
Subsignal("txn", Pins("AD10")),
Subsignal("rxp", Pins("AC12")),
Subsignal("rxn", Pins("AD12")),
),
("sfp_mgt_clk_sel0", 0, Pins("B26"), IOStandard("LVCMOS25")),
("sfp_mgt_clk_sel1", 0, Pins("C24"), IOStandard("LVCMOS25")),
("sfp_tx_disable_n", 0, Pins("R18"), IOStandard("LVCMOS33")),
("sfp_rx_los", 0, Pins("R23"), IOStandard("LVCMOS33")),
("XADC", 0,
Subsignal("GPIO0", Pins("H17")),
Subsignal("GPIO1", Pins("E22")),
Subsignal("GPIO2", Pins("K18")),
Subsignal("GPIO3", Pins("L19")),
Subsignal("VAUX0_N", Pins("J16")),
Subsignal("VAUX0_P", Pins("K15")),
Subsignal("VAUX8_N", Pins("J15")),
Subsignal("VAUX8_P", Pins("J14")),
IOStandard("LVCMOS25")),
]
_connectors = [
('HPC',
{'CLK0_M2C_N': 'C19',
'CLK0_M2C_P': 'D19',
'CLK1_M2C_N': 'H22',
'CLK1_M2C_P': 'H21',
'LA00_CC_N': 'C18',
'LA00_CC_P': 'D18',
'LA01_CC_N': 'E18',
'LA01_CC_P': 'E17',
'LA02_N': 'H15',
'LA02_P': 'H14',
'LA03_N': 'F17',
'LA03_P': 'G17',
'LA04_N': 'F19',
'LA04_P': 'F18',
'LA05_N': 'F15',
'LA05_P': 'G15',
'LA06_N': 'F20',
'LA06_P': 'G19',
'LA07_N': 'G16',
'LA07_P': 'H16',
'LA08_N': 'B17',
'LA08_P': 'C17',
'LA09_N': 'D16',
'LA09_P': 'E16',
'LA10_N': 'A18',
'LA10_P': 'A17',
'LA11_N': 'A19',
'LA11_P': 'B19',
'LA12_N': 'D20',
'LA12_P': 'E20',
'LA13_N': 'A20',
'LA13_P': 'B20',
'LA14_N': 'B21',
'LA14_P': 'C21',
'LA15_N': 'A22',
'LA15_P': 'B22',
'LA16_N': 'D21',
'LA16_P': 'E21',
'LA17_CC_N': 'J21',
'LA17_CC_P': 'K21',
'LA18_CC_N': 'G21',
'LA18_CC_P': 'G20',
'LA19_N': 'L14',
'LA19_P': 'M14',
'LA20_N': 'M17',
'LA20_P': 'M16',
'LA21_N': 'H19',
'LA21_P': 'J19',
'LA22_N': 'L18',
'LA22_P': 'L17',
'LA23_N': 'J20',
'LA23_P': 'K20',
'LA24_N': 'H18',
'LA24_P': 'J18',
'LA25_N': 'F22',
'LA25_P': 'G22',
'LA26_N': 'H24',
'LA26_P': 'J24',
'LA27_N': 'E23',
'LA27_P': 'F23',
'LA28_N': 'K23',
'LA28_P': 'K22',
'LA29_N': 'F24',
'LA29_P': 'G24',
'LA30_N': 'D25',
'LA30_P': 'E25',
'LA31_N': 'D26',
'LA31_P': 'E26',
'LA32_N': 'G26',
'LA32_P': 'H26',
'LA33_N': 'F25',
'LA33_P': 'G25',
'PRSNT_M2C_L': 'N16',
'PWR_GOOD_FLASH_RST_B': 'P15'})
]
class Platform(XilinxPlatform):
default_clk_name = "clk156"
default_clk_period = 6.4
def __init__(self, toolchain="vivado", programmer="vivado"):
XilinxPlatform.__init__(self, "xc7a200t-fbg676-2", _io, _connectors,
toolchain=toolchain)
self.toolchain.bitstream_commands = ["set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]"]
self.toolchain.additional_commands = ["write_cfgmem -force -format bin -interface spix4 -size 16 -loadbit \"up 0x0 {build_name}.bit\" -file {build_name}.bin"]
self.programmer = programmer
def create_programmer(self):
if self.programmer == "xc3sprog":
return XC3SProg("jtaghs1_fast")
elif self.programmer == "vivado":
return VivadoProgrammer()
elif self.programmer == "impact":
return iMPACT()
else:
raise ValueError("{} programmer is not supported".format(programmer))
def do_finalize(self, fragment):
XilinxPlatform.do_finalize(self, fragment)
try:
self.add_period_constraint(self.lookup_request("clk200").p, 5.0)
except ConstraintError:
pass
try:
self.add_period_constraint(self.lookup_request("eth_clocks").rx, 8.0)
except ConstraintError:
pass
try:
self.add_period_constraint(self.lookup_request("eth_clocks").tx, 8.0)
except ConstraintError:
pass

199
litex/boards/targets/ac701.py Executable file
View file

@ -0,0 +1,199 @@
#!/usr/bin/env python3
import argparse
from migen import ClockDomain, Signal, Instance, Module
from litex.boards.platforms import ac701
from litex.soc.cores.clock import S7MMCM, S7IDELAYCTRL
from litex.soc.integration.soc_sdram import (SoCSDRAM, soc_sdram_args,
soc_sdram_argdict)
from litex.soc.integration.builder import (builder_args, Builder,
builder_argdict)
# from litex.soc.integration.soc_core import mem_decoder
from litedram.modules import MT8JTF12864
from litedram.phy import s7ddrphy
from liteeth.phy.a7_gtp import QPLLSettings, QPLL
from liteeth.phy.a7_1000basex import A7_1000BASEX
from liteeth.phy.s7rgmii import LiteEthPHYRGMII
from liteeth.core import LiteEthUDPIPCore
from liteeth.frontend.etherbone import LiteEthEtherbone
from litex.soc.interconnect.csr import AutoCSR, CSRStatus
class _CRG(Module):
def __init__(self, platform, sys_clk_freq):
self.clock_domains.cd_sys = ClockDomain()
self.clock_domains.cd_sys4x = ClockDomain(reset_less=True)
self.clock_domains.cd_sys4x_dqs = ClockDomain(reset_less=True)
self.clock_domains.cd_clk200 = ClockDomain()
self.clock_domains.cd_clk1x = ClockDomain()
self.clock_domains.cd_clk2x = ClockDomain()
self.clk125 = Signal()
clk125_ds = platform.request("gtp_refclk")
self.specials += Instance("IBUFDS_GTE2",
i_CEB=0,
i_I=clk125_ds.p, i_IB=clk125_ds.n,
o_O=self.clk125)
self.submodules.pll = pll = S7MMCM(speedgrade=-2)
self.comb += platform.request("sfp_mgt_clk_sel0", 0).eq(0)
self.comb += platform.request("sfp_mgt_clk_sel1", 0).eq(0)
self.comb += platform.request("sfp_tx_disable_n", 0).eq(0)
self.comb += pll.reset.eq(platform.request("cpu_reset"))
pll.register_clkin(self.clk125, 125e6)
pll.create_clkout(self.cd_sys, sys_clk_freq)
pll.create_clkout(self.cd_sys4x, 4*sys_clk_freq)
pll.create_clkout(self.cd_sys4x_dqs, 4*sys_clk_freq, phase=90.0)
pll.create_clkout(self.cd_clk200, 200e6)
pll.create_clkout(self.cd_clk1x, 100e6)
self.submodules.idelayctrl = S7IDELAYCTRL(self.cd_clk200)
class BaseSoC(SoCSDRAM):
csr_map = {
"ddrphy": 16,
}
csr_map.update(SoCSDRAM.csr_map)
def __init__(self, clk_freq=125e6, **kwargs):
platform = ac701.Platform(programmer='xc3sprog')
sys_clk_freq = int(clk_freq)
SoCSDRAM.__init__(self, platform, clk_freq=sys_clk_freq,
integrated_rom_size=0x8000,
integrated_sram_size=0x8000,
**kwargs)
self.submodules.crg = _CRG(platform, sys_clk_freq)
# sdram
self.submodules.ddrphy = s7ddrphy.A7DDRPHY(platform.request("ddram"),
sys_clk_freq=sys_clk_freq)
sdram_module = MT8JTF12864(sys_clk_freq, "1:4")
self.register_sdram(self.ddrphy,
sdram_module.geom_settings,
sdram_module.timing_settings)
class Debug(Module, AutoCSR):
def __init__(self, lock, tx_init_done, test):
self.foo_counter = CSRStatus(26)
self.lock = CSRStatus(1)
self.tx_init_done = CSRStatus(1)
self.test = CSRStatus(1)
counter = Signal(26)
self.sync.eth_tx += [counter.eq(counter + 1),
self.foo_counter.status.eq(counter)]
self.comb += [
self.tx_init_done.status.eq(tx_init_done),
self.lock.status.eq(lock),
self.test.status.eq(test)
]
class EthernetSoC(BaseSoC):
csr_map = {
"ethphy": 18,
"xadc": 19,
"Debug": 20,
# "ethmac": 21
}
csr_map.update(BaseSoC.csr_map)
interrupt_map = {
# "ethmac": 3,
}
interrupt_map.update(BaseSoC.interrupt_map)
mem_map = {
# "xadc": 0x30000000,
# "ethmac": 0x30000000, # (shadow @0xb0000000)
}
mem_map.update(BaseSoC.mem_map)
def setup_sfp_phy(self):
self.create_qpll()
self.submodules.ethphy = A7_1000BASEX(self.ethphy_qpll_channel,
self.platform.request("sfp", 0),
self.clk_freq)
self.platform.add_period_constraint(self.crg.cd_sys.clk, 8.0)
self.platform.add_period_constraint(self.ethphy.txoutclk, 16.)
self.platform.add_period_constraint(self.ethphy.rxoutclk, 16.)
self.platform.add_false_path_constraints(
self.crg.cd_sys.clk,
self.ethphy.txoutclk, self.ethphy.rxoutclk)
def setup_rgmii_phy(self):
self.submodules.ethphy = LiteEthPHYRGMII(self.platform.request("eth_clocks"),
self.platform.request("eth"))
# self.add_wb_slave(mem_decoder(self.mem_map["ethmac"]), self.ethmac.bus)
# self.add_memory_region("ethmac", self.mem_map["ethmac"] | self.shadow_base, 0x2000)
self.crg.cd_sys.clk.attr.add("keep")
self.ethphy.crg.cd_eth_rx.clk.attr.add("keep")
self.ethphy.crg.cd_eth_tx.clk.attr.add("keep")
self.platform.add_period_constraint(self.crg.cd_sys.clk, 8.0)
self.platform.add_period_constraint(self.ethphy.crg.cd_eth_rx.clk, 8.0)
self.platform.add_period_constraint(self.ethphy.crg.cd_eth_tx.clk, 8.0)
self.platform.add_false_path_constraints(
self.crg.cd_sys.clk,
self.ethphy.crg.cd_eth_rx.clk,
self.ethphy.crg.cd_eth_tx.clk)
def __init__(self, use_sfp=True, **kwargs):
BaseSoC.__init__(self, **kwargs)
if use_sfp:
self.setup_sfp_phy()
else:
self.setup_rgmii_phy()
self.crg.cd_sys.clk.attr.add("keep")
mac_address = 0x10e2d5000000
ip_address = 0xc0a80132
self.submodules.core = LiteEthUDPIPCore(self.ethphy, mac_address,
ip_address, self.clk_freq)
# self.submodules.Debug = Debug(self.ethphy_qpll_channel.lock,
# self.ethphy.tx_init.done,
# self.ethphy.tx_init.tx_reset)
def create_qpll(self):
qpll_settings = QPLLSettings(
refclksel=0b001,
fbdiv=4,
fbdiv_45=5,
refclk_div=1)
qpll = QPLL(self.crg.clk125, qpll_settings)
self.submodules += qpll
self.ethphy_qpll_channel = qpll.channels[0]
class EtherboneSoC(EthernetSoC):
def __init__(self, **kwargs):
EthernetSoC.__init__(self, **kwargs)
self.submodules.etherbone = LiteEthEtherbone(self.core.udp, 1234,
mode="master")
self.add_wb_master(self.etherbone.wishbone.bus)
# Build --------------------------------------------------------------------------------------------
def main():
parser = argparse.ArgumentParser(description="LiteX SoC on AC701")
builder_args(parser)
soc_sdram_args(parser)
parser.add_argument("--with-ethernet", action="store_true",
help="enable Ethernet support")
args = parser.parse_args()
cls = EtherboneSoC if args.with_ethernet else BaseSoC
soc = cls(**soc_sdram_argdict(args))
builder = Builder(soc, **builder_argdict(args))
builder.build()
if __name__ == "__main__":
main()