diff options
| author | Schuyler Eldridge | 2018-08-21 14:32:13 -0400 |
|---|---|---|
| committer | Schuyler Eldridge | 2018-08-23 14:05:20 -0400 |
| commit | 87551bf5f56d52198efaabdeb69dcd15fb230954 (patch) | |
| tree | 9e7464dc06123b102045ed04136666efd0308ae8 /src/main/scala/chisel3 | |
| parent | ee0f27c50f8d029721e69c0e7a7bd47b9a4c1d02 (diff) | |
Add FlattenInstance API
This adds a new trait, FlattenInstance, to chisel3.util.experimental. When
mixed into a module or a specific instance this trait will "flatten",
i.e., "inline that module and all of its submodules".
This includes testing (additions to InlineSpec) and ScalaDoc
documentation.
Signed-off-by: Schuyler Eldridge <schuyler.eldridge@ibm.com>
Diffstat (limited to 'src/main/scala/chisel3')
| -rw-r--r-- | src/main/scala/chisel3/util/experimental/Inline.scala | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/main/scala/chisel3/util/experimental/Inline.scala b/src/main/scala/chisel3/util/experimental/Inline.scala index 4039f3ed..8ec5219b 100644 --- a/src/main/scala/chisel3/util/experimental/Inline.scala +++ b/src/main/scala/chisel3/util/experimental/Inline.scala @@ -48,3 +48,38 @@ trait InlineInstance { self: BaseModule => def toFirrtl: Annotation = NoDedupAnnotation(self.toNamed) }) .map(chisel3.experimental.annotate(_)) } + +/** Flattens an instance of a module + * + * @example {{{ + * trait Internals { this: Module => + * val io = IO(new Bundle{ val a = Input(Bool()) }) + * } + * class Foo extends Module with Internals with FlattenInstance + * class Bar extends Module with Internals { + * val baz = Module(new Baz) + * baz.io.a := io.a + * } + * class Baz extends Module with Internals + * /* The resulting instances will be: + * - Top + * - Top.x + * - Top.y + * - Top.z + * - Top.z.baz */ + * class Top extends Module with Internals { + * val x = Module(new Foo) // x will be flattened + * val y = Module(new Bar with FlattenInstance) // y will also be flattened + * val z = Module(new Bar) // z will not be flattened + * Seq(x, y, z).map(_.io.a := io.a) + * } + * }}} + */ +trait FlattenInstance { self: BaseModule => + Seq(new ChiselAnnotation with RunFirrtlTransform { + def toFirrtl: Annotation = FlattenAnnotation(self.toNamed) + def transformClass: Class[_ <: Transform] = classOf[Flatten] }, + new ChiselAnnotation { + def toFirrtl: Annotation = NoDedupAnnotation(self.toNamed) }) + .map(chisel3.experimental.annotate(_)) +} |
