gpio上拉下拉区别
GPIO是一颗芯片(MCU)必须具备的最基本外设功能。
GPIO通常有三种状态:高电平、低电平和高阻态。高阻态换句话说就是断开状态或浮空态。因此上拉和下拉其中一个强大的理由就是为了防止输入端悬空,使其有确定的状态。减弱外部电流对芯片的产生的干扰。
上拉就是将不确定的信号通过一个电阻提升为高电平,这个上拉的电阻的选择通常有讲究,通常是驱动能力和功耗的平衡,若GPIO为输出为高电平,一般来说,上拉电阻越小,驱动能力越强,但功耗也就越大,同时还要考虑下级电路对驱动能力的要求,上拉电阻选择的合适才能向下级电路提供足够的电流。另外就是数字电路对高低电平都有一个门槛,以上拉电阻为例,输出高电平自然是被拉高,但输出低电平的时候,通常内部的开关管会被导通到地,这必须确保内部导通到地这一段之间的电阻和上拉电阻的比值足够让其电平处在零电平门槛之下。对频率比较高的时候,上拉电阻和开关管漏源级之间的电容和下级电路之间的输入电容会形成“RC延迟”,电阻越大,延迟越大。下拉电阻的选择原理和上拉电阻是一样的。
还有另外两个概念:拉电流和灌电流。这两个名词本是为更形象的表述却意外的让人更加迷惑。要弄清楚这两个概念首先必须以芯片本身为出发点,所谓的拉和灌都是相对芯片本身而言。
拉是芯片主动输出电流,从输出端口输出电流 ,拉电流就是GPIO输出高电平给负载提供的输出电流。
灌是芯片被输入电流,从输出端口灌入,灌电流是输出低电平时外部数字电路输入的电流。
另外还有一个吸收电流的概念,吸收电流时主动吸入电流,是从输入端口流入,即GPIO被设置为输入状态。 所以拉电流和灌电流通常都是指相对输出而言。