一、gpio简介
gpio是通用输入输出端口的简称,简单来说就是stm32可控制的引脚,stm32芯片的gpio引脚与外部设备连接起来,从而实现与外部通讯、控制以及数据采集的功能。stm32芯片的gpio被分成很多组,每组有16个引脚,所有的gpio引脚都有基本的输入输出功能。
最基本的输出功能是由stm32控制引脚输出高、低电平,实现开关控制,如把gpio引脚接入led灯,那就可以控制led灯的亮灭,引脚接入到继电器或三极管,那就可以通过继电器或三极管控制外部大功率电路的通断。
最基本的输入功能是检测外部电平,如把gpio引脚连接到按键,通过电平高低区分按键是否被按下。
二、gpio框图剖析
通过gpio硬件结构框图,就可以从整体上深入了解gpio外设及它的各种应用模式,该图从最右端看起,最右端就是代表stm32芯片引出的gpio引脚,其它部件都位于芯片内部。
1、保护二极管及上、下拉电阻
引脚的两个保护二极管可以防止引脚外部过高或过低的电压输入,当引脚电压高于时,上方的二极管导通,当引脚电压低于vss时,下方的二极管导通,防止不正常电压引入芯片导致芯片烧毁。
上下拉电阻,从它的结构我们可以看出,通过上、下拉电阻的开关配置,我们可以控制引脚默认状态的电压,开启上拉的时候引脚电压为高电平,开启下拉的时候引脚电压为低电平。也可以设置“既不上拉也不下拉模式”,我们也把这种状态称为浮空模式,配置成这个模式时,直接用电压表测量其引脚电压为1点几伏,这是个不确定的值。所以一般来说我们都会选择给引脚设置“上拉模式”或“下拉模式”使它有默认状态。stm32的内部上拉时“弱上拉”,即通过上拉输出的电流时很弱的,如要求大电流还是需要外部上拉,通过“上拉/下拉寄存器gpiox_pupdr”控制引脚的上、下拉及浮空模式。
2、p-mos管和n-mos管
gpio引脚线路经过两个保护二极管后,向上流向“输入模式”结构,向下流向“输出模式”结构。先看输出模式部分,线路经过一个由p-mos和n-mos管组成的单元电路,这个结构使gpio具有了“推挽输出”和“开漏输出”两种模式。
所谓的推挽输出模式,是根据这两个mos管的工作方式来命名的。在该结构中输入高电平时,经过反向后,上方的p-mos导通,下方的n-mos关闭,对外输出高电平;而在该结构中输入低电平时,经过反向后,n-mos导通,p-mos关闭,对外输出低电平,当引脚高低电平切换时,两个管子轮流导通,p管负责灌电流,n管负责拉电流,使其负载能力和开关速度都比普通的方式由很大的提高。推挽输出的低电平为0伏,高电平为3.3v,如下图,它是推挽输出模式时的等效电路。
而在开漏输出模式时,上方的p-mos完全不工作。如果我们控制输出为0,低电平,则p-mos管完全关闭,n-mos管导通,使输出接地,若控制输出为1(它无法直接输出高电平)时,则p-mos和n-mos都关闭,所以引脚既不输出高电平也不输出低电平,为高阻态。为了正常使用时必须外部接上拉电阻,参考下图中的等效电路。它具有“线与”特性,也就是说,若有很多个开漏模式引脚连接到一起时,只有当所有引脚都输出高阻态,才由上拉电阻提供高电平,此电平的电压为外部上拉电阻所接的电源的电压。若其中一个引脚为低电平,那线路就相当于短路接地,使得整条线路都为低电平,0伏。
推挽输出模式一般应用在输出电平0和3.3伏而且需要高速切换开关状态的场合。在stm32的应用中,除了必须用开漏模式的场合,我们都习惯使用推挽输出模式。开漏输出一般应用在i2c、smbus通讯等需要“线与”功能的总线电路中。除此之外,还用在电平不匹配的场合,如需要输出5伏的高电平,就可以在外部接一个上拉电阻,上拉电源为5伏,并且把gpio设置为开漏模式,当输出高阻态时,由上拉电阻和电源向外输出5伏电平,如下图所示。
3、输出数据寄存器
前面提到的双mos管结构电路的输入信号,是由gpio“输出数据寄存器“gpiox_odr”提供的,因此我们通过修改输出数据寄存器的值就可以修改gpio引脚的输出电平。
而”置位/复位寄存器gpiox_bsrr“可以通过修改输出数据寄存器的值从而影响电路的输出。
4、复用功能输出
“复用功能输出”中的“复用”是指stm32的其他片上外设对gpio引脚进行控制,此时gpio引脚用作该外设的一部分,算第二用途。从其他外设引出来的“复用功能输出信号”与gpio本身的数据寄存器都连接到双mos管结构中,通过途中梯形结构作为开关切换选择。
例如我们使用usart串口通讯时,需要用到某个gpio引脚作为通讯发送引脚,这个时候就可以把该gpio引脚配置成usart串口复用功能,由串口外设控制该引脚,发送数据。
5、输入数据寄存器
看gpio结构框图的上半部分,它时gpio引脚经过上、下拉电阻后引入的,它连接到施密特触发器,信号经过触发器后,模拟信号转化为0、1的数字信号,然后存储再“输出数据寄存器gpiox_idr”中,通过读取该寄存器就可以了解gpio引脚的电平状态。
6、复用功能输入
与“复用功能输出”模式类似,在“复用功能输出模式”时,gpio引脚的信号传输到stm32其他片上外设,由该外设读取引脚状态。
同样,如我们使用usart串口通讯时,需要用到某个gpio引脚作为通讯接收引脚,这个时候就可以把该gpio引脚配置成usart串口复用功能,使usart可以通过该通讯引脚接收远端数据。
7、模拟输入输出
当gpio引脚用于adc采集电压的输入通道时,用作“模拟输入功能”,此时信号时不经过施密特触发器的,因为经过施密特触发器后信号只有0、1两种状态,所以adc外设要采集到原始的模拟信号,信号源输入必须在施密特触发器之前。类似的,当gpio引脚用于dac作为模拟电压输出通道时,此时作为“模拟输出”功能,dac的模拟信号输出就不经过双mos管结构了,在啊gpio结构框图的右下角处,模拟信号直接输出到引脚。同时,当gpio用于模拟功能时(包括输入输出),引脚的上、下拉电阻是不起作用的。这个时候即使在寄存器配置了上拉或下拉模式,也不会影响到模拟信号的输入输出。
三、gpio工作模式总结
1、输入模式(上拉/下拉/浮空)
在输入模式时,施密特触发器打开,输出被禁止。数据寄存器每隔1个ahb1时钟周期更新一次,可通过数据寄存器gpiox_idr读取i/o状态。其中ahb1的时钟如按默认配置一般为180mhz。
2、输出模式·(推挽/开漏,上拉/下拉)
在输出模式中,输出使能,推完模式时以双mos管的方式工作,输出数据寄存器gpiox_odr可控制i/o输出高低点评。开漏模式时,只有n-mos工作,输出数据寄存器可控制i/o输出高阻态或低电平。输出速度可配置,有2mhz25mhz50mhz100mhz的选项。此处的输出速度即i/o支持的高低电平状态最高切换频率,支持的频率越高,功耗越大,如果功耗要求不严格,把速度设置成最大即可。
此时施密特触发器时打开的,即输入可用,通过输入数据寄存器gpiox_idr可读取i/o的实际状态。
用于输出模式时,可使用上拉、下拉或悬空模式。但此时由于输出模式时引脚电平会收到odr寄存器的影响,而odr寄存器对应引脚的位为0,即引脚初始化后默认输出低电平,所以在这种情况下,上拉只能起到小幅提高输出电流能力,但不会影响引脚的默认状态。
3、复用功能(推挽/开漏,上拉/下拉)
复用功能模式中,输出使能,输出速度可配置,可工作在开漏及推挽模式,但是输出信号源于其它外设,输出数据寄存器gpiox_odr无效;输入可用,通过输入数据寄存器可获取i/o实际状态,但一般直接用外设的寄存器来获取该数据信号。
用于复用功能时,可使用上拉、下拉或者浮空模式。同输出模式,在这种情况下,初始化后引脚默认输出低电平,上拉只起到小幅提高输出电流能力,但不会影响引脚的默认状态。
4、模拟输入输出
模拟输入输出模式中,双mos管结构被关闭,施密特触发器停用,上/下拉也被禁止,其他外设通过模拟通道进行输入输出。
通过gpio寄存器写入不同的参数,就可以改变gpio的用用模式。再gpio外设中,通过设置“模式寄存器gpiox_moder”可配置gpio的输出/输出/复用/模拟模式,“输出类型寄存器gpiox_otyper”配置推挽/开漏模式,配置“输出速度寄存器gpiox_ospeedr”可选2/25/50/100mhz输出速度,“上/下拉寄存器gpiox_pupdr”可配置上拉/下拉/浮空模式,各寄存器的具体参数见下表。
PCB多层印制板层压工艺技术解析
物联网技术成为企业纷纷选择的工作手段
机器学习如今大获成功的原因有哪些?如何才能取得进一步的突破?
海信洗衣机高效除菌不伤衣 助力打赢疫情战斗
“电-氢”综合能源系统的发展分析
STM32-GPIO详解
Graphcore采用新思科技基于Verdi调试的VCS仿真解决方案
比特币与闪电网络的本质区别解释
高通骁龙865可独立于系统升级GPU驱动,更加及时与方便
百林通信将亮相2011北京国际通信展
大联大旗下品佳推出基于英飞凌和立锜科技的USB PD电源转换解决方案
高精度农业土壤养分检测仪的产品特点介绍
PLC的选型方法及硬件配置
新基建会如何引领智慧交通的发展方向
真实的案例,带你走进工业4.0时代
2014 MWC 爱立信携五大主题诠释ICT
三星8英寸平板电脑发布 小米MIX4搭载可升降加全面屏
如何使用Rust创建一个基于ChatGPT的RAG助手
中芯国际3.97亿美元紧急采购!美国拿下2019年全球55%半导体市场占有率
羽迹人工智能极速3D人脸建模 让美在指尖跃动