Rocket - regmapper - RegField
https://mp.weixin.qq.com/s/7WKB1QxcVzqm2Q7bWcKHzA
简单介绍RegField的实现。
1. 简单介绍
定义寄存器域相关的参数类型。
2. RegFieldAccessType
访问类型:读、写、读写:
3. RegFieldWrType
写操作类型:
写一清零,写一置位,写一反转,
写零清零,写零置位,写零反转,
清除,置位,修改
4. RegFieldRdAction
读操作的作用:清零,置位,修改:
5. RegFieldDesc
1) class
寄存器域描述,定义寄存器域的各种属性:
a. name:名称;
b. desc:描述;
c. group:所在组;
d. groupDesc:组描述;
e. access:访问类型,默认为读写类型;
f. wrType:写类型;
g. rdAction:读的动作;
h. volatile:寄存器的值是否会自动变换;
i. reset:复位值;
j. enumberations:推测为寄存器域各个值代表意义的描述:
2) object
创建一个reserved的寄存器域:
6. RegFieldGroup
使用name和desc描述regs中的寄存器:
7. RegReadFn
1) class
读寄存器的函数:
包含两个参数:
a. combinational:是否为组合逻辑;
b. fn:参数为输入信号,返回值为输出信号的用于生成读取逻辑的函数:
2) object
用于生成读取逻辑的辅助方法。
a. 直接传入逻辑生成函数作为参数:
b. 使用RegisterReadIO作为参数:
RegisterReadIO在RegisterCrossing中定义:
c. 只输入oready用于生成读取逻辑:
d. 使用ReadValidIO读取:
e. 直接使用一个UInt作为读取逻辑的输出:
f. 把Unit转换为RegReadFn的隐式类型转换方法:
8. RegWriteFn
与RegReadFn同理,用于生成写入逻辑的辅助方法。
9. RegField
用于描述一个寄存器域。
1) case class
定义了寄存器域的比特位宽度,读函数、写函数,描述信息:
a. pipelined
读写函数中是否有非组合逻辑:
b. readOnly:
生成一个只读版本的拷贝:
c. toJson:
把寄存器域的各个属性转换为JSON格式的对象,以便输出:
PS. 可以看到这里需要外部提供字节偏移量和位偏移量信息(因为RegField只有位宽度信息,寄存器域可以复用,具体放在哪个位置可以是变化的)。
2) object
辅助方法,用于创建各种类型的寄存器域:
其中:
a. ()表示空函数;
b. r:生成只读寄存器;
c. w:生成只写寄存器;
d. w1ToClear:生成一个协议清零的读写寄存器:
e. rwReg:为BlackBox寄存器生成读写逻辑:
f. bytes:生成一个以字节为单位进行读写的逻辑:
其中:
a) fullBytes为全部为有效位的字节;
b) partialBytes为部分位有效位的字节(是否应该为partialByte,因为要么1个字节,要么0个字节,不是复数);
c) padBytes:补到numBytes宽度所需要添加的字节数;
g. 为寄存器reg生成一个以字节为单位进行读写的逻辑:
10. HasRegMap
该特征为子类引入一个中断向量表,一个生成寄存器访问逻辑的方法:
Rocket - regmapper - RegField的更多相关文章
- Rocket - regmapper - RegMapper
https://mp.weixin.qq.com/s/aXxgzWwh6unuztjgyVX0iQ 简单介绍RegMapper的实现. 1. 简单介绍 RegMapper使用指定的输入接口,为一组寄存 ...
- Rocket - regmapper - RegisterCrossing
https://mp.weixin.qq.com/s/82iLT-fmDg9Comp2p9bxKg 简单介绍RegisterCrossing的实现. 1. BusyRegisterCrossing 简 ...
- 64位开源处理器Rocket该人士介绍
最近大概读一点UCB发布时间Rocket处理器的源代码,的每个文件的源代码的功能有一定的一般理解,Mark一点点. Rocket是一家64bit标量处理器,5第一阶段管道,用途risc-v指令集.综合 ...
- Slack 开源替代品 Rocket.Chat(聊天,文件上传等等)
Rocket.Chat 是特性最丰富的 Slack 开源替代品之一. 主要功能:群组聊天,直接通信,私聊群,桌面通知,媒体嵌入,链接预览,文件上传,语音/视频 聊天,截图等等. Rocket.Chat ...
- web.py 学习(-)Rocket web框架
Rocket是一个轻量级,多线程,符合WSGI规范的web框架. Rocket使用一个线程监听连接,接收到连接之后放到Queue中,有worker线程进行处理. Rocket含有以下属性: metho ...
- 参加完Rocket MQ Meetup深圳站,回顾和想法
最近一段时间才开始关注云栖社区的公众号,在两周前看到要在深圳科兴科学园办一场Rocket MQ的Meetup.因为从来没有参加过这种线下活动,而且对Rocket MQ比较感兴趣,所以就立即报名参加. ...
- gitlab勾住rocket chat
出于协作的要求, 需要在把gitlab的push event勾到rocket chat上面, 通知协作的其他人. BUT rocket chat提供的脚本没有具体的文件diff, so, 只好修改一下 ...
- Mac 下安装运行Rocket.chat
最近花了一周的时间,复习了HTML.CSS.原生JS,并学习了Node.js.CoffeeScript.js.MongoDB,入了下门. 因为准备在Rocket.chat 上做二次开发,所以先下载和安 ...
- Rocket.Chat 开源IM系统部署
Rocket.Chat 官方给出的文档也个人觉得太麻烦了,并且对ubuntu的支持程度远高于CentOS,自己就折腾写了个安装的笔记,如果是在公司内部或者是部门内部还是很有用处的,比较看中的功能有和g ...
随机推荐
- C. Yet Another Counting Problem(循环节规律)
\(给出a,b,l,r,求在区间[l,r]内有多少x满足x%a%b!=x%b%a\) \(--------------------分割!!~----------------------------\) ...
- Linux下3种常用的网络测速工具
大家好,我是良许. 不管你用的是什么操作系统,网速都是你非常关心的一个性能指标,毕竟,谁都不想看个视频结果网速卡到你怀疑人生.本文介绍三个 Linux 命令行下的网络测速工具,让你随时随地知道你的网络 ...
- Java return 关键字
一.基本概念 return一方面用在循环语句中来结束循环,另一方面用来终止函数的执行或者退出类的方法,并把控制权返回该方法的调用者.如果方法有返回类型,则return的返回该类型的值:如果没有返回值, ...
- # C#学习笔记(一)——准备工作
C#学习笔记(一)--准备工作 目录 C#学习笔记(一)--准备工作 1.1 下载安装.NET框架 1.2 创建源代码 1.3 一些基本名称 1.4 简单的命名建议 1.1 下载安装.NET框架 .N ...
- MySQL 主从复制原理及过程讲解
mysql主从原理描述,摘自老男孩. 下面简 单描述下 MySQL Replication 复制的原理及过程 . 1.在 Slave 服务器上执行 start slave 命令开启主从复制开关,主从复 ...
- [hdu5216]排序
题意:给定两个长度为M的数组a,b,对于一个1-M的排列,不妨设为P,如果对任意0<=i<M,都有a[i] <= b[P[i]],那么称为一种合法情况,对于一种合法情况,对所有0&l ...
- screen命令两种用法
screen命令用法举例 screen命令,故名思议于屏幕有关. 1. screen用于关闭shell应用不退出 思路:创建一个单独的shell窗口,在此窗口中启动应用,然后把这个shell放置于后台 ...
- c#得出两个列表的交集
c#提供了Intersect来得到两个列表的交集,它是通过使用默认的相等比较器对值进行比较生成两个序列的交集,定义为: public static IEnumerable<TSource> ...
- Python 的缩进是不是反人类的设计?
前些天,我写了<Python为什么使用缩进来划分代码块?>,文中详细梳理了 Python 采用缩进语法的 8 大原因.我极其喜欢这种简洁优雅的风格,所以对它赞美有加. 然而文章发出去后,非 ...
- python实现边缘提取
1. 题目描述 安装opencv环境,实现边缘提取 2. 实现过程 1. 安装opencv+python环境 2. 打开图片 3. 将图片二值化 4. 提取边缘 5. 显示图片 3. 运行结果 ...