代码拉取完成,页面将自动刷新
// See LICENSE.txt for license details.
package examples
import chisel3.iotesters.{PeekPokeTester, Driver, ChiselFlatSpec}
import chisel3.util._
import chisel3._
class alu32Tests(c: alu32) extends PeekPokeTester(c) {
for (t <- 0 until 16) {
val rnd0 = rnd.nextInt(16)
val rnd1 = rnd.nextInt(16)
val rnd2 = rnd.nextInt(2)
poke(c.io.in1, rnd0)
poke(c.io.in2, rnd1)
poke(c.io.aluop, rnd2)
step(1)
val rsum0 = c.io.in1 + c.io.in2
val rsum1 = c.io.in1 - c.io.in2
val rsum2 = c.io.in1 * c.io.in2
val rsum3 = c.io.in1 / c.io.in2
val rsum = rsum0
switch(c.io.aluop)
{
is(0.U) {rsum := rsum0}
is(1.U) {rsum := rsum1}
is(2.U) {rsum := rsum2}
is(3.U) {rsum := rsum3}
}
expect(c.io.out, rsum)
}
}
class alu32Tester extends ChiselFlatSpec {
behavior of "alu32"
backends foreach {backend =>
it should s"correctly add randomly generated numbers $backend" in {
Driver(() => new alu32, backend)(c => new alu32Tests(c)) should be (true)
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。