GPIO常见名词——推挽、开漏、浮空、上拉、下拉、高阻态

🙌秋名山码民的主页
😂oi退役选手,Java、大数据、单片机、IoT均有所涉猎,热爱技术,技术无罪
🎉欢迎关注🔎点赞👍收藏⭐️留言📝
获取源码,添加WX


1、前言

最近有不少初入嵌入式的小伙伴问我,推挽输出,开漏输出是什么,啥是浮空输入,上拉和下拉输入又该怎么区分,啥时候需要用?鉴于此前也没有写过这方面的博客,今天抽空来进行补充一下。

2、输出输入GPIO

GPIO是指通用输入输出(General Purpose Input/Output),是一种通用的数字输入输出接口,可以通过程序控制来读取或控制外部设备。

在单片机或嵌入式系统中,GPIO通常由一个或多个引脚组成,可以通过编程来配置引脚的工作模式(输入或输出)、电平状态(高电平或低电平)等参数,即,

  1. 数字芯片的IO口,一般分为输入和输出
  2. 数字芯片内部单元大都是CMOS,一般mos的栅极为输入,漏极为输出

2.1 基本类型

输出:

  1. 开漏输出(OP)
  2. 推挽输出(PP)
  3. 复用开漏
  4. 复用推挽

输入:

  1. 浮空输入
  2. 下拉输入
  3. 上拉输入

3. 输出

3.1 推挽输出

推挽输出是指输出端口通过一个晶体管的开关来控制电平状态,推挽输出可以实现高电平和低电平两种状态

输出高电平时,NPN型晶体管导通,PNP型晶体管截止,呈现向外推的形式,为
在这里插入图片描述
输出低电平时,PNP型晶体管导通,NPN型晶体管截止,呈现向回挽的形式,为

在这里插入图片描述
优点:

  1. 输出高低电平、电源电压基本没有压差
  2. 高低电平驱动能力较强,一般数字芯片推挽,输出IO口驱动电流最大可到20ma
  3. 电平切换速度快

缺点:
不支持线与(指俩个输出不可以接到一起)

3.2 开漏输出

输出端口通过一个晶体管的开关来控制电平状态,但与推挽输出不同,开漏输出只能实现低电平状态,而不能直接输出高电平

开漏输出的原理是,在输出端口接入一个NPN型晶体管,它的集电极连接到输出端口,发射极接地。当需要输出低电平时,晶体管导通,输出端口接地,形成低电平;当需要输出高电平时,晶体管截止,输出端口处于悬空状态,即高阻态。为了实现完整的输出功能,开漏输出通常需要结合外部上拉电阻。当输出端口处于高阻态时,外部上拉电阻将输出端口拉高至所需的高电平。因此,开漏输出可以通过控制晶体管的导通和截止来实现低电平输出,而高电平输出则由外部上拉电阻提供。开漏输出常用于多路设备共享总线的情况下,如I2C、SPI等通信协议中。通过多个开漏输出端口的组合,可以实现多路设备对总线的控制,同时避免输出冲突和电平干扰。

在这里插入图片描述
优点:

  1. 可实现电平转换,输出电平取决于上拉电阻电源
  2. 可以实现IO的线与

缺点:

  1. 高电平的驱动能力差,取决于外部上拉电阻
  2. 电平切换速率取决于外部上拉电阻

3.3 高阻态

关于开漏输出的高阻态,他通常用在总线上,当主设备与其中一个从设备相连的时候,阻断其他设备与主设备相连,即呈现出高阻态的形式。
在这里插入图片描述

4. 输入

4.1 上拉输入

是指芯片输入引脚通过电阻接到电源电压
在这里插入图片描述

4.2 下拉输入

指芯片输入引脚通过电阻借到参考0电平
在这里插入图片描述

4.3 浮空输入

浮空输入是指将输入引脚未连接到任何外部信号源或电路,使其处于未定义的状态。在这种情况下,输入引脚既不连接到高电平(VDD)也不连接到低电平(GND),而是处于开路状态。

浮空输入可能会导致输入信号漂移或产生不确定的结果。这是因为未连接的输入引脚可以受到周围环境中的电磁干扰,从而引起电压波动,进而影响输入状态。在某些情况下,浮空输入可能会被误认为是高电平或低电平,这取决于具体的电路设计和输入引脚的特性。

5. 野火的STM32 GPIO电路设计

在这里插入图片描述
我们主要看一下他这个推挽、开漏输出的设计,N-MOS晶体管导通,P-MOS晶体管截止,呈现向外推的形式,为,P-MOS管截止,N-MOS导通,为挽。
当为开漏状态时,只需要N-MOS管,当需要输出低电平时,晶体管导通,输出端口接地,形成低电平;当需要输出高电平时,晶体管截止,输出端口处于悬空状态,即高阻态。

最后

如果本文对你有所帮助,还请三连支持一下博主!
请添加图片描述

  • 21
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
GPIO(通用输入输出)是一种通用的数字接口,可以用于连接外部设备和处理器。在GPIO中,浮空、模拟、上拉下拉推挽开漏常见的概念。下面我来逐个介绍它们的含义: 1. 浮空(Floating):当一个GPIO引脚处于浮空状态时,它没有连接到任何电源或地,因此其电压状态是不确定的。这种状态常用于输入引脚,可以通过外部电路将其拉高或拉低。 2. 模拟(Analog):模拟GPIO引脚可以接收和发送连续范围内的电压信号,用于处理模拟信号,如声音、光线等。模拟引脚通常需要额外的模数转换器(ADC)和数模转换器(DAC)来实现与数字系统的交互。 3. 上拉(Pull-up):上拉是一种使输入引脚保持高电平(逻辑1)的电路配置。当没有外部信号输入时,上拉电阻将引脚拉高到高电平。 4. 下拉(Pull-down):下拉是一种使输入引脚保持低电平(逻辑0)的电路配置。当没有外部信号输入时,下拉电阻将引脚拉低到低电平。 5. 推挽(Push-pull):推挽输出是一种输出模式,引脚可以提供高电平和低电平的输出。在高电平时,驱动器提供电压源,使引脚保持高电平;在低电平时,驱动器提供接地路径,使引脚保持低电平。 6. 开漏(Open-drain):开漏输出是一种输出模式,引脚可以提供低电平输出,但无法提供高电平输出。在开漏模式下,引脚通过一个开漏晶体管与地连接,当引脚输出低电平时,晶体管导通,引脚被拉低;当引脚输出高电平时,晶体管截断,引脚处于浮空状态。为了实现高电平输出,通常需要外部上拉电阻。 这些概念在GPIO的配置和使用中起着重要的作用,可以根据具体需求选择适合的模式和配置方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋名山码民

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值