介绍解码单个信号逻辑的实现。 
 
1. 单个信号
 
每个指令对应了一组信号,每个信号对应了一个解码逻辑。
 
如BNE指令对应的信号如下:
 
各个信号的含义如下:
 
每个信号都是一个BitPat,位宽不定,并非只有一位:
 
事实上是每个信号的每一位对应了一个解码逻辑,每一次只解出一位。
 
2. generator
 
生成解码逻辑的代码(generator)定义于DecodeLogic对象中,如下(已做重构):
 
1) addr即是inst,也就是指令本身;
2) default为默认值;
3) 调用term方法把default转换为项(Term类的实例,如最小项或最大项): val dTerm = term(default)
4) 把映射表mapping解为一组keys和一组values:val (keys, values) = mapping.unzip
5) 分别求出keys和values的最大宽度:
6) 把keys和values转变成为Term:
 
7) 检查kTerms是否存在重叠的情况,即各个指令的编码是否存在重叠的情况:
 
执行示例如下:
 
intersects实现如下:
 
(value ^ x.value) &~ mask &~ x.mask 可以转换为更容易理解的形式:(value ^ x.value) & (~mask) & (~x.mask)
a. (~mask) & (~x.mask)意为:this和x共同的变量;
b. (value ^ x.value) & (~mask) & (~x.mask)意为:this和x共同的变量值都相同;
 
8) 逐个解出信号value的每一位:(0 until vMaxWidth).map(...),然后组合成为所对应的信号:Cat(...)
 
因为前者LSB在前,后者MSB在前,所以需要使用reverse逆序。
 
 
3. 解码单个位
 
先提一下项(Term)的mask中为1的位对应的变量为忽略(dont care)的变量,其对应的位在value中的值为0。mask中为0的位对应的变量为项(最大项、最小项)中包含的变量,其对应的位在value中的值可以为0或1。
 
如由四个变量(A/B/C/D)组成的项AB,则AB对应的mask位为0,CD对应的mask位为1。
 
生成解码单个位的逻辑的代码如下:
 
1) 取出最小项
 
 
k对应的为key,即指令编码;
t对应的为要解码的信号;
 
mint即minTerms,即信号的第i位为1的key的集合,也就是指令的集合。
 
 
2) 取出最大项
 
 
maxt即maxTerms,即信号的第i为为0的key的集合,也是指令的集合。
 
之所以称为maxTerms,是因为其对应的值为0,与minTerms对应的值1相反。根据反演律亦即德摩根定律,最小项取反即为最大项。
 
3) 取出无关项
 
 
mask为1的变量为无关项。
 
 
4) 根据默认值选择要参与解码的项
 
译码的结果有三种:
a. 0
b. 1
c. x/dc,不关心
 
默认值为其中一种,则只需要把 要解码的指令 到 另外两种解码结果的指令集合 中查找即可。
 
a. 默认值为不关心:((dTerm.mask >> i) & 1) != 0
 
使用minTerms和maxTerms进行查找:
 
SimplifyDC使用类似卡诺图化简的方法进行化简,返回Seq[Term]。logic中生成逐个比较并返回的逻辑。
 
b. 默认值为0:val dBit = (dTerm.value.toInt >> i) & 1
 
默认值dBit=0,使用minTerms和dc进行查找:
 
bit为查找结果,找到为1,找不到为0,即默认值。与译码结果一致。
 
c. 默认值为1:val dBit = (dTerm.value.toInt >> i) & 1
 
默认值dBit=1, 使用maxTerms和dc进行查找:
bit为查找结果,找到为1,找不到为0。与译码结果相反,需要取反。
 
4. logic
 
 
把addr与terms中的所有项逐个比对,返回比对结果。
 
 
5. term
 
 
term方法把BitPat,转换为Term。
 
a. Term的值即为BitPat的值;
b. Term的mask为BitPat的mask取反;
 
mask补码 = 2^n - mask = ~mask + 1
即:~mask = 2^n - mask - 1 = 2^n - (mask + 1)
 
 
 

