1 Star 0 Fork 1

刘梦缘/ALU

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
aluTests.scala 1.06 KB
一键复制 编辑 原始数据 按行查看 历史
刘梦缘 提交于 2019-05-18 22:09 . ALU
// 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)
}
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Scala
1
https://gitee.com/liu1807182820/ALU.git
git@gitee.com:liu1807182820/ALU.git
liu1807182820
ALU
ALU
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385