3109|8

2644

帖子

6

TA的资源

五彩晶圆(初级)

楼主
 

学Verilog时候的错题合辑 [复制链接]

Verilog错题合辑(1)

1.Always语句错误

always@( posedge sclk or nss) ❌

always@( posedge sclk or posedge nss) ✔

 

 

在always 语句里不能既 用posedge 这种沿触发,又用nss 这种电平触发,修改nss为沿触发即可。

2. 寄存器变量的使用

always @(temp_reg) begin

    case (temp_reg[15:0]) //不能直接使用Temp_reg

        ON1:begin

            leds<=2'b01;

        end

        ON2:begin

            leds<=2'b10;

        end

        ON3:begin

            leds<=2'b11;

        end

        default:begin

            leds<=2'b11;

        end  

    endcase

end

 

在寄存器变量使用中,最好不要直接使用temp_reg,最好说清楚其头在哪里尾在哪里改为temp_reg[15:0]编译器就能清晰的知道你描述的是那一段,不然编译器可能没法正确的识别其头和尾。

3.寄存器触发的使用

寄存器数据更新最好都使用CLK去更新,这样可以避免产生中间状态导致毛刺,最好基于CLK 去更新

||||||||||||||||||||||||||||||||||||||||||||||||||||错误示范||||||||||||||||||||||||||||||||||||||||||||||||||||

always @(temp_reg) begin

    case (temp_reg[15:0])

        ON1:begin

            leds<=2'b01;

        end

        ON2:begin

            leds<=2'b10;

        end

        ON3:begin

            leds<=2'b11;

        end

        default:begin

            leds<=2'b11;

        end  

    endcase

end

 

#####################可能是正确的?#####################

always@( posedge clks or negedge rsts) begin

    if (!rsts) begin

        leds<=2'b00;

    end

    else begin

        case (temp_reg[15:0])

        ON1:begin

            leds<=2'b01;

        end

        ON2:begin

            leds<=2'b10;

        end

        ON3:begin

            leds<=2'b11;

        end

        default:begin

            leds<=2'b11;

        end  

    endcase

    end

end

 

其中使用了CLK和NRST做触发,实际点led灯效果似乎看不出差别,到时候在拿逻辑分析仪看看

4.一个module里面可以用多次同样触发信号

在module里面可以用多次相同的触发信号,但不要拿相同的变量去在多个always语句里面赋值

5.在Verilog里小数运算怎么办?

在Verilog 里面无论是reg型还是integer都不能运行小数计算,使用windows自带的计算器软件计算得出以下结果。

在verilog 中也是一样,假设我要将16位的数据等比例缩小到12位的数据我没法直接 用小(0x0100)除大(0xffff),再去*4095,但我们可以使用大除小

确定其比例关系,再去反向计算回去,就能得到一个正确的比例(有所偏差)

6.Verilog for语句的使用

 for (ClkState =0 ;ClkState<ClkstateCounter ;ClkState=ClkState+1 ) begin

 

在Verilog里面 for 的最后一个表达式,ClkState=ClkState+1

此帖出自FPGA/CPLD论坛

最新回复

  详情 回复 发表于 2022-12-1 17:38
点赞 关注
个人签名

希望做一些大家觉得好用的东西!

 

回复
举报

1万

帖子

2853

TA的资源

管理员

沙发
 

谢谢分享~~确实是容易忽略的点。

此帖出自FPGA/CPLD论坛
加EE小助手好友,
入技术交流群
EE服务号
精彩活动e手掌握
EE订阅号
热门资讯e网打尽
聚焦汽车电子软硬件开发
认真关注技术本身

点评

边学边订正  详情 回复 发表于 2022-11-17 09:53
个人签名玩板看这里:
https://bbs.eeworld.com.cn/elecplay.html
EEWorld测评频道众多好板等你来玩,还可以来频道许愿树许愿说说你想要玩的板子,我们都在努力为大家实现!
 
 

回复

2644

帖子

6

TA的资源

五彩晶圆(初级)

板凳
 
okhxyyo 发表于 2022-11-16 23:45 谢谢分享~~确实是容易忽略的点。

边学边订正

此帖出自FPGA/CPLD论坛
个人签名

希望做一些大家觉得好用的东西!

 
 
 

回复

2

帖子

0

TA的资源

一粒金砂(初级)

4
 
谢谢楼主分享,最近正在学习verilog,可以帮助少走很多弯路
此帖出自FPGA/CPLD论坛

点评

边学边订正,不断变好  详情 回复 发表于 2022-11-17 11:25
 
 
 

回复

2644

帖子

6

TA的资源

五彩晶圆(初级)

5
 
mm123321 发表于 2022-11-17 10:44 谢谢楼主分享,最近正在学习verilog,可以帮助少走很多弯路

边学边订正,不断变好

此帖出自FPGA/CPLD论坛
个人签名

希望做一些大家觉得好用的东西!

 
 
 

回复

7

帖子

0

TA的资源

一粒金砂(初级)

6
 

此帖出自FPGA/CPLD论坛

点评

感谢捧场,,  详情 回复 发表于 2022-12-1 18:00
 
 
 

回复

1

帖子

0

TA的资源

一粒金砂(初级)

7
 

此帖出自FPGA/CPLD论坛

点评

感谢捧场  详情 回复 发表于 2022-12-1 18:00
 
 
 

回复

2644

帖子

6

TA的资源

五彩晶圆(初级)

8
个人签名

希望做一些大家觉得好用的东西!

 
 
 

回复

2644

帖子

6

TA的资源

五彩晶圆(初级)

9
 

感谢捧场,,

此帖出自FPGA/CPLD论坛
个人签名

希望做一些大家觉得好用的东西!

 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表