什么时候要用开漏输出(open drain output)?

开漏输出(Open-Drain Output)是一种常见的数字电路输出模式,在微控制器(MCU)和数字系统中应用广泛。简单理解,它只能"主动"输出低电平,而无法"主动"输出高电平。输出高电平需要依赖外部电路的一个电阻"帮忙"拉上去。

那么什么时候需要用开漏输出呢?开漏输出有什么好处呢?

首先看一下开漏输出的工作原理:

可以把开漏输出结构想象成一个简单的开关。

  • 当内部控制逻辑希望输出低电平(0)时,它会闭合内部的N-MOSFET开关。这样输出引脚就直接通过开关连接到地(GND),从而被拉低到低电平。

  • 当内部控制逻辑希望输出高电平(1)时,它会断开内部的N-MOSFET开关。此时输出引脚与地之间的连接是断开的,相当于悬空状态(高阻态)。如果没有任何外部元件,这个引脚的电平是不确定的。因此,必须在外部的输出引脚和电源(VCC)之间连接一个上拉电阻。当内部开关断开时,电流会通过这个上拉电阻将引脚电压"拉"到电源电压,从而输出高电平

开漏输出的常见应用场景

  • 电平转换(Level Shifting):当系统中不同器件工作在不同电压时(如MCU为3.3V,外设为5V),开漏输出可以方便地实现电平转换。只需将开漏引脚的上拉电阻连接到目标设备的电源电压(如5V)即可。推挽输出通常不具备这种灵活性。

  • 多设备共享总线与"线与"逻辑("Wire-AND"):在I²C、SMBus等通信总线中,多个设备的数据线(SDA)和时钟线(SCL)通常直接并联。开漏输出允许任一设备主动将总线拉低,而只有当所有设备都释放总线(输出高阻态)时,总线才被上拉电阻拉高。这种"线与"特性是总线仲裁和多主设备通信的基础。推挽输出直接并联则可能因同时输出高低电平而导致短路。

  • 驱动较大电流负载:开漏输出结构通常吸收电流(sink current)的能力较强**。对于一些需要较大电流的负载,如LED、继电器或蜂鸣器,可以将负载连接在外部电源和开漏输出引脚之间,由开漏引脚控制地的通断来驱动。这种方式有时比直接用推挽输出驱动更灵活,尤其当负载工作电压与控制器电压不同时。

使用开漏输出的注意事项

开漏输出虽然有用,但也有些地方需要留意:

  • 上拉电阻的选择:上拉电阻的阻值需要仔细考量。阻值太小,当输出拉低时电流大,功耗也大;阻值太大,则给线路电容充电慢,会导致信号上升沿变缓,限制最高通信速度。通常需要在速度、功耗和抗干扰能力之间取得平衡。

  • 速度限制:由于输出高电平依赖外部上拉电阻对线路电容的充电,其上升速度通常比推挽输出慢,因而不太适合像SPI这样的高速通信接口。

  • 低电平功耗:输出低电平时,电流会通过上拉电阻到地形成通路,会有一定的静态功耗

如何选择输出模式

选择开漏输出还是推挽输出,主要取决于你的具体需求:

  • 需要电平转换、多设备"线与"(如I²C)、或驱动电压/电流不匹配的负载时,开漏输出更合适。

  • 需要高速信号(如SPI、UART)、强驱动能力或简单的数字输出控制(如直接驱动LED)时,推挽输出通常是更好的选择。

特性 开漏输出 (Open-Drain) 推挽输出 (Push-Pull)
输出能力 只能主动拉低 (到GND),高电平为高阻态(悬空),需外部上拉 既能主动输出高电平 (到VCC),也能主动输出低电平(到GND)
驱动能力 相对较弱(高电平驱动能力取决于外部上拉电阻) 驱动能力强
电平转换 容易(可通过改变上拉电阻的电源电压实现不同电平转换) 不方便
"线与"功能 支持(多个开漏输出可并联形成"与"逻辑) 不支持(直接并联可能因电平冲突导致短路)
典型应用 I²C、SMBus等总线;电平转换;需要"线与"的场合 GPIO驱动;高速信号(如SPI、UART);直接驱动负载
相关推荐
电子工程师-C513 小时前
基于51单片机的家居环境监测系统
单片机·嵌入式硬件·51单片机
Big_潘大师3 小时前
十轴IMU模块-AHRS角度姿态、加速度计、磁力计、气压陀螺仪传感器
stm32·单片机·嵌入式硬件·arduino·陀螺仪
ghomeway5 小时前
keil使用虚拟的调试串口给调试助手发送数据
单片机·嵌入式硬件
Jason_zhao_MR6 小时前
米尔RK3506核心板SDK重磅升级,解锁三核A7实时控制新架构
linux·嵌入式硬件·物联网·架构·嵌入式·嵌入式实时数据库
小痞同学6 小时前
stm32跑马灯实验
stm32·单片机·嵌入式硬件
宇宙realman_9997 小时前
Flash2833x_API的cmd文件解析
单片机
易水寒陈7 小时前
定时器计数溢出引发的bug
stm32·单片机
染予8 小时前
串口发送之中断方式
单片机·嵌入式硬件
TangDuoduo00058 小时前
【I2C协议】
stm32·单片机