mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
minicon: small simplifications
This commit is contained in:
parent
edb1622668
commit
4189440eef
1 changed files with 11 additions and 18 deletions
|
@ -57,7 +57,6 @@ class Minicon(Module):
|
||||||
slicer = _AddressSlicer(geom_settings.col_a, geom_settings.bank_a, geom_settings.row_a, address_align)
|
slicer = _AddressSlicer(geom_settings.col_a, geom_settings.bank_a, geom_settings.row_a, address_align)
|
||||||
refresh_req = Signal()
|
refresh_req = Signal()
|
||||||
refresh_ack = Signal()
|
refresh_ack = Signal()
|
||||||
wb_access = Signal()
|
|
||||||
refresh_counter = Signal(max=timing_settings.tREFI+1)
|
refresh_counter = Signal(max=timing_settings.tREFI+1)
|
||||||
hit = Signal()
|
hit = Signal()
|
||||||
row_open = Signal()
|
row_open = Signal()
|
||||||
|
@ -71,24 +70,18 @@ class Minicon(Module):
|
||||||
self.comb += [
|
self.comb += [
|
||||||
hit.eq(openrow[slicer.bank(bus.adr)] == Cat(slicer.row(bus.adr), 1)),
|
hit.eq(openrow[slicer.bank(bus.adr)] == Cat(slicer.row(bus.adr), 1)),
|
||||||
has_curbank_openrow.eq(openrow[slicer.bank(bus.adr)][-1]),
|
has_curbank_openrow.eq(openrow[slicer.bank(bus.adr)][-1]),
|
||||||
wb_access.eq(bus.stb & bus.cyc),
|
bus.dat_r.eq(Cat(phase.rddata for phase in dfi.phases)),
|
||||||
bus.dat_r.eq(Cat([phase.rddata for phase in dfi.phases])),
|
Cat(phase.wrdata for phase in dfi.phases).eq(bus.dat_w),
|
||||||
Cat([phase.wrdata for phase in dfi.phases]).eq(bus.dat_w),
|
Cat(phase.wrdata_mask for phase in dfi.phases).eq(~bus.sel),
|
||||||
Cat([phase.wrdata_mask for phase in dfi.phases]).eq(~bus.sel),
|
|
||||||
]
|
]
|
||||||
|
|
||||||
for phase in dfi.phases:
|
for phase in dfi.phases:
|
||||||
self.comb += [
|
self.comb += [
|
||||||
phase.cke.eq(1),
|
phase.cke.eq(1),
|
||||||
|
phase.cs_n.eq(0),
|
||||||
phase.address.eq(Array([2**10, slicer.col(bus.adr), slicer.row(bus.adr)])[addr_sel]),
|
phase.address.eq(Array([2**10, slicer.col(bus.adr), slicer.row(bus.adr)])[addr_sel]),
|
||||||
If(wb_access,
|
phase.bank.eq(slicer.bank(bus.adr))
|
||||||
phase.bank.eq(slicer.bank(bus.adr))
|
|
||||||
)
|
|
||||||
]
|
]
|
||||||
phase.cs_n.reset = 0
|
|
||||||
phase.ras_n.reset = 1
|
|
||||||
phase.cas_n.reset = 1
|
|
||||||
phase.we_n.reset = 1
|
|
||||||
|
|
||||||
for b in nbanks:
|
for b in nbanks:
|
||||||
self.sync += [
|
self.sync += [
|
||||||
|
@ -117,23 +110,23 @@ class Minicon(Module):
|
||||||
fsm.act("IDLE",
|
fsm.act("IDLE",
|
||||||
If(refresh_req,
|
If(refresh_req,
|
||||||
NextState("PRECHARGEALL")
|
NextState("PRECHARGEALL")
|
||||||
).Elif(wb_access,
|
).Elif(bus.stb & bus.cyc,
|
||||||
If(hit & bus.we,
|
If(hit & bus.we,
|
||||||
NextState("WRITE"),
|
NextState("WRITE")
|
||||||
),
|
),
|
||||||
If(hit & ~bus.we,
|
If(hit & ~bus.we,
|
||||||
NextState("READ"),
|
NextState("READ")
|
||||||
),
|
),
|
||||||
If(has_curbank_openrow & ~hit,
|
If(has_curbank_openrow & ~hit,
|
||||||
NextState("PRECHARGE")
|
NextState("PRECHARGE")
|
||||||
),
|
),
|
||||||
If(~has_curbank_openrow,
|
If(~has_curbank_openrow,
|
||||||
NextState("ACTIVATE")
|
NextState("ACTIVATE")
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
fsm.act("READ",
|
fsm.act("READ",
|
||||||
# We output Column bits at address pins so that A10 is 0
|
# We output Column bits at address pins so A10 is 0
|
||||||
# to disable row Auto-Precharge
|
# to disable row Auto-Precharge
|
||||||
dfi.phases[rdphase].ras_n.eq(1),
|
dfi.phases[rdphase].ras_n.eq(1),
|
||||||
dfi.phases[rdphase].cas_n.eq(0),
|
dfi.phases[rdphase].cas_n.eq(0),
|
||||||
|
|
Loading…
Reference in a new issue