在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2415|回复: 8

[求助] 请问下面一段简单的verilog代码什么意义

[复制链接]
发表于 2016-6-7 18:20:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 yyz1988 于 2016-6-7 20:40 编辑

下面一段代码为以太网通信的MAC程序中的一段,Add_wr是一个写地址,可以看出第一段代码得到Add_wr_gray是Add_wr的格雷码。请问第三段代码中的
Add_wr_ungray有什么意义呢,非常感谢!      





// 将写地址转换为格雷码      
always @ (posedge Reset or posedge Clk_SYS)
    if (Reset)
        Add_wr_gray         <=0;
    else begin
Add_wr_gray[8]<=Add_wr[8];
for (i=7;i>=0;i=i-1)
Add_wr_gray <=Add_wr[i+1]^Add_wr;
end




always @ (posedge Clk_MAC or posedge Reset)
    if (Reset)
        Add_wr_gray_dl1     <=0;
    else
        Add_wr_gray_dl1     <=Add_wr_gray;





always @ (posedge Clk_MAC or posedge Reset)
    if (Reset)
        Add_wr_ungray       =0;
    else  begin
Add_wr_ungray[8]=Add_wr_gray_dl1[8];
for (i=7;i>=0;i=i-1)
Add_wr_ungray=Add_wr_ungray[i+1]^Add_wr_gray_dl1;
end
发表于 2016-6-7 18:56:25 | 显示全部楼层
不懂逻辑也可以猜出来啦,格雷码转换回二进制码!
另外第二段代码设计不严谨,格雷码向clk_mac时钟域传递的时候,应该抓两拍,这是异步信号处理的基本要求。
发表于 2016-6-8 09:05:40 | 显示全部楼层
对头,转回二进制后才能和读指针(也是二进制)比较大小。
你想直接拿格雷码和读指针比?
 楼主| 发表于 2016-6-8 11:43:27 | 显示全部楼层
回复 3# iyama

我通过仿真验证了一下,的确是把格雷码转换为二进制码,转换后的得到的写地址的二进制码的确是用来与读地址进行比较的,当读地址与写地址想等时就说明FIFO空了,但是为什么要先把写地址转化为格雷码,然后再转换回来才与读地址进行比较呢,为什么不能直接用转换前的数据进行比较呢?
发表于 2016-6-8 12:11:25 | 显示全部楼层




   格雷码不好直接比大小。。。和二进制不一样。
发表于 2016-6-8 13:53:28 | 显示全部楼层
回复 4# yyz1988


这就涉及到异步时钟域之间多比特地址传递的问题了。 转成格雷码目的就是,地址的每一次递增只会有1比特发生变化,这样传递到另一个时钟域能被正确采样然后转回来。
发表于 2016-6-8 15:30:02 | 显示全部楼层


回复  yyz1988


这就涉及到异步时钟域之间多比特地址传递的问题了。 转成格雷码目的就是,地址的每一 ...
iyama 发表于 2016-6-8 13:53




   正解
发表于 2016-6-10 12:57:58 | 显示全部楼层
格雷码不是加权码,不能比较大小,因此必须转换为2进制编码
发表于 2016-6-14 16:28:58 | 显示全部楼层
对,顶
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

×

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-5-2 20:27 , Processed in 0.029409 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表