搜索
bottom↓
回复: 6

请问:在VHDL中定义两个inout双向IO的问题.

[复制链接]

出0入0汤圆

发表于 2010-8-21 15:38:38 | 显示全部楼层 |阅读模式
在VHDL中,定义两个双向IO口inout.平时这两个端口为高阻态.这两个端口外部有两个上拉电阻.当只要其中一个端口被拉低时,另外一个端口也要紧跟着拉低.直到被拉低的端口再次变为高电平时,另外一个端口再次变为高阻.这样的逻辑是否可以实现?

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2010-8-21 16:11:27 | 显示全部楼层
为什么要定义成双向? 一个输入一个输出不就完了。。。

出0入0汤圆

 楼主| 发表于 2010-8-21 16:15:33 | 显示全部楼层
因为两个端口必须同时支持输入和输出的.

出0入0汤圆

发表于 2010-8-21 23:52:13 | 显示全部楼层
高阻态是检测不到信号的。再加一个输入端口并到信号出现的端口控制才有可能。

出0入0汤圆

 楼主| 发表于 2010-8-22 20:21:23 | 显示全部楼层
回复【3楼】40130064
高阻态是检测不到信号的。再加一个输入端口并到信号出现的端口控制才有可能。
-----------------------------------------------------------------------

高阻太检测不到信号?那定义了inout的端口,输出高阻态.外部有上拉,回读不是'1'吗?

出0入0汤圆

发表于 2010-8-22 21:20:13 | 显示全部楼层
回读是'1'

高阻态是检测不到信号的,这没错。   

INOUT 是普通输出口+三态缓冲器+输入缓冲器。什么时候作输出,什么时候作输入是你自己决定的。

一个单独INOUT端口是没任何意义的。


在VHDL中……再次变为高电平时,另外一个端口再次变为高阻.……实现?

你INOUT输出低电平后,IO就是低电平,请问外部信号怎么还能拉高IO?你要检测信号,IO就一定是INPUT态。

为了再次检测IO 你就得输出Z态,转换到Z态,IO就是电平就是外部电平,但不是检测到外部信号高电平了。

出0入0汤圆

 楼主| 发表于 2010-8-22 21:36:51 | 显示全部楼层
回复【5楼】40130064
-----------------------------------------------------------------------

谢谢你的解答.

我的目的是 主机I2C总线的SDA --- 经过CPLD --- 从机的SDA.
当有一边端口为低时.另一个端口就输出低.输入的端口就一直当作输入,直到输入的端口为高时,就把输出的端口变为高阻态.两个端口什么时候做输出什么时候就输入就以这个条件判断.不知能否实现?
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 17:32

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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