https://mp.weixin.qq.com/s/OH_Z1gdSUpfgM-tjx0OlrA

 
追溯配置信息的源头。
 
0. HasRocketCoreParameters
 
HasRocketCoreParameters中使用从HasTileParameters中继承的implicit Parameters p获取各个配置项的值。
 
这个p是抽象的,在HasRocketCoreParameters被混入(mixin)的类中实现或者推断(infer)。
 
 
1. class Rocket
 
 
class Rocket的主要构造方法有一个参数列表提供了implicit Parameters p,这个p可以被推断(infer)为HasRocketCoreParameters中的p。
 
 
2. RocketTileModuleImp
 
 
Rocket类在RocketTileModuleImp类中实例化,这里为Rocket类的主要构造方法的implicit Parameters p参数提供的实参为outer.p。
 
下一节追溯RocketTileModuleImp在哪里实例化并传入outer。
 
PS. 这里讲一个Intellij IDEA的细节。
 
按住Ctrl,鼠标左键点击outer.p中的p,跳转到如下位置:
 
outer是RocketTile的实例:
他的方法列表里也有一个implicit p: Parameters。
 
那么为什么点击outer.p的p定位到的不是RocketTile类的p呢?
 
看一下Structure窗口。
LazyModule的如下:
这里的p作为一个数据成员存在;
 
RocketTile的如下:
没有p;
 
如果把RocketTile的定义改一下:
 
这说明类的主要构造方法的参数列表中,以var/val关键字修饰的是类的成员,不带的不是。
 
那么RocketTile类主要构造方法(primary constructor)参数列表中的implicit p: Parameters就不是覆盖父类的数据成员,而只是一个参数。向当前范围(scope)内提供一个Parameters变量,这个变量可以被推断(infer)为HasTileParameters中的p。
 
 
3. RocketTile
 
RocketTileModuleImp在RocketTile类中实例化:
 
RocketTile类的定义如下:
 
他也有一个implicit p: Parameters参数。
 
 
4. HasRocketTiles
 
 
RocketTile在HasRocketTiles中实例化,使用的tp来自于:
 
这个p来自于BaseSubsystem。
 
 
5. BaseSubsystem
 
 
 
6. RocketSubsystem
 
BaseSubsystem的p来自于其子类,如RocketSubsystem:
 
 
7. ExampleRocketSystem
 
RocketSubsystem的p来自于其子类,如ExampleRocketSystem:
 
 
8. TestHarness
 
ExampleRocketSystem在TestHarness中实例化:
 
TestHarness找不到被引用的地方。
 
 
9. Makefrag
 
TestHarness在Makefrag这个Makefile文件中使用:
 
同时注意这里的CONFIG被赋值为DefaultConfig,这是一个配置类。
 
 
这里调用Generator中的main函数,并把MODEL(TestHarness)和CONFIG(DefaultConfig)作为参数传入。
 
 
10. GeneratorApp
 
Generator中没有配置相关的内容,其继承自GeneratorApp:
 
把传入的参数封装成ParsedInputNames:
 
1) 先看CONFIG,亦即DefaultConfig
 
 
fullConfigClass是DefaultConfig加上包名的路径,即:freechips.rocketchip.system.DefaultConfig。
 
这里加载这个类、实例化,并类型转换成为Parameters对象params。
 
2) 再看MODEL,亦即TestHarness
 
 
fullTopModuleClass是TestHarness加上包名的路径,即:freechips.rocketchip.system.TestHarness。
 
elaborate中就比较熟悉了:
 
调用chisel3.Driver.elaborate()返回一个Circuit实例。
 
top是一个无参但返回RawModule的函数:
a. 加载TestHarness类:Class.forName(fullTopModuleClassName)
b. 获取参数为Parameters的构造方法:getConstructor(classOf[Parameters])
c. 调用该构造方法,把params作为参数传入:newInstance(params)
 
即相当于:new TestHarness(params);
 
11. 总结
 
可以发现,配置的源头是用户传入的配置类的类名。
 
 
12. Scala:构造方法中的implicit参数列表
 
CoreModule类只定义了一个参数列表,为什么要多加一个空的参数列表呢?
 
 
这在Scala语言规范中有讲:
If a class has no formal parameter section that is not implicit, an empty parameter section () is assumed.
也就是说,即便没有明写非implicit参数列表(formal parameter section),也默认有一个。实例化时需要加上。
 
参考如下链接:
 
 
 
 

