From 41c8c172b510dc6ead4f6e0c7c3abec228831baa Mon Sep 17 00:00:00 2001 From: Sebastien Bourdeauducq Date: Fri, 8 Aug 2014 21:58:41 +0800 Subject: [PATCH] targets/kc705: integrate DDR3 --- targets/kc705.py | 33 +++++++++++++++++++++++++-------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/targets/kc705.py b/targets/kc705.py index a4ce686b4..964a5b6fc 100644 --- a/targets/kc705.py +++ b/targets/kc705.py @@ -1,8 +1,9 @@ from migen.fhdl.std import * from migen.genlib.resetsync import AsyncResetSynchronizer -from migen.bus import wishbone -from misoclib.gensoc import GenSoC, IntegratedBIOS +from misoclib import lasmicon +from misoclib.sdramphy import k7ddrphy +from misoclib.gensoc import SDRAMSoC, IntegratedBIOS class _CRG(Module): def __init__(self, platform): @@ -58,19 +59,35 @@ class _CRG(Module): ) self.specials += Instance("IDELAYCTRL", i_REFCLK=ClockSignal("clk200"), i_RST=ic_reset) -class BaseSoC(GenSoC, IntegratedBIOS): +class BaseSoC(SDRAMSoC, IntegratedBIOS): default_platform = "kc705" def __init__(self, platform, **kwargs): - GenSoC.__init__(self, platform, + SDRAMSoC.__init__(self, platform, clk_freq=125*1000000, cpu_reset_address=0, **kwargs) IntegratedBIOS.__init__(self) + sdram_geom = lasmicon.GeomSettings( + bank_a=3, + row_a=16, + col_a=10 + ) + sdram_timing = lasmicon.TimingSettings( + tRP=self.ns(15), + tRCD=self.ns(15), + tWR=self.ns(15), + tWTR=2, + tREFI=self.ns(7800, False), + tRFC=self.ns(70), + + req_queue_size=8, + read_time=32, + write_time=16 + ) + self.submodules.ddrphy = k7ddrphy.K7DDRPHY(platform.request("ddram"), memtype="DDR3") + self.register_sdram_phy(self.ddrphy.dfi, self.ddrphy.phy_settings, sdram_geom, sdram_timing) + self.submodules.crg = _CRG(platform) - self.submodules.usermem = wishbone.SRAM(64*1024) - self.add_wb_slave(lambda a: a[27:29] == 2, self.usermem.bus) - self.add_cpu_memory_region("sdram", 0x40000000, 64*1024) - default_subtarget = BaseSoC