3214|3

9

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

请教 @ 的用法 [复制链接]

我再夏宇闻老师书中 IIC一节时,描述SDA数据线上的数据存入寄存器,数据在SCL的高电平有效(就是高电平的时候SDA上要稳定,在SCL低电平的时候,SDA上的数据可以改变),大概代码如下:

output [7:0] shift;                    //  寄存器
  begin
      @ (posedge scl )    shift[7] = sda;
      @ (posedge scl )    shift[6] = sda;
      @ (posedge scl )    shift[5] = sda;
      @ (posedge scl )    shift[4] = sda;
      @ (posedge scl )    shift[3] = sda;
      @ (posedge scl )    shift[2] = sda;
      @ (posedge scl )    shift[1] = sda;
      @ (posedge scl )    shift[0] = sda;
       .......

    end

我想问下 单独的@出现时 和always @ 连用 会有什么差别?  

我知道在begin...end 里代码是顺序执行的,  这样理解有没有错:  单独使用 @ 时,比如第一个@,后面敏感列表中变化时,执行相应功能。然后敏感列表再次变化,但因为不是 always @, 所以第一个@ 就不在执行了? 顺序到第二个@ 执行?  谢谢各位啦~
此帖出自FPGA/CPLD论坛

最新回复

jiangde zhenhao  详情 回复 发表于 2011-8-12 14:14
点赞 关注
 

回复
举报

699

帖子

0

TA的资源

五彩晶圆(中级)

沙发
 

原帖由 forlsy 于 2011-8-12 11:27 发表 我再夏宇闻老师书中 IIC一节时,描述SDA数据线上的数据存入寄存器,数据在SCL的高电平有效(就是高电平的时候SDA上要稳定,在SCL低电平的时候,SDA上的数据可以改变),大概代码如下: output [7:0] shift; ...

 

单独用@(posedge clk) 表示一个延迟行为,即当时钟正跳变沿到来后执行以下语句,如果没有来就等着。该语句不能综合成电路,只表示电路的行为。

 

而符合标准的always块,如:

 

always @(posedge clk)

    begin

         if (rst)

          ..............

       else

          case

           ...........

           ............

         endcase

    end

 

则表示时序逻辑,如果编写符合可综合风格,是可以综合成具体电路的。所以不只是表示行为的语句,还可以转换成时序逻辑。

此帖出自FPGA/CPLD论坛
 
 

回复

7230

帖子

195

TA的资源

五彩晶圆(高级)

板凳
 

回复 沙发 夏宇闻 的帖子

jiangde zhenhao
此帖出自FPGA/CPLD论坛
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(中级)

4
 
明白了  谢谢夏老师啦
此帖出自FPGA/CPLD论坛
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
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
快速回复 返回顶部 返回列表