Rocket - config - implicit Parameters的更多相关文章

  1. Rocket - config - Keys & Params

    https://mp.weixin.qq.com/s/Y42EWrO7IoHRD_yHD4iRLA   介绍配置项.配置值以及他们的使用方式.   参考链接: https://docs.qq.com/ ...

  2. Rocket - config - Parameters

    https://mp.weixin.qq.com/s/uLEr9gAFaMDIXa8S9xJVTw   介绍配置类Parameters及其伴生对象的实现.   参考链接: https://docs.q ...

  3. Rocket - config - Configs

    https://mp.weixin.qq.com/s/z2gUYuYQAHQCa_5HZcBszw   介绍各个配置项的组织方式.   参考链接: https://docs.qq.com/sheet/ ...

  4. Rocket - config - DefaultConfig

    https://mp.weixin.qq.com/s/zWW00D0fb8h7_TotGD9YoQ   介绍DefaultConfig类的组成.     1. DefaultConfig   Defa ...

  5. Rocket - config - View

    https://mp.weixin.qq.com/s/b5o3s2DgqOz3-iK8FqPeLQ   介绍配置相关的基础类及其继承关系.   参考链接: https://github.com/fre ...

  6. Scala中的Implicit详解

    Scala中的implicit关键字对于我们初学者像是一个谜一样的存在,一边惊讶于代码的简洁, 一边像在迷宫里打转一样地去找隐式的代码,因此我们团队结合目前的开发工作,将implicit作为一个专题进 ...

  7. HttpRunner学习6--使用parameters参数化

    前言 在使用HttpRunner测试过程中,我们可能会遇到这种场景: 账号登录功能,需要输入用户名和密码,设计测试用例后有 N 种组合情况 如果测试组合比较少,比如只有2个,那我们直接在YAML脚本中 ...

  8. Rocket - diplomacy - AddressAdjuster分析

    https://mp.weixin.qq.com/s/UYVSO3XFJmhe5bUD_XbMLg   先介绍如何使用AddressAdjuster,然后分析UI参数的生成及使用.   ​​   1. ...

  9. Scala HandBook

    目录[-] 1.   Scala有多cool 1.1.     速度! 1.2.     易用的数据结构 1.3.     OOP+FP 1.4.     动态+静态 1.5.     DSL 1.6 ...

随机推荐

  1. qt creator源码全方面分析(4-5)

    目录 Qt中的字符串 QLatinString 详细介绍 源码 小结 QStringLiteral(str) 详细介绍 源码 小结 Qt中的字符串 Qt中处理字符串最常用的肯定是QString,但是在 ...

  2. 【Hadoop离线基础总结】impala简单介绍及安装部署

    目录 impala的简单介绍 概述 优点 缺点 impala和Hive的关系 impala如何和CDH一起工作 impala的架构及查询计划 impala/hive/spark 对比 impala的安 ...

  3. redis crackit入侵事件总结

    今天发现服务器有异常进程/opt/yam/yam,上网搜了搜,是由于redis未授权引起的入侵,查了些资料,这里做下总结. 1. 现象 有以下其一现象就要注意是否被入侵 crontab -l 可以看到 ...

  4. Linux,Unix,GNU 到底有什么样的渊源?

    Linux,Unix, GNU,你可能经常听到这些名字被放在一起,比如 “Linux是类Unix系统”, “Linux其实应该叫 GNU/Linux” 等等.为什么会有这些说法,这些名词的历史渊源和背 ...

  5. 8、HTTPS证书Actions无法导出问题

    前言 在点Actions时候出现Export Failed:The root certificate could not be located.最近有很多小伙伴在fiddler导出证书的时候,遇到无法 ...

  6. 用C++验证三门问题

    三门问题(换门): #include <iostream> #include <cstdlib> #include <ctime> #define random(a ...

  7. Web安全工程师(网易微专业Web安全学习笔记)

    本篇笔记的配套视频:网易云课堂,微专业/web安全工程师. 一.WEB基础知识 1.1 Web简介 1.1.1 Web介绍 1)web的发展 web1.0:以内容为中心,网站提供内容信息,用户进行访问 ...

  8. UIStackView上手教程

    https://www.jianshu.com/p/19fbf3ee2840 https://www.cnblogs.com/bokeyuanlibin/p/5693575.html https:// ...

  9. 母牛的故事(hdu2018)——笔记待完善

    思考:这道题考验的是罗辑思维,这个网址http://blog.csdn.net/sxhelijian/article/details/42609353的罗辑思维值得学习 #include<std ...

  10. flatbuffer介绍和用法

    介绍 flatbuffer是google发布的一个跨平台序列化框架具有如下特点 1.对序列化的数据不需要打包和拆包 2.内存和效率速度高,扩展灵活 3.代码依赖较少 4.强类型设计,编译期即可完成类型 ...