summaryrefslogtreecommitdiff
path: root/core/src/main/scala/chisel3/experimental/package.scala
diff options
context:
space:
mode:
authorJack Koenig2020-03-22 18:13:58 -0700
committerJack Koenig2020-03-25 19:17:15 -0700
commitfbf5e6f1a0e8bf535d465b748ad554575fe62156 (patch)
tree578858ab6d219ca6daf44cf87b73f75054989097 /core/src/main/scala/chisel3/experimental/package.scala
parentb2e004fb615a3c931d910a338b9faa99c1c975d7 (diff)
Rename subprojects to more canonical names
* Rename coreMacros to macros * Rename chiselFrontend to core Also make each subproject publish with "chisel3-" as a prefix
Diffstat (limited to 'core/src/main/scala/chisel3/experimental/package.scala')
-rw-r--r--core/src/main/scala/chisel3/experimental/package.scala140
1 files changed, 140 insertions, 0 deletions
diff --git a/core/src/main/scala/chisel3/experimental/package.scala b/core/src/main/scala/chisel3/experimental/package.scala
new file mode 100644
index 00000000..985f7715
--- /dev/null
+++ b/core/src/main/scala/chisel3/experimental/package.scala
@@ -0,0 +1,140 @@
+// See LICENSE for license details.
+
+package chisel3
+
+/** Package for experimental features, which may have their API changed, be removed, etc.
+ *
+ * Because its contents won't necessarily have the same level of stability and support as
+ * non-experimental, you must explicitly import this package to use its contents.
+ */
+package object experimental { // scalastyle:ignore object.name
+ import scala.language.implicitConversions
+ import chisel3.internal.BaseModule
+
+ // Implicit conversions for BlackBox Parameters
+ implicit def fromIntToIntParam(x: Int): IntParam = IntParam(BigInt(x))
+ implicit def fromLongToIntParam(x: Long): IntParam = IntParam(BigInt(x))
+ implicit def fromBigIntToIntParam(x: BigInt): IntParam = IntParam(x)
+ implicit def fromDoubleToDoubleParam(x: Double): DoubleParam = DoubleParam(x)
+ implicit def fromStringToStringParam(x: String): StringParam = StringParam(x)
+
+ type ChiselEnum = EnumFactory
+
+ @deprecated("Use the version in chisel3._", "3.2")
+ val withClockAndReset = chisel3.withClockAndReset
+ @deprecated("Use the version in chisel3._", "3.2")
+ val withClock = chisel3.withClock
+ @deprecated("Use the version in chisel3._", "3.2")
+ val withReset = chisel3.withReset
+
+ // Rocket Chip-style clonemodule
+
+ /** A record containing the results of CloneModuleAsRecord
+ * The apply method is retrieves the element with the supplied name.
+ */
+ type ClonePorts = BaseModule.ClonePorts
+
+ object CloneModuleAsRecord {
+ /** Clones an existing module and returns a record of all its top-level ports.
+ * Each element of the record is named with a string matching the
+ * corresponding port's name and shares the port's type.
+ * @example {{{
+ * val q1 = Module(new Queue(UInt(32.W), 2))
+ * val q2_io = CloneModuleAsRecord(q1)("io").asInstanceOf[q1.io.type]
+ * q2_io.enq <> q1.io.deq
+ * }}}
+ */
+ def apply(proto: BaseModule)(implicit sourceInfo: chisel3.internal.sourceinfo.SourceInfo, compileOptions: CompileOptions): ClonePorts = { // scalastyle:ignore line.size.limit
+ BaseModule.cloneIORecord(proto)
+ }
+ }
+
+ val requireIsHardware = chisel3.internal.requireIsHardware
+ val requireIsChiselType = chisel3.internal.requireIsChiselType
+ type Direction = ActualDirection
+ val Direction = ActualDirection
+
+ implicit class ChiselRange(val sc: StringContext) extends AnyVal {
+
+ import scala.language.experimental.macros
+
+ /** Specifies a range using mathematical range notation. Variables can be interpolated using
+ * standard string interpolation syntax.
+ * @example {{{
+ * UInt(range"[0, 2)")
+ * UInt(range"[0, \$myInt)")
+ * UInt(range"[0, \${myInt + 2})")
+ * }}}
+ */
+ def range(args: Any*): chisel3.internal.firrtl.IntervalRange = macro chisel3.internal.RangeTransform.apply
+ }
+
+ class dump extends chisel3.internal.naming.dump // scalastyle:ignore class.name
+ class treedump extends chisel3.internal.naming.treedump // scalastyle:ignore class.name
+ /** Experimental macro for naming Chisel hardware values
+ *
+ * By default, Chisel uses reflection for naming which only works for public fields of `Bundle`
+ * and `Module` classes. Applying this macro annotation to a `class` or `object` enables Chisel
+ * to name any hardware values within the annotated `class` or `object.
+ *
+ * @example {{{
+ * import chisel3._
+ * import chisel3.experimental.chiselName
+ *
+ * @chiselName
+ * class MyModule extends Module {
+ * val io = IO(new Bundle {
+ * val in = Input(UInt(8.W))
+ * val out = Output(UInt(8.W))
+ * })
+ * def createReg(): Unit = {
+ * // @chiselName allows Chisel to name this Reg
+ * val myReg = RegInit(io.in)
+ * io.out := myReg
+ * }
+ * createReg()
+ * }
+ * }}}
+ */
+ class chiselName extends chisel3.internal.naming.chiselName // scalastyle:ignore class.name
+ /** Do not name instances of this type in [[chiselName]]
+ *
+ * By default, `chiselName` will include `val` names of instances of annotated classes as a
+ * prefix in final naming. Mixing in this trait to a `class`, `object`, or anonymous `class`
+ * instances will exclude the `val` name from `chiselName` naming.
+ *
+ * @example {{{
+ * import chisel3._
+ * import chisel3.experimental.{chiselName, NoChiselNamePrefix}
+ *
+ * // Note that this is not a Module
+ * @chiselName
+ * class Counter(w: Int) {
+ * val myReg = RegInit(0.U(w.W))
+ * myReg := myReg + 1.U
+ * }
+ *
+ * @chiselName
+ * class MyModule extends Module {
+ * val io = IO(new Bundle {
+ * val out = Output(UInt(8.W))
+ * })
+ * // Name of myReg will be "counter0_myReg"
+ * val counter0 = new Counter(8)
+ * // Name of myReg will be "myReg"
+ * val counter1 = new Counter(8) with NoChiselNamePrefix
+ * io.out := counter0.myReg + counter1.myReg
+ * }
+ * }}}
+ */
+ trait NoChiselNamePrefix
+
+ object BundleLiterals {
+ implicit class AddBundleLiteralConstructor[T <: Bundle](x: T) {
+ //scalastyle:off method.name
+ def Lit(elems: (T => (Data, Data))*): T = {
+ x._makeLit(elems: _*)
+ }
+ }
+ }
+}