OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7494|回复: 4

初学者求助 Verilog 的 if 语句

[复制链接]

6

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2015-3-12
在线时间
1 小时
发表于 2015-10-19 14:17:00 | 显示全部楼层 |阅读模式
5金钱
写了个最简单的分频程序:
[mw_shl_code=c,true]module fp_verilog( clk,rst_n, fm ); parameter devide=32'd99; input clk; //时钟信号 input rst_n; //复位 output fm; //输出 低亮高不亮 reg[31:0] cnt; always @(posedge clk or negedge rst_n) begin if(rst_n==0||cnt==0) cnt<=devide; else cnt<=cnt-32'd1; end assign fm=(cnt>=(devide/2))? 1'b0:1'b1; endmodule[/mw_shl_code]
显示if语句用法错误
改为:
[mw_shl_code=c,true]module fp_verilog( clk,rst_n, fm ); parameter devide=32'd99; input clk; //时钟信号 input rst_n; //复位 output fm; //输出 低亮高不亮 reg[31:0] cnt; always @(posedge clk or negedge rst_n) begin if(rst_n==0) cnt<=devide; else if(cnt==0) cnt<=devide; else cnt<=cnt-32'd1; end assign fm=(cnt>=(devide/2))? 1'b0:1'b1; endmodule[/mw_shl_code]
后,编译通过,请问这样使用逻辑表达式有什么问题,为何在if语句中条件表达式不能使用“或”?

最佳答案

查看完整内容[请看2#楼]

我发现不是 "或"的问题了,是always 后的第一个if 必须为敏感表中的变量,只要添加其他任何变量都会出错,我又发了一个帖子,你可以看看
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2015-3-12
在线时间
1 小时
 楼主| 发表于 2015-10-19 14:17:01 | 显示全部楼层
我发现不是 "或"的问题了,是always 后的第一个if 必须为敏感表中的变量,只要添加其他任何变量都会出错,我又发了一个帖子,你可以看看
回复

使用道具 举报

58

主题

6291

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11406
金钱
11406
注册时间
2014-4-1
在线时间
1282 小时
发表于 2015-10-19 21:55:52 | 显示全部楼层
把错的信息贴出来。

估计你误判信息了。
回复

使用道具 举报

6

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2015-3-12
在线时间
1 小时
 楼主| 发表于 2015-10-19 22:01:07 | 显示全部楼层
回复【2楼】xuande:
---------------------------------
错误信息是在always块中条件表达式中无法匹配操作数Error (10200): Verilog HDL Conditional Statement error at fp_verilog.v(17): cannot match operand(s) in the condition to the corresponding edges in the enclosing event control of the always construct
回复

使用道具 举报

6

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2015-3-12
在线时间
1 小时
 楼主| 发表于 2015-10-19 22:05:57 | 显示全部楼层
回复【2楼】xuande:
---------------------------------
我发现不是 "或"的问题了,是always 后的第一个if 必须为敏感表中的变量,只要添加其他任何变量都会出错,所以把第二段程序中的第二个条件判断与第一个调换也会出错,我又发了一个帖子,你可以看看
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 18:54

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表