wishbone2lasmi : add support for 32 bits lasmim data width

This commit is contained in:
Florent Kermarrec 2013-08-20 16:53:55 +02:00 committed by Sebastien Bourdeauducq
parent 37930d70ac
commit a653a6144b

View file

@ -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)]