1、GPIO简介
GPIO是通用输入输出端口的简称,简单来说就是STM32可控制的引脚,STM32芯片的GPIO引脚与外部设备连接起来,从而实现与外部通讯、控制以及数据采集的功能。STM32芯片的GPIO被分成很多组,每组有16个引脚,如型号为STM32F4IGT6型号的芯片有GPIOA、GPIOB、GPIOC至GPIOI共9组GPIO,芯片一共176个引脚,其中GPIO就占了一大部分,所有的GPIO引脚都有基本的输入输出功能。
最基本的输出功能是由STM32控制引脚输出高、低电平,实现开关控制,如把GPIO引脚接入到LED灯,那就可以控制LED灯的亮灭, 引脚接入到继电器或三极管,那就可以通过继电器或三极管控制外部大功率电路的通断。
最基本的输入功能是检测外部输入电平,如把GPIO引脚连接到按键,通过电平高低区分按键是否被按下。
2、GPIO框图分析
下面我们将对上面的GPIO硬件结构框图,深入了解GPIO外设和他的各种应用模式。
2.1、保护二极管及上、下拉电阻
引脚的两保护个二级管可以防止引脚外部过高或过低的电压输入,当引脚电压高于VDD_FT时,上方的二极管导通, 当引脚电压低于VSS时,下方的二极管导通,防止不正常电压引入芯片导致芯片烧毁。尽管有这样的保护,并不意味着STM32的引脚能直接外接大功率驱动器件, 如直接驱动电机,强制驱动要么电机不转,要么导致芯片烧坏,必须要加大功率及隔离电路驱动。具体电压、电流范围可查阅《STM32F4xx规格书》。
上拉、下拉电阻,从它的结构我们可以看出,通过上、下拉对应的开关配置,我们可以控制引脚默认状态的电压,开启上拉的时候引脚电压为高电平, 开启下拉的时候引脚电压为低电平,这样可以消除引脚不定状态的影响。如引脚外部没有外接器件,或者外部的器件不干扰该引脚电压时,STM32的引脚都会有这个默认状态。
也可以设置“既不上拉也不下拉模式”,我们也把这种状态称为浮空模式,配置成这个模式时,直接用电压表测量其引脚电压为1点几伏, 这是个不确定值。所以一般来说我们都会选择给引脚设置“上拉模式”或“下拉模式”使它有默认状态。
STM32的内部上拉是“弱上拉”,即通过此上拉输出的电流是很弱的,如要求大电流还是需要外部上拉。
通过“上拉/下拉寄存器GPIOx_PUPDR”控制引脚的上、下拉以及浮空模式。
2.2、P-MOS管和N-MOS管 -- 2
GPIO引脚线路经过两个上、下拉电阻结构后,向上流向“输入模式”结构,向下流向“输出模式”结构。先看输出模式部分, 线路经过一个由P-MOS和N-MOS管组成的单元电路。这个结构使GPIO具有了“推挽输出”和“开漏输出”两种模式。
所谓的推挽输出模式,是根据这两个MOS管的工作方式来命名的。在该结构中输入高电平时,上方的P-MOS导通,下方的N-MOS关闭, 对外输出高电平;而在该结构中输入低电平时,N-MOS管导通,P-MOS关闭,对外输出低电平。当引脚高低电平切换时,两个管子轮流导通, 一个负责灌电流,一个负责拉电流,使其负载能力和开关速度都比普通的方式有很大的提高。推挽输出的低电平为0伏,高电平为3.3伏, 具体参考图 等效电路 ,它是推挽输出模式时的等效电路。
而在开漏输出模式时,上方的P-MOS管完全不工作。如果我们控制输出为0,低电平,则P-MOS管关闭,N-MOS管导通,使输出接地, 若控制输出为1 (它无法直接输出高电平)时,则P-MOS管和N-MOS管都关闭,所以引脚既不输出高电平,也不输出低电平,为高阻态。 为正常使用时必须接上拉电阻(可用STM32的内部上拉,但建议在STM32外部再接一个上拉电阻)。 它具有“线与”特性,也就是说,若有很多个开漏模式引脚连接到一起时, 只有当所有引脚都输出高阻态,才由上拉电阻提供高电平,此高电平的电压为外部上拉电阻所接的电源的电压。若其中一个引脚为低电平, 那线路就相当于短路接地,使得整条线路都为低电平,0伏。
推挽输出模式一般应用在输出电平为0和3.3伏而且需要高速切换开关状态的场合。在STM32的应用中,除了必须用开漏模式的场合,我们都习惯使用推挽输出模式。
开漏输出一般应用在I2C、SMBUS通讯等需要“线与”功能的总线电路中。除此之外,还用在电平不匹配的场合,如需要输出5伏的高电平, 就可以在外部接一个上拉电阻,上拉电源为5伏,并且把GPIO设置为开漏模式,当输出高阻态时,由上拉电阻和电源向外输出5伏的电平。
通过 “输出类型寄存器GPIOx_OTYPER”可以控制GPIO端口是推挽模式还是开漏模式。
2.3、输出数据寄存器
前面提到的双MOS管结构电路的输入信号,是由GPIO“输出数据寄存器GPIOx_ODR”提供的,因此我们通过修改输出数据寄存器的值就可以修改GPIO引脚的输出电平。 而“置位/复位寄存器GPIOx_BSRR”可以通过修改输出数据寄存器的值从而影响电路的输出。
2.4、复用功能输入/输出
有两个寄存器可用来从每个 I/O 可用的 16 个复用功能输入/输出中进行选择。借助这些寄存
器,可根据应用程序的要求将某个复用功能连接到其它某个引脚。
这意味着可使用 GPIOx_AFRL 和 GPIOx_AFRH 复用功能寄存器在每个 GPIO 上复用多个可
用的外设功能。这样一来,应用程序可为每个 I/O 选择任何一个可用功能。由于 AF 选择信
号由复用功能输入和复用功能输出共用,所以只需为每个 I/O 的复用功能输入/输出选择一个
通道即可。
注意:虽然由于复用功能的输入和输出共用一个引脚,导致我们无法手动控制是复用输出还是复用输入,但是实际上我们给通道配置好复用后,STM32会自动根据配置来设置为输出/输入。例如:
1、当配置为USART_RX时,就会变为复用输入
2、当配置为USART_TX时,就会变为复用输出
对于每个 I/O 而言,应用程序一次只能为其选择一个可用的外设功能。
2.5、输入数据寄存器
看GPIO结构框图的上半部分,它是GPIO引脚经过上、下拉电阻后引入的,它连接到施密特触发器,信号经过触发器后,模拟信号转化为0、1的数字信号, 然后存储在“输入数据寄存器GPIOx_IDR”中,通过读取该寄存器就可以了解GPIO引脚的电平状态。
2.6、模拟输入输出
当GPIO引脚用于ADC采集电压的输入通道时,用作“模拟输入”功能,此时信号是不经过施密特触发器的,因为经过施密特触发器后信号只有0、1两种状态, 所以ADC外设要采集到原始的模拟信号,信号源输入必须在施密特触发器之前。类似地,当GPIO引脚用于DAC作为模拟电压输出通道时,此时作为“模拟输出”功能, DAC的模拟信号输出就不经过双MOS管结构了,在GPIO结构框图的右下角处,模拟信号直接输出到引脚。同时,当GPIO用于模拟功能时(包括输入输出), 引脚的上、下拉电阻是不起作用的,这个时候即使在寄存器配置了上拉或下拉模式,也不会影响到模拟信号的输入输出。
3、GPIO模式配置
可以通过GPIOx_MODER寄存器
3.1、输入模式
对 I/O 端口进行编程作为输入时:
1、输出缓冲器被关闭
2、施密特触发器打开
3、根据 GPIOx_PUPDR 寄存器中的值决定是否打开上拉和下拉电阻
4、输入数据寄存器每隔 1 个 AHB1 时钟周期对 I/O 引脚上的数据进行一次采样
5、可以读取GPIOx_IDR输入寄存器获取I/O状态
3.2、输出模式
对 I/O 端口进行编程作为输出时:
1、输出缓冲器被打开
2、施密特触发器打开
3、根据 GPIOx_PUPDR 寄存器中的值决定是否打开上拉和下拉电阻
4、输入数据寄存器每隔 1 个 AHB1 时钟周期对 I/O 引脚上的数据进行一次采样
5、可以读取GPIOx_IDR输入寄存器获取I/O状态
6、读GPIOx_ODR输出寄存器可访问最后的写入值
3.3、复用输入/输出模式
对 I/O 端口进行编程作为复用功能时:
1、可将输出缓冲器配置为开楼或推挽。
2、输出缓冲器由来自外设的信号驱动(发送器使能和数据)。
3、施密特触发器输入被打开。
4、根据GPIOx_PUPDR寄存器中的值决定是否打开弱上拉电阻和下拉电阻。
5、输入数据寄存器每隔1AHB1时钟周期对I/O引脚上的数据进行一次采样。
6、读输入数据寄存器的可获取I/O状态。
3.4、模拟输入/输出模式
对I/O端口进行编程作为模拟配置时:
1、输出缓冲器被禁止。
2、施密特触发器输入停用,I/O引脚的每个模拟输入的功耗变为0。施密特触发器的输出被强制处理为恒定值0。
3、弱上拉和下拉电阻被关闭。
4、读输入数据寄存器的值永远为0。
注意:在模拟配置中,I/O引脚不能为5V容忍。
4、复用功能详解
复用是指一个I/O引脚可以被不同的外设控制。每个I/O引脚通过一个复用器连接到多个外设上,该复用器有16路输入(AF0-AF15),用户可通过GPIOx_AFRL(针对引脚0-7)和GPIOx_AFRH(针对引脚8-15)对复用器进行配置:
1、复位后,所有I/O引脚都会连接到系统的复用功能AF0。
2、外设复用功能映射到AF1-AF13。
3、Cortex™-M4F EVENTOUT 映射到 AF15。
每个引脚具体能支持什么外设,需要参考数据手册中“复用功能映射表”,示例如下:
我们以PA10为例,可以看到,系统复位后该引脚默认是普通IO,可以通过软件配置成TIM_CH3、USART1_RX等外设功能引脚。