verilog 双向IO实现

网上搜索了一番,示例挺多,但发现都写的是 input in; output out;

然后  assign io= (oe)?out:1'bz;
就有点想不明白了,当IO方向为输出时,应该输出out的值,那么针对这个IO模块,out应该是input才对。

而in应该是ouput的。

尝试写了段代码

module iopin
(
    iopin,
    in_data,
    out_data,
    oe
);

inout iopin;
output in_data;
input out_data;
input oe;

assign in_data = iopin;
assign iopin = (oe)?out_data:1'bz;

endmodule

编译后 RTL viewer显示如下,符合预期要求,有空再继续研究。

posted on 2014-09-01 00:27  aozima  阅读(3265)  评论(0编辑  收藏  举报

导航