2

モジュールをテストしているテスター内から、モジュールを構築するために使用されるパラメーターにどのようにアクセスしますか?

以下のテストでは、パラメーターをモジュールとテスターの両方に明示的に渡しています。それらをテスターに​​渡す必要はなく、代わりに渡されたモジュールからそれらを抽出したいと思います。

また、私はscala/chiselを初めて使用するので、私が使用している悪いテクニックに関するヒントをいただければ幸いです:)。

import Chisel._
import math.pow

class TestA(dataWidth: Int, arrayLength: Int) extends Module {
  val dataType = Bits(INPUT, width = dataWidth)
  val arrayType = Vec(gen = dataType, n = arrayLength)
  val io = new Bundle {
    val i_valid = Bool(INPUT)
    val i_data = dataType
    val i_array = arrayType
    val o_valid = Bool(OUTPUT)
    val o_data = dataType.flip
    val o_array = arrayType.flip
  }
  io.o_valid := io.i_valid
  io.o_data := io.i_data
  io.o_array := io.i_array
}

class TestATests(c: TestA, dataWidth: Int, arrayLength: Int) extends Tester(c) {
  val maxData = pow(2, dataWidth).toInt
  for (t <- 0 until 16) {
    val i_valid = rnd.nextInt(2)
    val i_data = rnd.nextInt(maxData)
    val i_array = List.fill(arrayLength)(rnd.nextInt(maxData))
    poke(c.io.i_valid, i_valid)
    poke(c.io.i_data, i_data)
    (c.io.i_array, i_array).zipped foreach {
      (element,value) => poke(element, value)
    }
    expect(c.io.o_valid, i_valid)
    expect(c.io.o_data, i_data)
    (c.io.o_array, i_array).zipped foreach {
      (element,value) => poke(element, value)
    }
    step(1)
  }
}    

object TestAObject {
  def main(args: Array[String]): Unit = {
    val tutArgs = args.slice(0, args.length)
    val dataWidth = 5
    val arrayLength = 6
    chiselMainTest(tutArgs, () => Module(
      new TestA(dataWidth=dataWidth, arrayLength=arrayLength))){
      c => new TestATests(c, dataWidth=dataWidth, arrayLength=arrayLength)
    }
   }
}
4

1 に答える 1

2

TestA の引数 dataWidth および arrayLength メンバーを作成すると、それらを参照することができます。Scala では、引数リストに val を挿入することでこれを実現できます。

class TestA(val dataWidth: Int, val arrayLength: Int) extends Module ...

c.dataWidth次に、またはを使用してメンバーとしてテストからそれらを参照できますc.arrayLength

于 2015-05-22T18:34:54.233 に答える