一. GPIO (General Purpose I/O Port) 统称为通用输入/输出端口。0 F2 f+ v4 v2 G2 w4 C" @9 [3 s) ~6 ? 一个完整的GPIO组由16个引脚构成,每个GPIO引脚都可以通过软件配置为0 h$ q6 f: b# R4 `9 r, H- E; O 输出 ,输入,复用的外设功能 并且所有的I/O都可以配置为外部中断的输入端。5 r# @& \: {9 F% P0 g9 n$ w/ { 8 e. R! O1 W% l( k Z0 v GPIO——输出状态下,可以配置成带有上拉或下拉的推挽输出或开漏输出。 GPIO——输入状态下,可以配置成浮空,上拉,下拉,或模拟输入。/ e8 ]6 x" N6 ~2 x 系统复位后所有的GPIO端口被配置成浮空输入模式, 特殊的是由于调试的 PA13 (SWDAT)引脚置于上拉模式。1 l- f# q1 P' `; d PA14 (SWCLK)引脚置于下拉模式。 3 p. e* |3 T# D7 ]. X4 P* V 二. GPIO的基本结构 保护二极管,上下拉电阻 引脚的两个二极管可以防止引脚外部过高或过低的电压输入, 当引脚的电压输入高于VDD时,上方的二极管导通。6 e: n& s. |! B1 @ 当引脚的电压输入低于VSS时,下方的二极管导通。 1. 输入配置# H' {9 F: R' Y$ O' e GPIO端口配置为输入模式时,端口的输出缓冲区禁止,输入端连接的TTL施密特触发器激活,GPIOx_PUPDR寄存器可以配置成上拉、下拉电阻。 3 g6 T7 V7 \& ~, I3 S" c* A TTL施密特触发器: 当输入电压高于正向阈值电压,输出为高;当输入电压低于负向阈值电压,输出为低;当输入在正负向阈值电压之间,输出不改变。8 D* p7 o1 [0 G( g% i$ V& s6 k- g/ X 能将模拟信号波形整形为数字电路能够处理的方波波形。 在此处的作用就是将模拟信号转化为0,1的数字信号,然后储存在 输入数据寄存器中。 在每个AHB时钟周期,引脚上的数据都会被锁存至输入数据寄存器,CPU通过对输入数据寄存器的访问可以获取I/O口的实际状态。7 ]+ ^3 h2 t" q. Y ! C2 I5 S, P: o9 x( D 2.输出配置% L' O8 B# W3 t; F8 M GPIO端口配置为输出模式时,输出缓冲器开启。 如果GPIO工作在开漏模式,8 ]- C* B: {# a3 W" C u( t2 H 输出数据寄存器上的数字“0“将激活N-MOS,端口输出低电平, 输出数据寄存器上的数字“1“则不会激活P-MOS,也就是N-MOS 和 P-MOS 都处于关闭状态,端口处于高阻状态。9 K% I b" t/ X0 z 如果GPIO工作在推挽模式,输出数据寄存器上的数字“0“将激活N-MOS,端口输出低电平,输出数据寄存器上的数字“1“将激活P-MOS,端口处于高电平。 当引脚高低电平切换时,两个 MOS管轮流导通,P负责管电流,N负责拉电流,使其负载能力和开关速度比普通方式有了很大的提高。推挽输出的低电平为0v,高电平为3.3v。% W! u6 S; C' n2 ` 6 }, a3 z) y1 P0 V9 `' {3 c 同时,在GPIO配置为输出时,施密特触发器输入也会激活,弱上拉,弱下拉电阻是否激活取决于GPIOx_PUPDR寄存器的值。也就是此时对输入数据寄存器的读操作同样可以获取I/O口的真实状况。( L" s9 y( |0 ~ 8 R" d; Q/ P7 G 6 G: w+ P# s3 ]9 P. Q' C( ? w& d 3. 复用功能配置4 |* z+ Y% d' x' z 绝大多数GPIO端口与外设输入输出共同使用引脚。- U) ~5 y4 P# o 当端口被配置为复用功能时,来自外设的信号会驱动输出缓冲器,此时输出数据寄存器将无法驱动输出缓冲器,也就是说,端口的状态完全有外设信号来决定。 同时,施密特触发器输入也会激活,弱上拉,弱下拉电阻是否激活取决于GPIOx_PUPDR寄存器的值,此时对输入数据寄存器的读操作同样可以获取I/O口的真实状况。9 I0 [2 q# Q0 L% `; ] 7 [7 {8 E/ t$ M 4. 模拟配置5 s, S( ~, |" e& N, N+ ]) @ i 当端口被配置为模拟输入时,例如作为ADC模块的输入时,输出缓冲器关闭,施密特触发器关闭,上下拉电阻被禁止。此时输入的电流电压完全是外部的真实电流电压。4 [. ?! s" p8 x) c 9 R1 u, e% ~7 m+ B9 f2 V 三. GPIO的特殊功能 GPIO除了可以配置输入,输出和复用功能外,还具有一些较为特殊的功能,比如可以单独对某一位进行置位/复位操作, 端口锁定操作,或将端口的复用功能重映射到其他引脚上等。' Q0 o! m* }7 L 1. 位操作 GPIO端口通过置位/复位寄存器 GPIOx_BSRR,可以对端口输出数据寄存器的每个位进行置位和复位操作。5 E9 q9 [, C6 K& `8 n' a 置位/复位寄存器 GPIOx_BSRR是一个32位寄存器,而端口输出数据寄存器GPIOx_ODR是16位的,相对于GPIOx_ODR寄存器中的每一位,GPIOx_BSRR寄存器中有两位与之对应,即 BSx和BRx。8 M, \( S8 a2 p3 @7 ~0 O6 B# | 对BSx位写1时会将相应的ODRx位置位,对BRx位写1时会将相应的ODRx位复位,6 ~" o6 H' D1 W& Z- j, _, k 对GPIOx_BSRR的任意位写0时,都不影响GPIOx_ODR的值。 如果对GPIOx_BSRR寄存器的BSx和BRx同时写1,那么置位操作具有优先权。* K' }( E$ U: v) h! J( ]6 v0 m 2 J/ d/ \5 s% a: E: r6 J8 E% V 2.端口锁定$ G/ w* u8 Y; Y7 x# E2 l 端口配置锁定寄存器(GPIOx_LCKR)用于冻结端口的控制寄存器。8 q3 J" z+ F) t2 \. K 当一个特定的写/读序列作用于GPIOx_LCKR寄存器时,相应端口的控制寄存器将会冻结,直到复位才有效。 9 }/ i R9 N+ |: ]+ Y7 k, ?! d& O 3. 端口复用功能映射。- w% ^1 H' b! d; ^5 q" ^* G' u STM32F系列微控制器的大部分GPIO端口会与多个外设共用,选择每个端口的有效复用功能可以通过GPIOx_AFR寄存器来实现。通过对GPIOx_AFR寄存器的AFRLx[3:0] 为赋值,可以选择该端口所连接的外设,也可以根据需要将某一外设复用功能映射到其他引脚。 5 c, E; |; u1 S- T" g 四,GPIO寄存器分类。 1. I/O端口控制寄存器 每个GPIO端口都有4个32为控制寄存器,. ]3 v! p# b6 M& S$ D: e o' p GPIOx_MODER: 选择I/O模式,如输入,输出,复用或模拟等。+ }+ y/ k4 ^) v# ^) l GPIOx_OTYPER: 选择输出类型,如推挽,开漏等。# z3 R7 u/ v7 D4 e6 o" x% \. M8 R GPIOx_OSPEEDR: 设定I/O口的速度。8 u' [7 M1 C/ S& V GPIOx_PUPDR: 选择I/O口上拉,下拉方式。) u- K7 U9 X7 O8 w: D5 d, m 2. I/O端口数据寄存器 每个GPIO口有2个16位数据寄存器和一个32位置位/复位寄存器! I% h8 P3 G1 O# Y5 U+ ], G( p 输入数据寄存器 GPIOx_IDR : 存放I/O口锁存的输入数据,只读寄存器。! q2 N, J8 ^: k% L7 Y' w; F7 o 输出数据寄存器 GPIOx_ODR: 存储输出数据,配置输出I/O, 可读可写。 置位/复位寄存器 GPIOx_BSRR: 用于对端口的某一位进行单独的操作。 3. I/O端口锁定及复用功能寄存器, O% D5 Y( ~3 H! F4 l 32位端口配置锁存寄存器GPIOx_LCKR: 用于锁定I/O口配置,防止被微控制器在运行过程中更改。 2个32位复用功能寄存器GPIOx_AFRH, GPIOx_AFRL: 用于端口复用功能配置。 |