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

verilog中对inout信号的处理

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-6-4 09:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x

verilog中对inout信号的处理

1、inout端口不能被赋值为reg型,因此,不能用于always语句中。

2、if等条件语句只能用于initial语句及always语句。

3、因此,对于inout端口的逻辑判断,要用到?:条件表达式,来控制高阻的赋值

4、需要有一个中转的寄存器,这样,在always语句中,才可以将输入的信号赋给输出(用inout代替纯output)

5、高阻态不要用于芯片内部,应该用逻辑引到引脚处,然后用高阻来实现。

举个例子  input  db2;

          output db1;

          inout  db;

          input  le;

          input clk;

          //le为控制信号,1时,将db的值赋给db1,0时,将db2的值赋值个db

          reg db_reg;

          assign db = (le)? 1'bz : db_reg;

          always @ (posedge clk)begin

          if(le)

          db1 <= db;

          else

          db_reg <=db2;

          end

          我也试了一下,下面这种组合逻辑在RTL视图中,也是可以实现的        

          assign db = (le)? 1'bz : db2;
7 O8 x# ~6 z5 M( o4 X9 r! B          assign db1 = (le)? db: db1;

         此外,当inout信号作为输入时,在测试代码的初始化赋值中,应该 force db=1,用这种赋值的方式,否则由于db相当于是wire型,正常的赋值会被报错的。(再用force赋值的时候,必须要用=)。

          在调用模块进行仿真时,输入信号要为reg 类型,输出信号要为wire


2 N  n  A3 U6 ], l2 G4 d
+ I  g0 O. k9 ?$ A- A

该用户从未签到

2#
发表于 2019-6-4 17:38 | 只看该作者
还没有涉及到这种问题,不过当做经验以后没准用到
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-8-4 09:18 , Processed in 0.109375 second(s), 23 queries , Gzip On.

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

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

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