Verilog HDL如何在测试文件tb中给inout类型的变量赋值并设置时延

Verilog HDL如何在测试文件tb中给inout类型的变量赋值并设置时延

首先要明白的一点,双向端口inout类型只能是线网型wire数据,那么就只能用连续赋值语句assign进行赋值。就是一个端口同时做输入和 输出。 inout 在具体实现上一般用三态门来实现。三态门的第三个状态就是高阻’Z’。当 inout 端口不输出时,将三态门置高阻。

在我测试文件中data为inout类型的数据,我希望从data输入的数据保持一段时间再变化,共有4个不同数据。但是当我用一般的时延语句进行赋值的时候,仿真波形并不是预想的结果。错误示范如下:
wr为写信号,低电平有效。
在这里插入图片描述
在这里插入图片描述
可以看到后三位的数据由于发生了变化所以是未知的,用x表示。

修改之后
在这里插入图片描述
modulesim仿真波形如下:

在这里插入图片描述

    • 4
      点赞
    • 8
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值