如何在Chisel中使用VecInit(Array())创建ROM?

法比恩

我想声明«ROM»与VecInit()喜欢它

  val GbColors = VecInit(Array(GB_GREEN0, GB_GREEN1, GB_GREEN2, GB_GREEN3))

用这样GB_GREENx声明:

class VgaColors extends Bundle {
  val red   = UInt(6.W)
  val green = UInt(6.W)
  val blue  = UInt(6.W)
}

//...
object GbConst {
//...
                            /* "#9BBC0F"*/
val GB_GREEN0 = (new VgaColors()).Lit(_.red   -> "h26".U(6.W),
                                      _.green -> "h2F".U(6.W),
                                      _.blue  -> "h03".U(6.W))

                          /* "#8BAC0F"*/
 val GB_GREEN1 = (new VgaColors()).Lit(_.red   -> "h1E".U(6.W),
                                       _.green -> "h27".U(6.W),
                                       _.blue  -> "h03".U(6.W))
                          /* "#306230"*/
 val GB_GREEN2 = (new VgaColors()).Lit(_.red   -> "h0C".U(6.W),
                                       _.green -> "h18".U(6.W),
                                       _.blue  -> "h0C".U(6.W))
                          /*"#0F380F"*/
 val GB_GREEN3 = (new VgaColors()).Lit(_.red   -> "h03".U(6.W),
                                       _.green -> "h0E".U(6.W),
                                       _.blue  -> "h03".U(6.W))

我无法使用GbColors作为可索引的Vec

 io.vga_color := GbColors(io.mem_data)

它生成一个Java堆栈错误:

[info] [0.004] Elaborating design...
[error] chisel3.internal.ChiselException: Connection between sink (VgaColors(IO in unelaborated MemVga)) and source (VgaColors(Wire in GbWrite)) failed @.blue: Sink or source unavailable to current module.
[error]     ...
[error]     at gbvga.MemVga.$anonfun$new$42(memvga.scala:87)
[error]     at scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:23)
[error]     at chisel3.WhenContext.<init>(When.scala:80)
[error]     at chisel3.when$.apply(When.scala:32)
[error]     at gbvga.MemVga.<init>(memvga.scala:86)
[error]     at gbvga.GbVga.$anonfun$memvga$1(gbvga.scala:24)
[error]     at chisel3.Module$.do_apply(Module.scala:54)
[error]     at gbvga.GbVga.<init>(gbvga.scala:24)
[error]     at gbvga.GbVgaDriver$.$anonfun$new$9(gbvga.scala:53)
[error]     ... (Stack trace trimmed to user code only, rerun with --full-stacktrace if you wish to see the full stack trace)
...

要管理它,我必须使用switch(){is()}format:

    switch(io.mem_data) {
      is("b00".U) {
        io.vga_color := GB_GREEN0
      }
      is("b01".U) {
        io.vga_color := GB_GREEN1
      }
      is("b10".U) {
        io.vga_color := GB_GREEN2
      }
      is("b11".U) {
        io.vga_color := GB_GREEN3
      }
    }

但这太冗长了。我的VecInit()«rom»有什么问题?

[编辑]

我的版本是:

$ java -version
java version "1.8.0_151"
Java(TM) SE Runtime Environment (build 1.8.0_151-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.151-b12, mixed mode)
$ scala -version
Scala code runner version 2.11.7-20150420-135909-555f8f09c9 -- Copyright 2002-2013, LAMP/EPFL

build.sbt中

val defaultVersions = Map(
  "chisel3" -> "3.4.0-RC1",
  "chisel-iotesters" -> "1.5.0-RC1",
  "chisel-formal" -> "0.1-SNAPSHOT",
  )
小鸡马克利

我认为这里的问题是因为Bundles inGbConst是在之外创建的Module一种可能的解决方法是将GbConst制成atrait并将其添加到需要访问这些值的模块中。(我创建了一个PR,它似乎表明了这种方法的有效性,尽管它可能创建了很多Bundles副本)。另一种方法(我尚未尝试过)是创建一个模块,该模块将所有捆绑软件作为输出使用(应该制作较少的副本)。

我的PR也将chisel3和chisel-testers依赖项更改为SNAPSHOTS。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何在Chisel中使用算术移位运算符

如何在Chisel3中使用实验功能?

如何在chisel中的聚合内存中使用掩码?

如何在I / O端口中使用chisel3.experimental.ChiselEnum?

如何在Chisel中使用参数化模块生成Verilog代码?

如何在 D3 v3 中使用 Catmull-Rom 插值?

如何在 Array[Array] 中使用 map

如何在angularjs中使用ng-repeat和array时创建对象

如何在PHP中使用array_fill函数创建数组?

如何在 php 中使用由“str_replace”和“array”创建的“变量”,也在 Javascript 中?

如何在多列中创建rom数据图(ggplot)

如何在pyspark中使用groupby创建转换矩阵

如何在熊猫中使用groupby创建索引列

如何在.NET中使用REST API创建Azure蓝图

如何在React中使用Formik创建动态下拉列表?

如何在Athena中使用日期分区创建VIEW?

如何在Maven中使用多模块项目创建汇编

如何在Haskell中使用属性输出创建quickCheck属性?

如何在Groovy中使用地图创建JSON

如何在Eclipse中使用Maven创建Spring Web项目?

如何在MarkLogic中使用XQuery创建UTC时间戳?

如何在windwos中使用参数创建git别名

如何在Clojure中使用JDBC创建数据库?

如何在React中使用for循环创建选择框?

如何在Kotlin中使用泛型创建地图?

如何在Debian中使用Gnome创建默认文件关联?

如何在Scala中使用Lambda创建Java Callable?

如何在python中使用魔杖创建图像

如何在Groovy中使用JsonBuilder创建数组