mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
wishbone2lasmi : add support for 32 bits lasmim data width
This commit is contained in:
parent
37930d70ac
commit
a653a6144b
1 changed files with 9 additions and 4 deletions
|
@ -11,8 +11,8 @@ class WB2LASMI(Module):
|
||||||
|
|
||||||
###
|
###
|
||||||
|
|
||||||
if lasmim.dw <= 32:
|
if lasmim.dw < 32:
|
||||||
raise ValueError("LASMI data width must be strictly larger than 32")
|
raise ValueError("LASMI data width must be >= 32")
|
||||||
if (lasmim.dw % 32) != 0:
|
if (lasmim.dw % 32) != 0:
|
||||||
raise ValueError("LASMI data width must be a multiple of 32")
|
raise ValueError("LASMI data width must be a multiple of 32")
|
||||||
|
|
||||||
|
@ -31,7 +31,12 @@ class WB2LASMI(Module):
|
||||||
|
|
||||||
write_from_lasmi = Signal()
|
write_from_lasmi = Signal()
|
||||||
write_to_lasmi = Signal()
|
write_to_lasmi = Signal()
|
||||||
|
if adr_offset is None:
|
||||||
|
adr_offset_r = None
|
||||||
|
else:
|
||||||
adr_offset_r = Signal(offsetbits)
|
adr_offset_r = Signal(offsetbits)
|
||||||
|
self.sync += adr_offset_r.eq(adr_offset)
|
||||||
|
|
||||||
self.comb += [
|
self.comb += [
|
||||||
data_port.adr.eq(adr_line),
|
data_port.adr.eq(adr_line),
|
||||||
If(write_from_lasmi,
|
If(write_from_lasmi,
|
||||||
|
@ -49,7 +54,7 @@ class WB2LASMI(Module):
|
||||||
),
|
),
|
||||||
chooser(data_port.dat_r, adr_offset_r, self.wishbone.dat_r, reverse=True)
|
chooser(data_port.dat_r, adr_offset_r, self.wishbone.dat_r, reverse=True)
|
||||||
]
|
]
|
||||||
self.sync += adr_offset_r.eq(adr_offset)
|
|
||||||
|
|
||||||
# Tag memory
|
# Tag memory
|
||||||
tag_layout = [("tag", tagbits), ("dirty", 1)]
|
tag_layout = [("tag", tagbits), ("dirty", 1)]
|
||||||
|
|
Loading…
Reference in a new issue