找回密码
 注册
关于网站域名变更的通知
查看: 241|回复: 4
打印 上一主题 下一主题

Verilog并行语句中变量赋值问题

[复制链接]
  • TA的每日心情
    开心
    2022-1-21 15:21
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2022-5-5 10:59 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

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

    x

    如上图,如果一个模块里面多个并行语句always1、2、3/ n' a5 L' [; R6 R
    a有初值09 A$ B1 T! v; Z& V
    第一个always需要a为1才执行红色语句;& ]( s* W: g& O- W4 ]9 D& A3 r
    而如果a只在第二个always中赋值为1;

    问题:

    1、这样的话always1红色部分的执行是不是在always1、always2并行执行的同时,还要等待always2赋值完成才能进一步执行?

    2、问题一中的情况就是Verilog与C这类语言的区别吗?

    3、如果一个Verilog中有多个这样的变量的话,代码看起来不是很乱?


    0 L! @; c5 T% `
  • TA的每日心情
    开心
    2022-1-21 15:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-5-5 13:19 | 只看该作者
    你列的1, 2, 3都是 @(posedge sys_clk) 同一个条件的,就是同时执行的。 里面用到 a 值的地方,就是用 a 的当前值。

    点评

    1、2、3是同时执行的, 如果要执行1中if里面的红色语句的话,是不是就得等到2中完成赋值操作才能执行1中的红色语句。 就是说1中的红色语句和2中的赋值语句就会有一个先后的问题  详情 回复 发表于 2022-5-5 14:09
  • TA的每日心情
    开心
    2022-1-29 15:05
  • 签到天数: 2 天

    [LV.1]初来乍到

    3#
    发表于 2022-5-5 13:37 | 只看该作者
    都不会执行,因为这些电路是并行的,一个时刻只能有一种状态,一个变量或是一组变量在某一时刻只能有一种状态。所以某一时刻只能有一个赋值起作用。
  • TA的每日心情
    开心
    2022-1-21 15:21
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
     楼主| 发表于 2022-5-5 14:09 | 只看该作者
    qian211111 发表于 2022-5-5 13:19
    4 r& k" T) k( s! H5 T9 z你列的1, 2, 3都是 @(posedge sys_clk) 同一个条件的,就是同时执行的。 里面用到 a 值的地方,就是用 a 的 ...
    8 O& a2 b/ W2 |8 I7 V9 B
    1、2、3是同时执行的, 如果要执行1中if里面的红色语句的话,是不是就得等到2中完成赋值操作才能执行1中的红色语句。 就是说1中的红色语句和2中的赋值语句就会有一个先后的问题
    ! J( ]3 c6 m$ g6 R

    该用户从未签到

    5#
    发表于 2022-5-5 14:10 | 只看该作者
    这样的话always1红色部分的执行是不是在always1、always2并行执行的同时,还要等待always2赋值完成才能进一步执行?
    " T* p, n" a1 V+ `, [A:1执行自己的,2执行自己的。
    ! v. q) r6 N& z6 s: z. K两个相互不干扰。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-5 13:07 , Processed in 0.156250 second(s), 30 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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