https://mp.weixin.qq.com/s/KqyklKrPLtPm38sftMYlHA

 
1. 使用Maven获取库
 
Chisel相关的库基本上都可以使用Maven获取到(https://mvnrepository.com/artifact/edu.berkeley.cs):
 
 
其中Chisel Iotesters是用来进行验证的库,可以看到各个版本及其发布日期:
 
随便打开一个版本:
可以看到该版本的基本信息,点击jar可以直接下载库的jar包。下面是使用各种构建工具如Maven/Gradle/SBT/Ivy等引入该库的方法。可以复制SBT的引入方法到build.sbt中,即可以下载这个库。
 
下方是该库所依赖的库的信息:
 
其中有chisel3和firrtl,可以看到比我们使用的chisel3 3.1.2新,需要找一个老一点的版本。
 
回溯发现chisel-iotesters 1.2.3刚好匹配,复制如下行到build.sbt:
libraryDependencies += "edu.berkeley.cs" %% "chisel-iotesters" % "1.2.3"
 
如下:
 
然后Intellij IDEA提示Import Changes,选择之后开始下载这个库:
 
点击箭头所示的按钮,可以看到同步的文字信息:
同步完成即可。
 
2. 创建FullAdderTester.scala
 
创建文件,并从chisel-tutorial项目中拷贝代码,如下:
 
直接在该文件中使用main函数验证:
 
看一下这一个Driver()函数签名:
 
这个函数有两个参数列表,即apply(args_a)(args_b)。
 
第一个参数列表包含用来创建一个待测试的模块的函数,即:dutGen: () => T,这个函数不接收参数,返回一个T类型的返回值,T <: MultiIOModule表明类型T是MultiIOModule的子类型,所以返回值是一个模块。
 
第二个参数列表包含一个产生测试器的函数:testerGen: T => PeekPokeTester[T], 即接收一个模块作为参数,返回一个Tester。这里我们返回class FullAdderTest(c: FullAdder) extends PeekPokeTester(c).
 
再来看我们的实现:
在对Driver()函数的调用中,提供了两个参数列表:Driver()()。第一个参数列表提供了一个函数参数,返回FullAdder模块实例,其余的参数都是用默认值。第二个参数列表提供了一个函数参数,返回FullAdderTester。
 
3. 直接执行验证
 
直接点击三角运行符号,运行main函数:
 
可以看到测试成功了,在9个时钟周期里,总共执行了8个测试,都成功了。
 
符合Tester的写法,2个expect循环了4次,总共8个测试。
 
4. sbt shell执行验证
 
compile:
 
因为测试代码放在test而不是main目录下,所以执行test:run命令:
 
也可以使用test:runMain FullAdderTester命令:
 
5. 附录

Chisel3 - 使用chisel-iotesters进行验证的更多相关文章

  1. Chisel3 - Chisel vs. Scala

    https://mp.weixin.qq.com/s/mTmXXBzSizgiigFYVQXKpw     介绍Chisel与Scala的不同与关联.   ​​   一. 层次高低   Chisel是 ...

  2. Chisel3 - model - Hardware Model

    https://mp.weixin.qq.com/s/x6j7LZg7i7i_KcNEA8YCQw   Chisel作为领域专用语言(DSL),用于构建硬件模型.待硬件模型建立后,再基于模型进行仿真. ...

  3. Chisel3 - bind - Binding

    https://mp.weixin.qq.com/s/2318e6VJ4wFGpWwBOmTikA   Chisel数据类型(Data)与Module的绑定关系,根据Data的使用方式不同,而有多种绑 ...

  4. Chisel3 - util - Valid

    https://mp.weixin.qq.com/s/L5eAwv--WzZdr-CfW2-XNA   Chisel提供的Valid接口.如果valid为置1,则表明输出的bits有效:反之,则输出无 ...

  5. Chisel3 - Tutorial - FullAdder

    https://mp.weixin.qq.com/s/Aye-SrUUuIP6_o67Rlt5OQ   全加器   逻辑图如下: ​​   参考链接: https://github.com/ucb-b ...

  6. Chisel3 - 模块

    https://mp.weixin.qq.com/s/2vjM-gcauvHnn6KJzlOm4g   Chisel的模块和Verilog的模块很相似,都用来定义模块结构(hierarchical s ...

  7. Chisel3 - 运算符和位宽推断

    https://mp.weixin.qq.com/s/rI-CJM6GyI6EUHPZ3uYiFg   如同Verilog中的众多运算符,Chisel也针对自身的数据类型,提供了很多运算符.   Ch ...

  8. Chisel3 - 接口方向(Direction)

    https://mp.weixin.qq.com/s/36jreQGpDLCCNfmUwI34lA   模块接口有三种方向:Input/Output/Inout.Chisel在声明模块接口的时候,也需 ...

  9. Chisel3 - 基本数据类型

    https://mp.weixin.qq.com/s/bSrM-wLRn7O_75xYKeoaEQ   Chisel中的基本数据类型,不是Verilog中的Wire和Reg.Wire和Register ...

随机推荐

  1. 戴尔服务器ipmi报错

    戴尔服务器ipmi配置完成,用浏览器打开报错 查看器已终止,网络已中断 原因:这个问题是java报错,用火狐打开报错 解决方法: 用IE打开就没问题,IE要用较高版本的,楼主的是win10-IE11

  2. spring表达式语言

    使用文本表达式 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http: ...

  3. React Native超简单完整示例-tabs、页面导航、热更新、用户行为分析

    初学React Native,如果没有人指引,会发现好多东西无从下手,但当有人指引后,会发现其实很简单.这也是本人写这篇博客的主要原因,希望能帮到初学者. 本文不会介绍如何搭建开发环境,如果你还没有搭 ...

  4. Springboot邮件发送思路分析

    毕业设计里需要邮件发送,所以学习,总的来讲,我考虑以下几点, 代码量少,代码简单.配置少,一看就懂,使用 JavaMail 太麻烦了. 异步执行,添加员工之后会发送入职邮件, 多线程处理,设计里有一个 ...

  5. QML设计飘散效果

    1,目标及展示 首先希望实现文字.图片.控件等在触发后,呈现飘散并消失的效果.在QT例程<Qt Quick Particles Examples>是一个海星点击鼠标后呈现打散的效果,这个效 ...

  6. qt-n个数组实现排列组合

    例如:现在有一批鞋子,其中颜色有[‘白色’,‘黑色’,‘灰色’]:大小有[‘40’,‘41’,‘42’],样式有[‘板鞋’,‘运动’,‘休闲’],要求写一个算法,实现[[‘白色’,‘40’,‘板鞋’] ...

  7. calc less 下不起作用

    在 less中不能使用css3 calc属性不能 css3 新增长度计算属性 可以根据不同单位计算宽度 .test{ width: calc(100% - 150px); } 但是当我们在less中使 ...

  8. 上位机开发之三菱Q系列PLC通信实践

    经常关注我们公众号或者公开课的学员(如果还没有关注的话,左上角点击一波关注)应该知道,我们会经常使用西门子PLC,其实对于其他品牌的PLC,我们都会讲到,包括三菱.欧姆龙.基恩士.松下及国产台达.信捷 ...

  9. Codeforces 1272E (Nearest Opposite Parity,反向建边)

    题意:给你n个数,每个数的值为a[i],每个点可以从i这号点跳转至(i - a[i]) 或 (i + a[i])点,点的范围为[1,n],然后问的是从偶数点跳至奇数点,从奇数点跳至偶数点的最少次数是多 ...

  10. SpringMvc上传图片及表单提交(单文件+实体类参数提交)

    前两天做项目用到了Springmvc的文件上传来上传图片,由于和这个普通的Java文件上传处理流程不太一样,所以做的时候碰了壁,一顿百度,博客,要不就是一部分代码,要不就是看不懂,用不会的代码,下面来 ...