Rocket - decode - 解码单个信号的更多相关文章

  1. Rocket - decode - Inst Decode

    https://mp.weixin.qq.com/s/WvepB3yAzjMbQalO3Z82pQ   介绍RocketChip Instruction解码逻辑的实现.   1. RISC-V   R ...

  2. Fidder详解-工具简介(保存会话、decode解码、Repaly、自定义会话框、隐藏会话、会话排序)

    前言 本文会对Fidder这款工具的一些重要功能,进行详细讲解,带大家进入Fidder的世界,本文会让你明白,Fidder不仅是一个抓包分析工具,也是一个请求发送工具,更加可以当作为Mock Serv ...

  3. javascript处理HTML的Encode(转码)和Decode(解码)总结

    HTML的Encode(转码)和解码(Decode)在平时的开发中也是经常要处理的,在这里总结了使用javascript处理HTML的Encode(转码)和解码(Decode)的常用方式 一.用浏览器 ...

  4. python 编码与解码 decode解码 encode 编码

    >>> '无'   #gbk字符'\xce\xde'>>> str1 = '\xce\xde'>>> str1.decode('gbk')  # ...

  5. 二、IRIG_B解码AC信号

    AC-----过零检测(MAX913ESA)---1khzB码信号(以0v为界大于0为高,小于0为低,的 方波信号) AC-----信号放大(TLE2022ID--mv到5v) ---系统电压转换(M ...

  6. python中------decode解码出现的0xca问题解决方法

    一.错误: 解决方法: #源代码 data = sk.recv(1024) print(str(data,'gbk')) #修改代码 data = sk.recv(1024) print(str(da ...

  7. Rocket - decode - 几个问题

    https://mp.weixin.qq.com/s/pMsK_E4mQrm3QXdnp7nDPQ   讨论指令解码部分遗留的几个问题.     1. 最小项与蕴含项之间的关系   参考链接: htt ...

  8. Rocket - decode - SimplifyDC

    https://mp.weixin.qq.com/s/4uWqBRrMVG6FlnBKmw8U-w   介绍SimplifyDC如何简化解码逻辑.     1. 使用   ​​   简化从mint和m ...

  9. Rocket - decode - Simplify

    https://mp.weixin.qq.com/s/YWXYNaRU-DbLOMxpzF2bpQ   介绍Simplify如何简化解码逻辑.     1. 使用   Simplify在DecodeL ...

随机推荐

  1. 微信小程序-swiper(轮播图)抖动问题

    ps:问题 组件swiper(轮播图)真机上不自动滚动 一直卡在那里抖动 以前遇到这个问题,官方一直没有正面回复.就搁置了,不过有大半年没写小程序了也没去关注,今天就去看了下官方文档,发觉更新了点好东 ...

  2. Unity2019.3缺少Cinemachine插件/AssetStore搜索不到

    Unity2019.1版本都还自带Cinemachine,到2019.3就没有了(原因暂时未知),PackageManager里没有,到资源商店里搜索也找不到 解决方法: Windows>Pac ...

  3. Linux开机自启动脚本的总结

    一.在/etc/rc.local中添加 如果不想将脚本粘来粘去,或创建链接什么的, 则: step1. 先修改好脚本,使其所有模块都能在任意目录启动时正常执行; step2. 再在/etc/rc.lo ...

  4. [codeforces 200 A Cinema]暴力,优化

    题意大致是这样的:有一个有n行.每行m个格子的矩形,每次往指定格子里填石子,如果指定格子里已经填过了,则找到与其曼哈顿距离最小的格子,然后填进去,有多个的时候依次按x.y从小到大排序然后取最小的.输出 ...

  5. [hdu5213]容斥原理+莫队算法

    题意:给一个序列a,以及K,有Q个询问,每个询问四个数,L,R,U,V, 求L<=i<=R,U<=j<=V,a[i]+a[j]=K的(i, j)对数(题目保证了L <= ...

  6. opengl简单入门实例

    实现任务目标: 使用纹理贴图,增强可视效果 应用坐标变换,实现场景中不同物体重建 采用双缓冲技术,实现场景实时绘制 具有一定的鼠标.键盘交互功能 先放效果 鼠标的交互功能有:右键暂停转动,左键继续转动 ...

  7. 前端组件:支持多选,支持选项筛选的下拉框选择器(基于Jquery和Bootstrap)

    效果图一:多选 效果图二:选项筛选 最后奉献源码,复制出来直接可用 <!DOCTYPE html> <html> <head> <meta charset=& ...

  8. case when的使用-解决分表查数据给某一个字段

    一个表中存的是目前有效的菜单,另外一个表中存的是有效菜单的历史更改数据 需要查询历史数据的时候,带上访问的历史数据菜单名称 SELECT msg.msg_id, msg.from_user_name, ...

  9. SQLServer用with temptb AS临时表查询或者更新字段,将某个字段赋值成某个字段的值

    with temptb AS(SELECT sl.CompanyID,info.BID FROM dbo.TableXXXXX   slLEFT JOIN dbo.Tableinfo  infoON ...

  10. 手把手教系列之IIR滤波器设计

    [导读]:在嵌入式系统中经常需要采集模拟信号,采集模拟信号的信号链中难免引入干扰,那么如何滤除干扰呢?今天就来个一步一步描述如何设计部署一个IIR滤波器到你的系统. 何为IIR滤波器? 无限冲激响应( ...