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

verilog 里面 在always 下有两个 if 语句 就出现如下错误 高手请进

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
always @ (posedge CLK,negedge RST)
+ _  }2 b# g, k, m6 g8 S9 Hbegin3 {0 m5 E! H2 h1 h
if(EN) // 提示在这里出现错误 Error: Can't elaborate top-level user hierarchy
8 [: p% o: C. M! _4 p, G7 ]if(!RST); Q5 b5 t9 U3 b# ^. J
U <= 0;% _6 `$ J, L# v+ l; _9 ]! ?5 X
else
1 k4 G/ e7 k, }6 g3 J& S+ Bif(CTRL)! x4 d: U( D/ i' h# k* c7 B
begin" {+ F% {/ y; c& k; r" N' `$ w
U <= U + 1;0 P7 V9 _# w# X$ |2 b
if(U == 15) c_b <= 1;7 @2 ^- |5 R9 F4 a" g2 P
else c_b <= 0;  v5 q' ~$ g. F9 C
end& |: G+ l- T- U8 I; l& ~$ ?* N
else
, E' e, G# ]; ^# m  nbegin
9 M7 V5 f* {5 \" C$ I4 _' n, \3 IU <= U - 1;# L5 \9 b5 o& X" j: a
if(U == 0) c_b <= 1;' L5 G: t& V) d7 Y. q
else c_b <= 0;
7 J+ O+ e  `; V0 `end6 J0 R6 ]9 A* y8 N$ f
end
: H/ w$ ]- B, v) _! o对于 数学的爱好者 和 wangxuede220 所说的,很抱歉,我都试过了,不管用啊!
) ~. D4 V) q: L2 w7 kmicroshuke 能再具体详细解释一下吗?多谢了,为什么有这样情况出现,如果我想在EN在低电平时,其他按键就失效,应该怎么做?
" I2 v* {' y6 U6 k& ?
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-11-24 13:11 | 只看该作者
    verilog对边沿触发的逻辑有规定:9 I* B. D7 Q2 Q6 }% v0 ]: y
    你写了negedge rst,就必须在always内的第一个if中写~rst的逻辑。就是你把if(en)写在rst下面就好了。
    " m+ R' m# L4 T这样综合时推断的是一个异步复位的寄存器。
    8 p- l- S5 U  O- d; e-------------------------------
    . u9 \1 |$ i" a) H9 _为什么语法要这么规定我也不知道。@()里面的第一项是时钟定义,第二项和第三项(如果有的话)是异步复位和异步置位,必须写在第一个if, else if里面(如果有第三项的话)。

    该用户从未签到

    3#
    发表于 2022-11-24 13:17 | 只看该作者
    这个en应该是同步的,而你的rst信号是异步的,这样写不行。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-7-22 00:54 , Processed in 0.109375 second(s), 23 queries , Gzip On.

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

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

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