mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
sdram/phy/s6ddrphy: rename S6DDRPHY to S6HalfRateDDRPHY and use ORed wrdata_en/rddata_en (the controller already manages that)
This commit is contained in:
parent
b8f3fd53f1
commit
158fbe49ac
3 changed files with 27 additions and 19 deletions
|
@ -23,10 +23,10 @@ from misoclib.mem.sdram.phy.dfi import *
|
||||||
from misoclib.mem import sdram
|
from misoclib.mem import sdram
|
||||||
|
|
||||||
|
|
||||||
class S6DDRPHY(Module):
|
class S6HalfRateDDRPHY(Module):
|
||||||
def __init__(self, pads, module, rd_bitslip, wr_bitslip, dqs_ddr_alignment):
|
def __init__(self, pads, module, rd_bitslip, wr_bitslip, dqs_ddr_alignment):
|
||||||
if module.memtype not in ["DDR", "LPDDR", "DDR2", "DDR3"]:
|
if module.memtype not in ["DDR", "LPDDR", "DDR2", "DDR3"]:
|
||||||
raise NotImplementedError("S6DDRPHY only supports DDR, LPDDR, DDR2 and DDR3")
|
raise NotImplementedError("S6HalfRateDDRPHY only supports DDR, LPDDR, DDR2 and DDR3")
|
||||||
addressbits = flen(pads.a)
|
addressbits = flen(pads.a)
|
||||||
bankbits = flen(pads.ba)
|
bankbits = flen(pads.ba)
|
||||||
databits = flen(pads.dq)
|
databits = flen(pads.dq)
|
||||||
|
@ -358,27 +358,35 @@ class S6DDRPHY(Module):
|
||||||
#
|
#
|
||||||
# DQ/DQS/DM control
|
# DQ/DQS/DM control
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# write
|
||||||
|
wrdata_en = Signal()
|
||||||
|
self.comb += wrdata_en.eq(optree("|", [d_dfi[p].wrdata_en for p in range(nphases)]))
|
||||||
|
|
||||||
if module.memtype == "DDR3":
|
if module.memtype == "DDR3":
|
||||||
r_drive_dq = Signal(self.settings.cwl-1)
|
r_drive_dq = Signal(self.settings.cwl-1)
|
||||||
sd_sdram_half += r_drive_dq.eq(Cat(d_dfi[self.settings.wrphase].wrdata_en, r_drive_dq))
|
sd_sdram_half += r_drive_dq.eq(Cat(wrdata_en, r_drive_dq))
|
||||||
self.comb += drive_dq.eq(r_drive_dq[self.settings.cwl-2])
|
self.comb += drive_dq.eq(r_drive_dq[self.settings.cwl-2])
|
||||||
else:
|
else:
|
||||||
self.comb += drive_dq.eq(d_dfi[self.settings.wrphase].wrdata_en)
|
self.comb += drive_dq.eq(wrdata_en)
|
||||||
|
|
||||||
d_dfi_wrdata_en = Signal()
|
wrdata_en_d = Signal()
|
||||||
sd_sys += d_dfi_wrdata_en.eq(d_dfi[self.settings.wrphase].wrdata_en)
|
sd_sys += wrdata_en_d.eq(wrdata_en)
|
||||||
|
|
||||||
r_dfi_wrdata_en = Signal(max(self.settings.cwl, self.settings.cl))
|
r_dfi_wrdata_en = Signal(max(self.settings.cwl, self.settings.cl))
|
||||||
sd_sdram_half += r_dfi_wrdata_en.eq(Cat(d_dfi_wrdata_en, r_dfi_wrdata_en))
|
sd_sdram_half += r_dfi_wrdata_en.eq(Cat(wrdata_en_d, r_dfi_wrdata_en))
|
||||||
|
|
||||||
if module.memtype == "DDR3":
|
if module.memtype == "DDR3":
|
||||||
self.comb += drive_dqs.eq(r_dfi_wrdata_en[self.settings.cwl-1])
|
self.comb += drive_dqs.eq(r_dfi_wrdata_en[self.settings.cwl-1])
|
||||||
else:
|
else:
|
||||||
self.comb += drive_dqs.eq(r_dfi_wrdata_en[1])
|
self.comb += drive_dqs.eq(r_dfi_wrdata_en[1])
|
||||||
|
|
||||||
|
# read
|
||||||
|
rddata_en = Signal()
|
||||||
|
self.comb += rddata_en.eq(optree("|", [d_dfi[p].rddata_en for p in range(nphases)]))
|
||||||
|
|
||||||
rddata_sr = Signal(self.settings.read_latency)
|
rddata_sr = Signal(self.settings.read_latency)
|
||||||
sd_sys += rddata_sr.eq(Cat(rddata_sr[1:self.settings.read_latency],
|
sd_sys += rddata_sr.eq(Cat(rddata_sr[1:self.settings.read_latency], rddata_en))
|
||||||
d_dfi[self.settings.rdphase].rddata_en))
|
|
||||||
|
|
||||||
for n, phase in enumerate(self.dfi.phases):
|
for n, phase in enumerate(self.dfi.phases):
|
||||||
self.comb += [
|
self.comb += [
|
||||||
|
|
|
@ -82,11 +82,11 @@ class BaseSoC(SDRAMSoC):
|
||||||
self.submodules.crg = _MXCRG(_MXClockPads(platform), self.clk_freq)
|
self.submodules.crg = _MXCRG(_MXClockPads(platform), self.clk_freq)
|
||||||
|
|
||||||
if not self.integrated_main_ram_size:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"),
|
self.submodules.ddrphy = s6ddrphy.S6HalfRateDDRPHY(platform.request("ddram"),
|
||||||
MT46V32M16(self.clk_freq),
|
MT46V32M16(self.clk_freq),
|
||||||
rd_bitslip=0,
|
rd_bitslip=0,
|
||||||
wr_bitslip=3,
|
wr_bitslip=3,
|
||||||
dqs_ddr_alignment="C1")
|
dqs_ddr_alignment="C1")
|
||||||
self.register_sdram_phy(self.ddrphy)
|
self.register_sdram_phy(self.ddrphy)
|
||||||
self.comb += [
|
self.comb += [
|
||||||
self.ddrphy.clk4x_wr_strb.eq(self.crg.clk4x_wr_strb),
|
self.ddrphy.clk4x_wr_strb.eq(self.crg.clk4x_wr_strb),
|
||||||
|
|
|
@ -108,11 +108,11 @@ class BaseSoC(SDRAMSoC):
|
||||||
self.submodules.crg = _CRG(platform, clk_freq)
|
self.submodules.crg = _CRG(platform, clk_freq)
|
||||||
|
|
||||||
if not self.integrated_main_ram_size:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"),
|
self.submodules.ddrphy = s6ddrphy.S6HalfRateDDRPHY(platform.request("ddram"),
|
||||||
MT46H32M16(self.clk_freq),
|
MT46H32M16(self.clk_freq),
|
||||||
rd_bitslip=1,
|
rd_bitslip=1,
|
||||||
wr_bitslip=3,
|
wr_bitslip=3,
|
||||||
dqs_ddr_alignment="C1")
|
dqs_ddr_alignment="C1")
|
||||||
self.comb += [
|
self.comb += [
|
||||||
self.ddrphy.clk4x_wr_strb.eq(self.crg.clk4x_wr_strb),
|
self.ddrphy.clk4x_wr_strb.eq(self.crg.clk4x_wr_strb),
|
||||||
self.ddrphy.clk4x_rd_strb.eq(self.crg.clk4x_rd_strb),
|
self.ddrphy.clk4x_rd_strb.eq(self.crg.clk4x_rd_strb),
|
||||||
|
|
Loading…
Reference in a new issue