verilog之inout

1、inout 类型的data信号

写操作有效时(rd_wr_l=0):data端口输入信号,此时data为高阻态,允许对其进行赋值。

读操作有效时(rd_wr_l=1):data端口输出信号,此时data赋值data_o,data_o即是输出的值。

当片选信号cs无效时(cs=1):data端口也应该置为高阻状态。

assign data = (!cs_l && rd_wr_l) ? data_o : 8'bz;

2、开漏结构的端口(i2c控制器的sda端口sda_pin和scl端口scl_pin)一种方式

assign scl_pin = scl ? 1'bz : 1'b0;

assign sda_pin = sda ? 1'bz : 1'b0;

由于scl_pin端口外接上拉电阻,所以当scl=1时,只需要令scl_pin输出高阻即可,当scl=0时,scl_pin拉低。

同理,对于sda端口,由于sda_pin端口外接上拉电阻,所以当sda=1时,只需要令sda_pin输出高阻即可,当sda=0时,sda_pin拉低。

3、开漏结构的端口(i2c控制器的sda端口和scl端口)第二种方式

assign sda = sda_link ? sda_r:1'bz;

利用sda_link信号控制sda作输出输入,sda_link=0时:sda是输入端口,(初始情况下sda设置为输入,检查是否sda是否被占用)。

sda_link=1时:sda是输出端口,输出的值为sda_r。

转载于:https://www.cnblogs.com/littleMa/p/5370978.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值