Skip to content
This repository has been archived by the owner on Aug 20, 2024. It is now read-only.

Fix bug in zero-width memory removal #2153

Merged
merged 2 commits into from
Mar 26, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 9 additions & 18 deletions src/main/scala/firrtl/passes/ZeroWidth.scala
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,12 @@ object ZeroWidth extends Transform with DependencyAPIMigration {
case _ => false
}

private def makeEmptyMemBundle(name: String): Field =
Field(
name,
Flip,
BundleType(
Seq(
Field("addr", Default, UIntType(IntWidth(0))),
Field("en", Default, UIntType(IntWidth(0))),
Field("clk", Default, UIntType(IntWidth(0))),
Field("data", Flip, UIntType(IntWidth(0)))
)
)
)
private def makeZero(tpe: ir.Type): ir.Type = tpe match {
case ClockType => UIntType(IntWidth(0))
case a: UIntType => a.copy(IntWidth(0))
case a: SIntType => a.copy(IntWidth(0))
case a: AggregateType => a.map(makeZero)
}
Comment on lines +28 to +33
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
private def makeZero(tpe: ir.Type): ir.Type = tpe match {
case ClockType => UIntType(IntWidth(0))
case a: UIntType => a.copy(IntWidth(0))
case a: SIntType => a.copy(IntWidth(0))
case a: AggregateType => a.map(makeZero)
}
private def makeZeroWidth(tpe: ir.Type): ir.Type = tpe match {
case ClockType => UIntType(IntWidth(0))
case a: UIntType => a.copy(IntWidth(0))
case a: SIntType => a.copy(IntWidth(0))
case a: AggregateType => a.map(makeZeroWidth)
}

I was about to link you to Utils.getGroundZero because that's the functionality that makeZero implies to me

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Well I'm too late, not worth changing heh


private def onEmptyMemStmt(s: Statement): Statement = s match {
case d @ DefMemory(info, name, tpe, _, _, _, rs, ws, rws, _) =>
Expand All @@ -46,11 +39,9 @@ object ZeroWidth extends Transform with DependencyAPIMigration {
DefWire(
info,
name,
BundleType(
rs.map(r => makeEmptyMemBundle(r)) ++
ws.map(w => makeEmptyMemBundle(w)) ++
rws.map(rw => makeEmptyMemBundle(rw))
)
MemPortUtils
.memType(d)
.map(makeZero)
)
case Some(_) => d
}
Expand Down
63 changes: 63 additions & 0 deletions src/test/scala/firrtlTests/ZeroWidthTests.scala
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,69 @@ class ZeroWidthTests extends FirrtlFlatSpec {
| z <= asUInt(y)""".stripMargin
(parse(exec(input))) should be(parse(check))
}

"Memories with zero-width data-type" should "be fully removed" in {
val input =
"""circuit Foo:
| module Foo:
| input clock: Clock
| input rAddr: UInt<4>
| input rEn: UInt<1>
| output rData: UInt<0>
| input wAddr: UInt<4>
| input wEn: UInt<1>
| input wMask: UInt<1>
| input wData: UInt<0>
| input rwEn: UInt<1>
| input rwMode: UInt<1>
| input rwAddr: UInt<1>
| input rwMask: UInt<1>
| input rwDataIn: UInt<0>
| output rwDataOut: UInt<0>
|
| mem memory:
| data-type => UInt<0>
| depth => 16
| reader => r
| writer => w
| readwriter => rw
| read-latency => 0
| write-latency => 1
| read-under-write => undefined
|
| memory.r.clk <= clock
| memory.r.en <= rEn
| memory.r.addr <= rAddr
| rData <= memory.r.data
| memory.w.clk <= clock
| memory.w.en <= wEn
| memory.w.addr <= wAddr
| memory.w.mask <= wMask
| memory.w.data <= wData
| memory.rw.clk <= clock
| memory.rw.en <= rwEn
| memory.rw.addr <= rwAddr
| memory.rw.wmode <= rwMode
| memory.rw.wmask <= rwMask
| memory.rw.wdata <= rwDataIn
| rwDataOut <= memory.rw.rdata""".stripMargin
val check =
s"""circuit Foo:
| module Foo:
| input clock: Clock
| input rAddr: UInt<4>
| input rEn: UInt<1>
| input wAddr: UInt<4>
| input wEn: UInt<1>
| input wMask: UInt<1>
| input rwEn: UInt<1>
| input rwMode: UInt<1>
| input rwAddr: UInt<1>
| input rwMask: UInt<1>
|
|${Seq.tabulate(17)(_ => " skip").mkString("\n")}""".stripMargin
parse(exec(input)) should be(parse(check))
}
}

class ZeroWidthVerilog extends FirrtlFlatSpec {
Expand Down