技术专栏
芯片设计之CDC异步电路(三)
芯片设计之CDC异步电路(二)
芯片设计之CDC异步电路(一)
上面两篇简单总结了异步电路设计,下面接着介绍Gray码转换。格雷码的特点就是任意两个相邻码只有一比特不同。
我们接下来介绍二进制码、格雷码的转换原理、不同代码实现风格比较。
(一)二进制码 -> 格雷码
二进制码的最高位作为格雷码的最高位;二进制码的高位、次高位相异或得到次高位格雷码;格雷码其余位依此类推;直接上图,简单明了:
编码风格1://code style 1:
<pre class="code-snippet__js" data-lang="powershell">```
<span class="code-snippet_outer">integer i;</span>
always @(*)begin
<span class="code-snippet_outer"> gray[PTR-<span class="code-snippet__number">1</span>]=bin[PTR-<span class="code-snippet__number">1</span>];</span>
for(i=0; i
<span class="code-snippet_outer"> gray[i]=bin[i]^bin[i+<span class="code-snippet__number">1</span>];</span>
end
编码风格2://code style 2:
<pre class="code-snippet__js" data-lang="nginx">```
<span class="code-snippet_outer"><span class="code-snippet__attribute">assign</span> gray = (bin >> <span class="code-snippet__number">1</span>)<span class="code-snippet__regexp"> ^</span> bin;</span>
两种RTL编码对比:***代码推崇:大道至简!***编码风格1:
![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561187026.jpg)
编码风格2:
![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561167403.jpg)
*资源对比:其实一样,都5个异或门;*
*时序对比:关键路径是多长?有意思的是,可以和下文格雷码转二进制码的关键路径PK下。*
******(二)**格雷码** -> 二进制**码****
格雷码最高位作为二进制码的最高位,二进制码的高位与格雷码次高位相异或,得到次高位的二进制码,其余位依此类推;直接上图,简单明了:![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561162115.jpg)
编码风格1://code style 1:
-
-
-
-
-
-
``` integer i; `````` always @(*)begin `````` bin[PTR-1]= gray[PTR-1]; `````` for(i=PTR-2; i>=0; i=i-1) `````` bin[i]=bin[i+1]^gray[i]; `````` end ``` ``` 编码风格2://code style 2:- - - - - - `````` generate `````` genvar i0; `````` for(i0=0; i0PTR; i0=i0+1) `````` assign bin[i0] = bin[i0+1] ^ gray[i0]; `````` endgenerate ``````
``` ``` 代码我们尝试用generate来实现,效果和***编码风格1***本质是相同的,都是复制硬件电路; 细品一下,就会发现我们省略了下面一行:- `````` bin[PTR-1]= gray[PTR-1]; ``` ``` 那么当***编码风格2***的i0=PTR-1时,不存bin\[PTR\],代码如何编译呢?综合电路告诉了我们答案: ![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561269551.jpg) 两种RTL编码对比:***代码推崇:大道至简!不过,值得细品的东西来了。***编码风格1: ![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561245963.jpg) 编码风格2:![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561272033.jpg) *资源对比:风格1有5个异或门,风格2有6个异或门;* *时序对比:***细品!两种电路critical path都是谁?几级combo path?**** 所以,代码精简的写法,资源不一定少,时序也不一定好。 只有心中有电路,RTL才最优,这就需要经验的积攒和反复打磨了。 感谢阅读文章,如果文章有用,麻烦点个“在看”或转发分享。 ![](https://ebaina.oss-cn-hangzhou.aliyuncs.com/wechat-official-crawl/2022-01/164203561255862.jpg) 转载:全栈芯片工程师
声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
红包
点赞
收藏
评论
打赏
- 分享
- 举报
评论
0个
手气红包
暂无数据
相关专栏
-
浏览量:3792次2022-02-20 09:00:18
-
浏览量:2945次2022-01-23 09:00:19
-
浏览量:2792次2022-01-12 09:00:12
-
浏览量:8573次2021-01-09 02:07:52
-
浏览量:4567次2022-08-17 09:01:18
-
浏览量:6924次2022-04-01 09:00:15
-
浏览量:10704次2021-01-17 00:16:33
-
浏览量:6249次2021-12-21 09:00:28
-
浏览量:12272次2021-01-02 00:02:19
-
浏览量:6888次2021-01-23 18:45:14
-
浏览量:3104次2020-08-24 21:19:41
-
浏览量:2513次2022-05-30 11:53:09
-
浏览量:3005次2020-11-27 10:06:38
-
浏览量:9090次2021-02-20 17:50:13
-
浏览量:41098次2020-12-12 19:46:11
-
浏览量:2625次2019-11-11 14:10:15
-
浏览量:6286次2022-03-26 09:00:12
-
浏览量:8911次2021-08-09 15:05:08
-
浏览量:7269次2022-01-11 09:00:13
置顶时间设置
结束时间
删除原因
-
广告/SPAM
-
恶意灌水
-
违规内容
-
文不对题
-
重复发帖
打赏作者
david
您的支持将鼓励我继续创作!
打赏金额:
¥1
¥5
¥10
¥50
¥100
支付方式:
微信支付
打赏成功!
感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
审核成功
发布时间设置
发布时间:
请选择发布时间设置
是否关联周任务-专栏模块
审核失败
失败原因
请选择失败原因
备注
请输入备注