mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
targets/ac701: cleanup and make it similar to others targets.
Still supports EthernetSoC with RGMII and 1000BaseX.
This commit is contained in:
parent
a24bf72fc7
commit
d2ad14417a
1 changed files with 77 additions and 118 deletions
|
@ -2,16 +2,14 @@
|
|||
|
||||
import argparse
|
||||
|
||||
from migen import ClockDomain, Signal, Instance, Module
|
||||
from migen import *
|
||||
|
||||
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 litex.soc.cores.clock import *
|
||||
from litex.soc.integration.soc_core import mem_decoder
|
||||
from litex.soc.integration.soc_sdram import *
|
||||
from litex.soc.integration.builder import *
|
||||
|
||||
from litedram.modules import MT8JTF12864
|
||||
from litedram.phy import s7ddrphy
|
||||
|
@ -19,11 +17,9 @@ 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
|
||||
from liteeth.core.mac import LiteEthMAC
|
||||
|
||||
# CRG ----------------------------------------------------------------------------------------------
|
||||
|
||||
class _CRG(Module):
|
||||
def __init__(self, platform, sys_clk_freq):
|
||||
|
@ -31,155 +27,113 @@ class _CRG(Module):
|
|||
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)
|
||||
self.cd_sys.clk.attr.add("keep")
|
||||
self.cd_sys4x.clk.attr.add("keep")
|
||||
self.cd_sys4x_dqs.clk.attr.add("keep")
|
||||
|
||||
self.submodules.pll = pll = S7PLL(speedgrade=-1)
|
||||
self.comb += pll.reset.eq(~platform.request("cpu_reset"))
|
||||
pll.register_clkin(platform.request("clk200"), 200e6)
|
||||
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_sys4x_dqs, 4*sys_clk_freq, phase=90)
|
||||
pll.create_clkout(self.cd_clk200, 200e6)
|
||||
pll.create_clkout(self.cd_clk1x, 100e6)
|
||||
|
||||
self.submodules.idelayctrl = S7IDELAYCTRL(self.cd_clk200)
|
||||
|
||||
# BaseSoC ------------------------------------------------------------------------------------------
|
||||
|
||||
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)
|
||||
def __init__(self, **kwargs):
|
||||
platform = ac701.Platform()
|
||||
sys_clk_freq = int(100e6)
|
||||
SoCSDRAM.__init__(self, platform, clk_freq=sys_clk_freq,
|
||||
integrated_rom_size=0x8000,
|
||||
integrated_sram_size=0x8000,
|
||||
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)
|
||||
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)
|
||||
]
|
||||
|
||||
# EthernetSoC --------------------------------------------------------------------------------------
|
||||
|
||||
class EthernetSoC(BaseSoC):
|
||||
csr_map = {
|
||||
"ethphy": 18,
|
||||
"xadc": 19,
|
||||
"Debug": 20,
|
||||
# "ethmac": 21
|
||||
"ethmac": 19
|
||||
}
|
||||
csr_map.update(BaseSoC.csr_map)
|
||||
|
||||
interrupt_map = {
|
||||
# "ethmac": 3,
|
||||
"ethmac": 3,
|
||||
}
|
||||
interrupt_map.update(BaseSoC.interrupt_map)
|
||||
|
||||
mem_map = {
|
||||
# "xadc": 0x30000000,
|
||||
# "ethmac": 0x30000000, # (shadow @0xb0000000)
|
||||
"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):
|
||||
def __init__(self, phy="rgmii", **kwargs):
|
||||
assert phy in ["rgmii", "1000basex"]
|
||||
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)
|
||||
if phy == "rgmii":
|
||||
self.submodules.ethphy = LiteEthPHYRGMII(self.platform.request("eth_clocks"),
|
||||
self.platform.request("eth"))
|
||||
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.ethphy.crg.cd_eth_rx.clk, 1e9/125e6)
|
||||
self.platform.add_period_constraint(self.ethphy.crg.cd_eth_tx.clk, 1e9/125e6)
|
||||
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)
|
||||
|
||||
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)
|
||||
if phy == "1000basex":
|
||||
self.comb += self.platform.request("sfp_mgt_clk_sel0", 0).eq(0)
|
||||
self.comb += self.platform.request("sfp_mgt_clk_sel1", 0).eq(0)
|
||||
self.comb += self.platform.request("sfp_tx_disable_n", 0).eq(0)
|
||||
qpll_settings = QPLLSettings(
|
||||
refclksel=0b001,
|
||||
fbdiv=4,
|
||||
fbdiv_45=5,
|
||||
refclk_div=1)
|
||||
refclk125 = self.platform.request("gtp_refclk")
|
||||
refclk125_se = Signal()
|
||||
self.specials += \
|
||||
Instance("IBUFDS_GTE2",
|
||||
i_CEB=0,
|
||||
i_I=refclk125.p,
|
||||
i_IB=refclk125.n,
|
||||
o_O=refclk125_se)
|
||||
qpll = QPLL(refclk125_se, qpll_settings)
|
||||
self.submodules += qpll
|
||||
self.submodules.ethphy = A7_1000BASEX(qpll.channels[0], self.platform.request("sfp", 0), self.clk_freq)
|
||||
self.platform.add_period_constraint(self.ethphy.txoutclk, 1e9/62.5e6)
|
||||
self.platform.add_period_constraint(self.ethphy.rxoutclk, 1e9/62.5e6)
|
||||
self.platform.add_false_path_constraints(
|
||||
self.crg.cd_sys.clk,
|
||||
self.ethphy.txoutclk,
|
||||
self.ethphy.rxoutclk)
|
||||
|
||||
self.submodules.ethmac = LiteEthMAC(phy=self.ethphy, dw=32,
|
||||
interface="wishbone", endianness=self.cpu.endianness)
|
||||
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)
|
||||
|
||||
# Build --------------------------------------------------------------------------------------------
|
||||
def main():
|
||||
|
@ -188,9 +142,14 @@ def main():
|
|||
soc_sdram_args(parser)
|
||||
parser.add_argument("--with-ethernet", action="store_true",
|
||||
help="enable Ethernet support")
|
||||
parser.add_argument("--ethernet-phy", default="rgmii",
|
||||
help="select Ethernet PHY (rgmii or 1000basex)")
|
||||
args = parser.parse_args()
|
||||
cls = EtherboneSoC if args.with_ethernet else BaseSoC
|
||||
soc = cls(**soc_sdram_argdict(args))
|
||||
|
||||
if args.with_ethernet:
|
||||
soc = EthernetSoC(args.ethernet_phy, **soc_sdram_argdict(args))
|
||||
else:
|
||||
soc = BaseSoC(**soc_sdram_argdict(args))
|
||||
builder = Builder(soc, **builder_argdict(args))
|
||||
builder.build()
|
||||
|
||||
|
|
Loading…
Reference in a new issue