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的更多相关文章

  1. Rocket - regmapper - RegMapper

    https://mp.weixin.qq.com/s/aXxgzWwh6unuztjgyVX0iQ 简单介绍RegMapper的实现. 1. 简单介绍 RegMapper使用指定的输入接口,为一组寄存 ...

  2. Rocket - regmapper - RegisterCrossing

    https://mp.weixin.qq.com/s/82iLT-fmDg9Comp2p9bxKg 简单介绍RegisterCrossing的实现. 1. BusyRegisterCrossing 简 ...

  3. 64位开源处理器Rocket该人士介绍

    最近大概读一点UCB发布时间Rocket处理器的源代码,的每个文件的源代码的功能有一定的一般理解,Mark一点点. Rocket是一家64bit标量处理器,5第一阶段管道,用途risc-v指令集.综合 ...

  4. Slack 开源替代品 Rocket.Chat(聊天,文件上传等等)

    Rocket.Chat 是特性最丰富的 Slack 开源替代品之一. 主要功能:群组聊天,直接通信,私聊群,桌面通知,媒体嵌入,链接预览,文件上传,语音/视频 聊天,截图等等. Rocket.Chat ...

  5. web.py 学习(-)Rocket web框架

    Rocket是一个轻量级,多线程,符合WSGI规范的web框架. Rocket使用一个线程监听连接,接收到连接之后放到Queue中,有worker线程进行处理. Rocket含有以下属性: metho ...

  6. 参加完Rocket MQ Meetup深圳站,回顾和想法

    最近一段时间才开始关注云栖社区的公众号,在两周前看到要在深圳科兴科学园办一场Rocket MQ的Meetup.因为从来没有参加过这种线下活动,而且对Rocket MQ比较感兴趣,所以就立即报名参加. ...

  7. gitlab勾住rocket chat

    出于协作的要求, 需要在把gitlab的push event勾到rocket chat上面, 通知协作的其他人. BUT rocket chat提供的脚本没有具体的文件diff, so, 只好修改一下 ...

  8. Mac 下安装运行Rocket.chat

    最近花了一周的时间,复习了HTML.CSS.原生JS,并学习了Node.js.CoffeeScript.js.MongoDB,入了下门. 因为准备在Rocket.chat 上做二次开发,所以先下载和安 ...

  9. Rocket.Chat 开源IM系统部署

    Rocket.Chat 官方给出的文档也个人觉得太麻烦了,并且对ubuntu的支持程度远高于CentOS,自己就折腾写了个安装的笔记,如果是在公司内部或者是部门内部还是很有用处的,比较看中的功能有和g ...

随机推荐

  1. Z - New Year Tree CodeForces - 620E 线段树 区间种类 bitset

    Z - New Year Tree CodeForces - 620E 这个题目还没有写,先想想思路,我觉得这个题目应该可以用bitset, 首先这个肯定是用dfs序把这个树转化成线段树,也就是二叉树 ...

  2. C. Ilya And The Tree 树形dp 暴力

    C. Ilya And The Tree 写法还是比较容易想到,但是这么暴力的写法不是那么的敢写. 就直接枚举了每一个点上面的点的所有的情况,对于这个点不放进去特判一下,然后排序去重提高效率. 注意d ...

  3. D - 小Z的加油店 线段树+差分+GCD

    D - 小Z的加油店 HYSBZ - 5028   这个题目是一个线段树+差分+GCD 推荐一个差分的博客:https://www.cnblogs.com/cjoierljl/p/8728110.ht ...

  4. LTE网络概述

    LTE主要由两部分组成:无线接入技术演进(E-UTRAN)+系统架构演进(SAE):其中,SAE主要含有的是演进型分组交换核心网(EPC),其控制处理部分为移动性管理实体(MME),数据承载部分称为业 ...

  5. 使用天祥TX-1C调试DS18B20温度传感器的收获

    翻查DS18B20的DataSheet编写操作函数,其过程遇到了不少坎,记下来备查. 对于单总线的DS18B20芯片,首先严格按照时序图写出正确的“写0”.“写1”和“读0.1”的基础函数,再以此写出 ...

  6. VA01信贷使用

    1业务场景 业务在正式机中发现,当使用VA01输入客户编号回车后会报错 2解决方法 1. SE24进入CL_IM_UKM_SD_FSCM_INTEGR1 2. 双击方法IF_EX_BADI_SD_CM ...

  7. vue实现音乐播放器实战笔记

    原文链接:https://blog.csdn.net/Forever201295/article/details/80266600 一.项目说明该播放器的是基于学习vue的实战练习,不用于其他途径.应 ...

  8. jQuery学习笔记——jQuery基础核心

    代码风格 在jQuery程序中,不管是页面元素的选择.内置的功能函数,都是美元符号“$”来起始的.而这个“$”就是jQuery当中最重要且独有的对象:jQuery对象,所以我们在页面元素选择或执行功能 ...

  9. js 延迟加载的几种方法

    1. defer 属性HTML 4.01 为 <script>标签定义了 defer属性. 用途:表明脚本在执行时不会影响页面的构造.也就是说,脚本会被延迟到整个页面都解析完毕之后再执行. ...

  10. 「雕爷学编程」Arduino动手做(32)——雨滴传感器模块

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...