mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Refactor directory hierarchy of sdram phys and controllers
This commit is contained in:
parent
f33b285af1
commit
cf92821fcf
24 changed files with 55 additions and 54 deletions
2
make.py
2
make.py
|
@ -7,7 +7,7 @@ from migen.util.misc import autotype
|
|||
from migen.fhdl import simplify
|
||||
|
||||
from misoclib.gensoc import cpuif
|
||||
from misoclib.sdramphy import initsequence
|
||||
from misoclib.sdram.phy import initsequence
|
||||
|
||||
from misoc_import import misoc_import
|
||||
|
||||
|
|
|
@ -8,8 +8,10 @@ from migen.bank import csrgen
|
|||
from migen.bus import wishbone, csr, lasmibus, dfi
|
||||
from migen.bus import wishbone2lasmi, wishbone2csr
|
||||
|
||||
from misoclib import lm32, mor1kx, uart, dfii, lasmicon, identifier, timer, memtest
|
||||
from misoclib.lasmicon.minicon import Minicon
|
||||
from misoclib import lm32, mor1kx, uart, identifier, timer, memtest
|
||||
from misoclib.sdram import lasmicon
|
||||
from misoclib.sdram import dfii
|
||||
from misoclib.sdram.minicon import Minicon
|
||||
|
||||
class GenSoC(Module):
|
||||
csr_base = 0xe0000000
|
||||
|
|
12
misoclib/sdram/__init__.py
Normal file
12
misoclib/sdram/__init__.py
Normal file
|
@ -0,0 +1,12 @@
|
|||
from collections import namedtuple
|
||||
|
||||
PhySettingsT = namedtuple("PhySettings", "memtype dfi_d nphases rdphase wrphase rdcmdphase wrcmdphase cl cwl read_latency write_latency")
|
||||
def PhySettings(memtype, dfi_d, nphases, rdphase, wrphase, rdcmdphase, wrcmdphase, cl, read_latency, write_latency, cwl=0):
|
||||
return PhySettingsT(memtype, dfi_d, nphases, rdphase, wrphase, rdcmdphase, wrcmdphase, cl, cwl, read_latency, write_latency)
|
||||
|
||||
GeomSettingsT = namedtuple("_GeomSettings", "bank_a row_a col_a mux_a")
|
||||
def GeomSettings(bank_a, row_a, col_a):
|
||||
return GeomSettingsT(bank_a, row_a, col_a, max(row_a, col_a))
|
||||
|
||||
TimingSettings = namedtuple("TimingSettings", "tRP tRCD tWR tWTR tREFI tRFC" \
|
||||
" req_queue_size read_time write_time")
|
|
@ -1,22 +1,9 @@
|
|||
from collections import namedtuple
|
||||
|
||||
from migen.fhdl.std import *
|
||||
from migen.bus import dfi, lasmibus
|
||||
|
||||
from misoclib.lasmicon.refresher import *
|
||||
from misoclib.lasmicon.bankmachine import *
|
||||
from misoclib.lasmicon.multiplexer import *
|
||||
|
||||
PhySettingsT = namedtuple("PhySettings", "memtype dfi_d nphases rdphase wrphase rdcmdphase wrcmdphase cl cwl read_latency write_latency")
|
||||
def PhySettings(memtype, dfi_d, nphases, rdphase, wrphase, rdcmdphase, wrcmdphase, cl, read_latency, write_latency, cwl=0):
|
||||
return PhySettingsT(memtype, dfi_d, nphases, rdphase, wrphase, rdcmdphase, wrcmdphase, cl, cwl, read_latency, write_latency)
|
||||
|
||||
GeomSettingsT = namedtuple("_GeomSettings", "bank_a row_a col_a mux_a")
|
||||
def GeomSettings(bank_a, row_a, col_a):
|
||||
return GeomSettingsT(bank_a, row_a, col_a, max(row_a, col_a))
|
||||
|
||||
TimingSettings = namedtuple("TimingSettings", "tRP tRCD tWR tWTR tREFI tRFC" \
|
||||
" req_queue_size read_time write_time")
|
||||
from misoclib.sdram.lasmicon.refresher import *
|
||||
from misoclib.sdram.lasmicon.bankmachine import *
|
||||
from misoclib.sdram.lasmicon.multiplexer import *
|
||||
|
||||
class LASMIcon(Module):
|
||||
def __init__(self, phy_settings, geom_settings, timing_settings):
|
|
@ -4,7 +4,7 @@ from migen.genlib.fsm import FSM, NextState
|
|||
from migen.genlib.misc import optree
|
||||
from migen.genlib.fifo import SyncFIFO
|
||||
|
||||
from misoclib.lasmicon.multiplexer import *
|
||||
from misoclib.sdram.lasmicon.multiplexer import *
|
||||
|
||||
class _AddressSlicer:
|
||||
def __init__(self, col_a, address_align):
|
|
@ -4,7 +4,7 @@ from migen.genlib.misc import optree
|
|||
from migen.genlib.fsm import FSM, NextState
|
||||
from migen.bank.description import AutoCSR
|
||||
|
||||
from misoclib.lasmicon.perf import Bandwidth
|
||||
from misoclib.sdram.lasmicon.perf import Bandwidth
|
||||
|
||||
class CommandRequest:
|
||||
def __init__(self, a, ba):
|
|
@ -2,7 +2,7 @@ from migen.fhdl.std import *
|
|||
from migen.genlib.misc import timeline
|
||||
from migen.genlib.fsm import FSM
|
||||
|
||||
from misoclib.lasmicon.multiplexer import *
|
||||
from misoclib.sdram.lasmicon.multiplexer import *
|
||||
|
||||
class Refresher(Module):
|
||||
def __init__(self, a, ba, tRP, tREFI, tRFC):
|
|
@ -2,7 +2,7 @@ from migen.fhdl.std import *
|
|||
from migen.bus.lasmibus import *
|
||||
from migen.sim.generic import run_simulation
|
||||
|
||||
from misoclib.lasmicon.bankmachine import *
|
||||
from misoclib.sdram.lasmicon.bankmachine import *
|
||||
|
||||
from common import sdram_phy, sdram_geom, sdram_timing, CommandLogger
|
||||
|
|
@ -3,7 +3,7 @@ from math import ceil
|
|||
|
||||
from migen.fhdl.std import *
|
||||
|
||||
from misoclib import lasmicon
|
||||
from misoclib import sdram
|
||||
|
||||
MHz = 1000000
|
||||
clk_freq = (83 + Fraction(1, 3))*MHz
|
||||
|
@ -14,7 +14,7 @@ def ns(t, margin=True):
|
|||
t += clk_period_ns/2
|
||||
return ceil(t/clk_period_ns)
|
||||
|
||||
sdram_phy = lasmicon.PhySettings(
|
||||
sdram_phy = sdram.PhySettings(
|
||||
memtype="DDR",
|
||||
dfi_d=64,
|
||||
nphases=2,
|
||||
|
@ -27,12 +27,12 @@ sdram_phy = lasmicon.PhySettings(
|
|||
write_latency=0
|
||||
)
|
||||
|
||||
sdram_geom = lasmicon.GeomSettings(
|
||||
sdram_geom = sdram.GeomSettings(
|
||||
bank_a=2,
|
||||
row_a=13,
|
||||
col_a=10
|
||||
)
|
||||
sdram_timing = lasmicon.TimingSettings(
|
||||
sdram_timing = sdram.TimingSettings(
|
||||
tRP=ns(15),
|
||||
tRCD=ns(15),
|
||||
tWR=ns(15),
|
|
@ -2,7 +2,7 @@ from migen.fhdl.std import *
|
|||
from migen.bus.lasmibus import *
|
||||
from migen.sim.generic import run_simulation
|
||||
|
||||
from misoclib.lasmicon import *
|
||||
from misoclib.sdram.lasmicon import *
|
||||
|
||||
from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
|
||||
|
|
@ -3,7 +3,7 @@ from migen.bus import lasmibus
|
|||
from migen.actorlib import dma_lasmi
|
||||
from migen.sim.generic import run_simulation
|
||||
|
||||
from misoclib.lasmicon import *
|
||||
from misoclib.sdram.lasmicon import *
|
||||
|
||||
from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
|
||||
|
|
@ -3,7 +3,7 @@ from migen.bus import wishbone, wishbone2lasmi, lasmibus
|
|||
from migen.bus.transactions import *
|
||||
from migen.sim.generic import run_simulation
|
||||
|
||||
from misoclib.lasmicon import *
|
||||
from misoclib.sdram.lasmicon import *
|
||||
|
||||
from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
|
||||
|
|
@ -3,7 +3,7 @@ from random import Random
|
|||
from migen.fhdl.std import *
|
||||
from migen.sim.generic import run_simulation
|
||||
|
||||
from misoclib.lasmicon.refresher import *
|
||||
from misoclib.sdram.lasmicon.refresher import *
|
||||
|
||||
from common import CommandLogger
|
||||
|
|
@ -4,9 +4,9 @@ from migen.bus import wishbone
|
|||
from migen.sim.generic import Simulator
|
||||
from migen.sim import icarus
|
||||
from mibuild.platforms import papilio_pro as board
|
||||
from misoclib import lasmicon
|
||||
from misoclib.lasmicon.minicon import Minicon
|
||||
from misoclib.sdramphy import gensdrphy
|
||||
from misoclib import sdram
|
||||
from misoclib.sdram.minicon import Minicon
|
||||
from misoclib.sdram.phy import gensdrphy
|
||||
from itertools import chain
|
||||
from os.path import isfile
|
||||
import sys
|
||||
|
@ -153,13 +153,13 @@ if __name__ == "__main__":
|
|||
|
||||
plat = board.Platform()
|
||||
|
||||
sdram_geom = lasmicon.GeomSettings(
|
||||
sdram_geom = sdram.GeomSettings(
|
||||
bank_a=2,
|
||||
row_a=12,
|
||||
col_a=8
|
||||
)
|
||||
|
||||
sdram_timing = lasmicon.TimingSettings(
|
||||
sdram_timing = sdram.TimingSettings(
|
||||
tRP=ns(15),
|
||||
tRCD=ns(15),
|
||||
tWR=ns(14),
|
|
@ -26,7 +26,7 @@ from migen.bus.dfi import *
|
|||
from migen.genlib.record import *
|
||||
from migen.fhdl.specials import *
|
||||
|
||||
from misoclib import lasmicon
|
||||
from misoclib import sdram
|
||||
|
||||
class GENSDRPHY(Module):
|
||||
def __init__(self, pads):
|
||||
|
@ -34,7 +34,7 @@ class GENSDRPHY(Module):
|
|||
ba = flen(pads.ba)
|
||||
d = flen(pads.dq)
|
||||
|
||||
self.phy_settings = lasmicon.PhySettings(
|
||||
self.phy_settings = sdram.PhySettings(
|
||||
memtype="SDR",
|
||||
dfi_d=d,
|
||||
nphases=1,
|
|
@ -4,7 +4,7 @@ from migen.fhdl.std import *
|
|||
from migen.bus.dfi import *
|
||||
from migen.bank.description import *
|
||||
|
||||
from misoclib import lasmicon
|
||||
from misoclib import sdram
|
||||
|
||||
class K7DDRPHY(Module, AutoCSR):
|
||||
def __init__(self, pads, memtype):
|
||||
|
@ -24,7 +24,7 @@ class K7DDRPHY(Module, AutoCSR):
|
|||
self._r_wdly_dqs_rst = CSR()
|
||||
self._r_wdly_dqs_inc = CSR()
|
||||
|
||||
self.phy_settings = lasmicon.PhySettings(
|
||||
self.phy_settings = sdram.PhySettings(
|
||||
memtype=memtype,
|
||||
dfi_d=2*d,
|
||||
nphases=nphases,
|
|
@ -18,7 +18,7 @@ from migen.fhdl.std import *
|
|||
from migen.bus.dfi import *
|
||||
from migen.genlib.record import *
|
||||
|
||||
from misoclib import lasmicon
|
||||
from misoclib import sdram
|
||||
|
||||
class S6DDRPHY(Module):
|
||||
def __init__(self, pads, memtype, rd_bitslip, wr_bitslip, dqs_ddr_alignment):
|
||||
|
@ -29,7 +29,7 @@ class S6DDRPHY(Module):
|
|||
d = flen(pads.dq)
|
||||
nphases = 2
|
||||
|
||||
self.phy_settings = lasmicon.PhySettings(
|
||||
self.phy_settings = sdram.PhySettings(
|
||||
memtype=memtype,
|
||||
dfi_d=2*d,
|
||||
nphases=nphases,
|
|
@ -1,8 +1,8 @@
|
|||
from migen.fhdl.std import *
|
||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||
|
||||
from misoclib import lasmicon, spiflash, ethmac
|
||||
from misoclib.sdramphy import k7ddrphy
|
||||
from misoclib import sdram, spiflash, ethmac
|
||||
from misoclib.sdram.phy import k7ddrphy
|
||||
from misoclib.gensoc import SDRAMSoC
|
||||
from misoclib.ethmac.phy import gmii
|
||||
|
||||
|
@ -75,12 +75,12 @@ class BaseSoC(SDRAMSoC):
|
|||
|
||||
self.submodules.crg = _CRG(platform)
|
||||
|
||||
sdram_geom = lasmicon.GeomSettings(
|
||||
sdram_geom = sdram.GeomSettings(
|
||||
bank_a=3,
|
||||
row_a=16,
|
||||
col_a=10
|
||||
)
|
||||
sdram_timing = lasmicon.TimingSettings(
|
||||
sdram_timing = sdram.TimingSettings(
|
||||
tRP=self.ns(15),
|
||||
tRCD=self.ns(15),
|
||||
tWR=self.ns(15),
|
||||
|
|
|
@ -4,8 +4,8 @@ from fractions import Fraction
|
|||
from migen.fhdl.std import *
|
||||
from mibuild.generic_platform import ConstraintError
|
||||
|
||||
from misoclib import lasmicon, mxcrg, norflash16, ethmac, framebuffer, gpio
|
||||
from misoclib.sdramphy import s6ddrphy
|
||||
from misoclib import sdram, mxcrg, norflash16, minimac3, framebuffer, gpio
|
||||
from misoclib.sdram.phy import s6ddrphy
|
||||
from misoclib.gensoc import SDRAMSoC
|
||||
from misoclib.ethmac.phy import mii
|
||||
|
||||
|
@ -31,12 +31,12 @@ class BaseSoC(SDRAMSoC):
|
|||
cpu_reset_address=0x00180000,
|
||||
**kwargs)
|
||||
|
||||
sdram_geom = lasmicon.GeomSettings(
|
||||
sdram_geom = sdram.GeomSettings(
|
||||
bank_a=2,
|
||||
row_a=13,
|
||||
col_a=10
|
||||
)
|
||||
sdram_timing = lasmicon.TimingSettings(
|
||||
sdram_timing = sdram.TimingSettings(
|
||||
tRP=self.ns(15),
|
||||
tRCD=self.ns(15),
|
||||
tWR=self.ns(15),
|
||||
|
|
|
@ -3,8 +3,8 @@ from fractions import Fraction
|
|||
from migen.fhdl.std import *
|
||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||
|
||||
from misoclib import lasmicon, spiflash
|
||||
from misoclib.sdramphy import gensdrphy
|
||||
from misoclib import spiflash, sdram
|
||||
from misoclib.sdram.phy import gensdrphy
|
||||
from misoclib.gensoc import SDRAMSoC
|
||||
|
||||
class _CRG(Module):
|
||||
|
@ -67,12 +67,12 @@ class BaseSoC(SDRAMSoC):
|
|||
|
||||
self.submodules.crg = _CRG(platform, clk_freq)
|
||||
|
||||
sdram_geom = lasmicon.GeomSettings(
|
||||
sdram_geom = sdram.GeomSettings(
|
||||
bank_a=2,
|
||||
row_a=12,
|
||||
col_a=8
|
||||
)
|
||||
sdram_timing = lasmicon.TimingSettings(
|
||||
sdram_timing = sdram.TimingSettings(
|
||||
tRP=self.ns(15),
|
||||
tRCD=self.ns(15),
|
||||
tWR=self.ns(14),
|
||||
|
|
Loading…
Reference in a new issue