sdram/module: add description and TODO list

This commit is contained in:
Florent Kermarrec 2015-03-21 17:44:04 +01:00
parent 52924ee1f2
commit 854058a8db

View file

@ -1,3 +1,19 @@
# SDRAM memory modules library
#
# This library avoid duplications of memory modules definitions in targets and
# ease SDRAM usage. (User can only select an already existing module or create
# one for its board and contribute to this library)
#
# TODO:
# Try to share the maximum information we can between modules:
# - ex: MT46V32M16 and MT46H32M16 are almost identical (V=DDR, H=LPDDR)
# - Modules can have different configuration:
# MT8JTF12864 (1GB), MT8JTF25664 (2GB)
# but share all others informations, try to create an unique module for all
# configurations.
# - Modules can have different speedgrades, add support for it (and also add
# a check to verify clk_freq is in the supported range)
from math import ceil from math import ceil
from migen.fhdl.std import * from migen.fhdl.std import *
@ -42,7 +58,8 @@ class IS42S16160(SDRAMModule):
"tRFC": 70 "tRFC": 70
} }
def __init__(self, clk_freq): def __init__(self, clk_freq):
SDRAMModule.__init__(self, clk_freq, self.geom_settings, self.timing_settings) SDRAMModule.__init__(self, clk_freq, self.geom_settings,
self.timing_settings)
class MT48LC4M16(SDRAMModule): class MT48LC4M16(SDRAMModule):
geom_settings = { geom_settings = {
@ -59,7 +76,8 @@ class MT48LC4M16(SDRAMModule):
"tRFC": 66 "tRFC": 66
} }
def __init__(self, clk_freq): def __init__(self, clk_freq):
SDRAMModule.__init__(self, clk_freq, self.geom_settings, self.timing_settings) SDRAMModule.__init__(self, clk_freq, self.geom_settings,
self.timing_settings)
# DDR # DDR
class MT46V32M16(SDRAMModule): class MT46V32M16(SDRAMModule):
@ -77,7 +95,8 @@ class MT46V32M16(SDRAMModule):
"tRFC": 70 "tRFC": 70
} }
def __init__(self, clk_freq): def __init__(self, clk_freq):
SDRAMModule.__init__(self, clk_freq, self.geom_settings, self.timing_settings) SDRAMModule.__init__(self, clk_freq, self.geom_settings,
self.timing_settings)
# LPDDR # LPDDR
class MT46H32M16(SDRAMModule): class MT46H32M16(SDRAMModule):
@ -95,7 +114,8 @@ class MT46H32M16(SDRAMModule):
"tRFC": 72 "tRFC": 72
} }
def __init__(self, clk_freq): def __init__(self, clk_freq):
SDRAMModule.__init__(self, clk_freq, self.geom_settings, self.timing_settings) SDRAMModule.__init__(self, clk_freq, self.geom_settings,
self.timing_settings)
# DDR2 # DDR2
@ -115,4 +135,5 @@ class MT8JTF12864(SDRAMModule):
"tRFC": 70 "tRFC": 70
} }
def __init__(self, clk_freq): def __init__(self, clk_freq):
SDRAMModule.__init__(self, clk_freq, self.geom_settings, self.timing_settings) SDRAMModule.__init__(self, clk_freq, self.geom_settings,
self.timing_settings)