我的一个接口程序用到双向口,设为DD,在底层模块使用时用的是三个信号ddi、ddo和oe,在顶层时将这三个信号组合形成三态口:
DD<=ddo when (oe='1') else (others =>'Z');
ddi<=DD;
现在我要仿真顶层模块,一些状态的转换是需要这个双向口控制的,在testbench中应该如何来描述这个信号,才能让我既看到DD作为输出时的信号波形,又可以编辑DD作为输入时的波形以便做正确的状态转换?
共5条
1/1 1 跳转至页
2楼
3楼
叮叮当当那篇帖子感觉也没讲太清楚,您的那篇讲双向口的部分很少,也没看懂。我现在的理解是,是否应该把方向控制信号oe定义为输出,testbench中,DD的激励由oe的输出响应来产生。
先将双向口的描述用verlog再写下:
assign DD = oe? ddo : 16’bz;
assign ddi = DD;
testbench是否可以这样描述:
`timescale 1ns / 1ps
initial
begin
#100;
if (oe) // oe为1时是向双向口写数据,在底层时可编辑ddo波形,
//在顶层ddo为内部信号,此时直接给DD赋值
DD=16'd1;
#200;
if (oe)
DD=16'd5;
end
......
verlog刚学,请指教。我现在还在用vhdl,版主可用verlog指点,我基本能看懂,再自己翻译成VHDL,谢谢!
先将双向口的描述用verlog再写下:
assign DD = oe? ddo : 16’bz;
assign ddi = DD;
testbench是否可以这样描述:
`timescale 1ns / 1ps
initial
begin
#100;
if (oe) // oe为1时是向双向口写数据,在底层时可编辑ddo波形,
//在顶层ddo为内部信号,此时直接给DD赋值
DD=16'd1;
#200;
if (oe)
DD=16'd5;
end
......
verlog刚学,请指教。我现在还在用vhdl,版主可用verlog指点,我基本能看懂,再自己翻译成VHDL,谢谢!
5楼
一般情况下,如果你所要描述的器件是个总线从设备,那么oe应该是个输入,由Testbench产生oe。正如由CPU控制RAM的读写一样。
这正好和你的描述是相反的。
assign DD = oe? ddo : 16’bz;
assign ddi = DD;
testbench:
`timescale 1ns / 1ps
initial
begin
#100;
oe = 1;
#20;
testReg = DD;
#100;
oe = 0;
#10;
DD = 16'd1;
#200;
end
......
这正好和你的描述是相反的。
assign DD = oe? ddo : 16’bz;
assign ddi = DD;
testbench:
`timescale 1ns / 1ps
initial
begin
#100;
oe = 1;
#20;
testReg = DD;
#100;
oe = 0;
#10;
DD = 16'd1;
#200;
end
......
共5条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 【FreeRtos】FreeRtos + MPU模块的配置使用被打赏¥32元 | |
| 【分享开发笔记,赚取电动螺丝刀】墨水屏文本显示器被打赏¥25元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX读取磁力计iis2mdc被打赏¥19元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX读取LPS22HH气压、温度被打赏¥19元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX读取STTS751温度被打赏¥17元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX软件读取HTS221温湿度被打赏¥22元 | |
| M5PAPERESP32EINKDEVKIT评测|使用MicroPython开发M5Paper被打赏¥15元 | |
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
我要赚赏金
