博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Chisel3 - model - UserModule commands
阅读量:6817 次
发布时间:2019-06-26

本文共 1221 字,大约阅读时间需要 4 分钟。

 
介绍UserModule类中,如何管理构建硬件模型所需的命令。
 
 
1. _commands
 
private val _commands = ArrayBuffer[Command]()
 
_commands中存放了构建模块所需的全部命令。
 
 
1) 添加命令:addCommand
 
a. 需要没有close:_closed意为模块构建所需已经齐备,不能再向其中添加内部数据和逻辑定义;
b. 把c添加到_commands中;
 
2) 获取所有命令:getCommands
 
 
a. 需要已经close,意为模块构建所需已经齐备;
b. 返回全部命令:_commands.toSeq
 
2. Builder.pushCommand()
 
 
addCommand()通过pushCommand()调用,将命令c添加到正在构建的模块(forcedUserModule)之中。
 
3. _closed
 
 
_closed定义与BaseModule类中,为该类数据成员,protected表明子类可以直接读写访问。
 
_closed是一个标志:标志着模块定义是否已经完成,即所需的各个内部数据变量、内部逻辑是否已经全部添加到模块中。亦即构建模块的硬件模型所需的所有命令已经齐备,可以开始构建了。
 
总结并简而言之,即过程分为两个阶段:定义、构建。而_closed标志着模块定义阶段的结束。也可以用来表明可以开始构建阶段了。
 
 
4. forcedUserModule
 
pushCommand()调用forcedUserModule.addCommand(c)把命令c加入到forcedUserModule中。
 
forcedUserModule定义如下:
可知,其为Option包裹着的UserModule,即currentModule拆包而来;
 
currentModule定义如下:
currentModule基于动态上下文(dynamicContext)中定义的变量currentModule。其赋值可以直接使用“currentModule = xxx”的形式。
 
currentModule定义与Builder类中,其赋值的地方为:
 
直接定义在BaseModule的类体中,每一个BaseModule类的子类实例化时,都要执行这个代码。所以Builder.currentModule的值即为当前实例化的模块。
 
如下代码中FullAdder即为Module的子类,亦即BaseModule的子类:
 
所以new FullAdder()时,会执行到Builder.currentModule = Some(this)这行代码,而把currentModule设置为正在创建(new)的这个FullAdder模块。
 
所以后续pushCommand()时,都是添加到这个FullAdder模块中。
 
 
 

转载于:https://www.cnblogs.com/wjcdx/p/10207636.html

你可能感兴趣的文章
实现批量数据增强 | keras ImageDataGenerator使用
查看>>
太忙女友消息未及时回复,分手吗?python微信自动消息帮你谈恋爱
查看>>
Java 多线程NIO学习
查看>>
命名实体识别
查看>>
动态切换的动态代理
查看>>
电商项目(下)
查看>>
vue 数字滚动递增效果
查看>>
vue2.0中父子,兄弟组件的传值2
查看>>
Spring Boot注解常用!!!看了就可以开发大量项目了
查看>>
音频编码 Audio Converter
查看>>
SQL - case when then else end 的用法
查看>>
web优化是http缓存(上)
查看>>
19-01-14
查看>>
媒体融合三部曲(未完待续...)
查看>>
OkHttp3-拦截器(Interceptor)
查看>>
Bootstrap在实际生产开发中的使用心得
查看>>
Google推出实时内容洞察工具 为用户提供表现最好的内容
查看>>
虚拟机故障与故障处理工具之指令篇
查看>>
iOS 基础知识学习目录索引
查看>>
My_Base_notes
查看>>