OpenEdv-开源电子网

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

为什么SDRAM程序中的always块没有begin end语句?

[复制链接]

4

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
103
金钱
103
注册时间
2018-1-22
在线时间
18 小时
发表于 2019-4-25 10:35:51 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 LoveDaivena 于 2019-4-25 10:37 编辑

在看咱们原子的SDRAM操作程序比如这部分代码中always块为什么没有加上begin end语句呢?
//刷新计数器循环计数7812ns (60ms内完成全部8192行刷新操作)
always @ (posedge clk or negedge rst_n)
        if(!rst_n)
        cnt_refresh <= 11'd0;
        else if(cnt_refresh < 11'd781)      // 64ms/8192 =7812ns
        cnt_refresh <= cnt_refresh + 1'b1;       
        else
        cnt_refresh <= 11'd0;       

//SDRAM 刷新请求
always @ (posedge clk or negedge rst_n)
        if(!rst_n)
        sdram_ref_req <= 1'b0;
        else if(cnt_refresh == 11'd780)
        sdram_ref_req <= 1'b1;                //刷新计数器计时达7812ns时产生刷新请求
        else if(sdram_ref_ack)
        sdram_ref_req <= 1'b0;                    //收到刷新请求响应信号后取消刷新请求

//延时计数器对时钟计数
always @ (posedge clk or negedge rst_n)
        if(!rst_n)
        cnt_clk <= 10'd0;
        else if(!cnt_rst_n)                 //在cnt_rst_n为低电平时延时计数器清零
        cnt_clk <= 10'd0;
        else
        cnt_clk <= cnt_clk + 1'b1;

//初始化过程中对自动刷新操作计数
always @ (posedge clk or negedge rst_n)
        if(!rst_n)
        init_ar_cnt <= 4'd0;
        else if(init_state == `I_NOP)
        init_ar_cnt <= 4'd0;
        else if(init_state == `I_AR)
        init_ar_cnt <= init_ar_cnt + 1'b1;
    else
        init_ar_cnt <= init_ar_cnt;

最佳答案

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

这些always块后面跟的是一个if……else if 语句,可以视为一条语句,所以不用加。如果是多条语句,就必须要加了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

202

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
839
金钱
839
注册时间
2018-7-29
在线时间
128 小时
发表于 2019-4-25 10:35:52 | 显示全部楼层
这些always块后面跟的是一个if……else if 语句,可以视为一条语句,所以不用加。如果是多条语句,就必须要加了
回复

使用道具 举报

18

主题

87

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2012-6-20
在线时间
100 小时
发表于 2019-4-25 11:07:33 | 显示全部楼层
·······
回复

使用道具 举报

3

主题

1979

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5520
金钱
5520
注册时间
2018-10-21
在线时间
1561 小时
发表于 2019-4-25 17:24:21 | 显示全部楼层
if后面只跟一行语句的话,可加可不加;超过一行必须加。
回复

使用道具 举报

18

主题

87

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2012-6-20
在线时间
100 小时
发表于 2019-4-26 11:13:34 | 显示全部楼层
always @ (*)
begin
........
end
试了下,不加编译不报错
回复

使用道具 举报

17

主题

587

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4461
金钱
4461
注册时间
2013-6-27
在线时间
564 小时
发表于 2019-4-29 17:01:32 | 显示全部楼层
跟C语言一样,一句的语句 可用加{}也可不加{}
2句以上就必须使用{}
让我们的思维驾驭在电的速度之上!
回复

使用道具 举报

18

主题

87

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
374
金钱
374
注册时间
2012-6-20
在线时间
100 小时
发表于 2019-4-30 08:50:37 | 显示全部楼层
楼上不对,这样也可可不加
always@(posedge clk )
if (!rst_n)  begin       
xdata <= 20'h0;
ydata <= 20'h0;
zdata <= 20'h0;
msyncT = 1'd0 ;
end
else if( sendCount == 5'd0)begin               
msyncT = 1'd0 ;               
xdata <= {3'b001,xPos,^{3'b001,xPos}};//^a操作就是将a中的每一位按位逐一进行异或
ydata <= {3'b001,yPos,^{3'b001,yPos}};
zdata <= {3'b001,zPos,^{3'b001,zPos}};
mxT =  xyChange?ydata[sendCount] : xdata[sendCount];
myT =  xyChange?xdata[sendCount] : ydata[sendCount];
mzT =  zdata[sendCount];
end
else
begin       
msyncT = 1'd1 ;          
mxT =  xyChange?ydata[sendCount] : xdata[sendCount];
myT =  xyChange?xdata[sendCount] : ydata[sendCount];
mzT =  zdata[sendCount];  
end
assign mclkT  = (!rst_n) ? 1'b0 : clk;
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-10-3 05:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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