Merge pull request #69 from ucb-bar/abejgonzalez-patch-1
Fix macrocompiler for RW mask port
This commit is contained in:
@@ -511,7 +511,7 @@ class MacroCompilerPass(mems: Option[Seq[Macro]],
|
|||||||
/* Palmer: If we don't have a chip enable but do have mask ports. */
|
/* Palmer: If we don't have a chip enable but do have mask ports. */
|
||||||
stmts += connectPorts(memMask, mask, mask_polarity)
|
stmts += connectPorts(memMask, mask, mask_polarity)
|
||||||
stmts += connectPorts(andAddrMatch(and(memWriteEnable, memChipEnable)),
|
stmts += connectPorts(andAddrMatch(and(memWriteEnable, memChipEnable)),
|
||||||
we, mask_polarity)
|
we, we_polarity)
|
||||||
case (None, Some(PolarizedPort(we, we_polarity)), chipEnable) =>
|
case (None, Some(PolarizedPort(we, we_polarity)), chipEnable) =>
|
||||||
if (bitWidth(memMask.tpe) == 1) {
|
if (bitWidth(memMask.tpe) == 1) {
|
||||||
/* Palmer: If we're expected to provide mask ports without a
|
/* Palmer: If we're expected to provide mask ports without a
|
||||||
|
|||||||
27
macros/src/test/resources/lib-MaskPortTest.json
Normal file
27
macros/src/test/resources/lib-MaskPortTest.json
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"type" : "sram",
|
||||||
|
"name" : "fake_mem",
|
||||||
|
"width" : 64,
|
||||||
|
"depth" : "512",
|
||||||
|
"mux" : 4,
|
||||||
|
"family" : "1rw",
|
||||||
|
"ports" : [ {
|
||||||
|
"address port name" : "addr",
|
||||||
|
"address port polarity" : "active high",
|
||||||
|
"clock port name" : "clk",
|
||||||
|
"clock port polarity" : "positive edge",
|
||||||
|
"write enable port name" : "wen",
|
||||||
|
"write enable port polarity" : "active high",
|
||||||
|
"read enable port name" : "ren",
|
||||||
|
"read enable port polarity" : "active high",
|
||||||
|
"output port name" : "dataout",
|
||||||
|
"output port polarity" : "active high",
|
||||||
|
"input port name" : "datain",
|
||||||
|
"input port polarity" : "active high",
|
||||||
|
"mask port name" : "mport",
|
||||||
|
"mask port polarity" : "active low",
|
||||||
|
"mask granularity" : 1
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
]
|
||||||
@@ -22,6 +22,90 @@ class GenerateSomeVerilog extends MacroCompilerSpec with HasSRAMGenerator with H
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class MaskPortTest extends MacroCompilerSpec with HasSRAMGenerator {
|
||||||
|
val mem = s"mem-MaskPortTest.json" // mem. you want to create
|
||||||
|
val lib = s"lib-MaskPortTest.json" // lib. of mems to create it
|
||||||
|
val v = s"MaskPortTest.json"
|
||||||
|
|
||||||
|
override val libPrefix = "macros/src/test/resources"
|
||||||
|
|
||||||
|
val memSRAMs = mdf.macrolib.Utils.readMDFFromString(
|
||||||
|
"""
|
||||||
|
[ {
|
||||||
|
"type" : "sram",
|
||||||
|
"name" : "cc_dir_ext",
|
||||||
|
"width" : 128,
|
||||||
|
"depth" : "512",
|
||||||
|
"mux" : 1,
|
||||||
|
"ports" : [ {
|
||||||
|
"address port name" : "RW0_addr",
|
||||||
|
"address port polarity" : "active high",
|
||||||
|
"clock port name" : "RW0_clk",
|
||||||
|
"clock port polarity" : "positive edge",
|
||||||
|
"write enable port name" : "RW0_wmode",
|
||||||
|
"write enable port polarity" : "active high",
|
||||||
|
"chip enable port name" : "RW0_en",
|
||||||
|
"chip enable port polarity" : "active high",
|
||||||
|
"output port name" : "RW0_rdata",
|
||||||
|
"output port polarity" : "active high",
|
||||||
|
"input port name" : "RW0_wdata",
|
||||||
|
"input port polarity" : "active high",
|
||||||
|
"mask port name" : "RW0_wmask",
|
||||||
|
"mask port polarity" : "active high",
|
||||||
|
"mask granularity" : 16
|
||||||
|
} ],
|
||||||
|
"family" : "1rw"
|
||||||
|
} ]
|
||||||
|
""").getOrElse(List())
|
||||||
|
|
||||||
|
writeToMem(mem, memSRAMs)
|
||||||
|
|
||||||
|
val output =
|
||||||
|
"""
|
||||||
|
circuit cc_dir_ext :
|
||||||
|
module cc_dir_ext :
|
||||||
|
input RW0_addr : UInt<9>
|
||||||
|
input RW0_clk : Clock
|
||||||
|
input RW0_wdata : UInt<128>
|
||||||
|
output RW0_rdata : UInt<128>
|
||||||
|
input RW0_en : UInt<1>
|
||||||
|
input RW0_wmode : UInt<1>
|
||||||
|
input RW0_wmask : UInt<8>
|
||||||
|
|
||||||
|
inst mem_0_0 of fake_mem
|
||||||
|
inst mem_0_1 of fake_mem
|
||||||
|
mem_0_0.clk <= RW0_clk
|
||||||
|
mem_0_0.addr <= RW0_addr
|
||||||
|
node RW0_rdata_0_0 = bits(mem_0_0.dataout, 63, 0)
|
||||||
|
mem_0_0.datain <= bits(RW0_wdata, 63, 0)
|
||||||
|
mem_0_0.ren <= and(not(RW0_wmode), UInt<1>("h1"))
|
||||||
|
mem_0_0.mport <= not(cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 3, 3), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 2, 2), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 1, 1), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), cat(bits(RW0_wmask, 0, 0), bits(RW0_wmask, 0, 0)))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))
|
||||||
|
mem_0_0.wen <= and(and(RW0_wmode, RW0_en), UInt<1>("h1"))
|
||||||
|
mem_0_1.clk <= RW0_clk
|
||||||
|
mem_0_1.addr <= RW0_addr
|
||||||
|
node RW0_rdata_0_1 = bits(mem_0_1.dataout, 63, 0)
|
||||||
|
mem_0_1.datain <= bits(RW0_wdata, 127, 64)
|
||||||
|
mem_0_1.ren <= and(not(RW0_wmode), UInt<1>("h1"))
|
||||||
|
mem_0_1.mport <= not(cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 7, 7), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 6, 6), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 5, 5), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), cat(bits(RW0_wmask, 4, 4), bits(RW0_wmask, 4, 4)))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))
|
||||||
|
mem_0_1.wen <= and(and(RW0_wmode, RW0_en), UInt<1>("h1"))
|
||||||
|
node RW0_rdata_0 = cat(RW0_rdata_0_1, RW0_rdata_0_0)
|
||||||
|
RW0_rdata <= mux(UInt<1>("h1"), RW0_rdata_0, UInt<1>("h0"))
|
||||||
|
|
||||||
|
extmodule fake_mem :
|
||||||
|
input addr : UInt<9>
|
||||||
|
input clk : Clock
|
||||||
|
input datain : UInt<64>
|
||||||
|
output dataout : UInt<64>
|
||||||
|
input ren : UInt<1>
|
||||||
|
input wen : UInt<1>
|
||||||
|
input mport : UInt<64>
|
||||||
|
|
||||||
|
defname = fake_mem
|
||||||
|
"""
|
||||||
|
|
||||||
|
compileExecuteAndTest(mem, lib, v, output)
|
||||||
|
}
|
||||||
|
|
||||||
class BOOMTest extends MacroCompilerSpec with HasSRAMGenerator {
|
class BOOMTest extends MacroCompilerSpec with HasSRAMGenerator {
|
||||||
val mem = s"mem-BOOMTest.json"
|
val mem = s"mem-BOOMTest.json"
|
||||||
val lib = s"lib-BOOMTest.json"
|
val lib = s"lib-BOOMTest.json"
|
||||||
|
|||||||
Reference in New Issue
Block a user