STM32 GPIO 寄存器的配置
  nEVDqNIaatqV 22天前 41 0

32位配置寄存器:GPIOx_CRL,GPIOx_CRH
32位数据寄存器:GPIOx_IDR,GPIOx_ODR
32位置位/复位寄存器:GPIOx_BSRR
16位复位寄存器:GPIOx_BRR
32位锁定寄存器:GPIOx_LCKR

GPIO 寄存器详解

CRL

32位端口配置低寄存器(GPIOx_CRL) (x=A..E)

用于配置低8位的GPIO口,每个GPIO口占用4个比特位,用于设置引脚的模式、输入/输出类型、上下拉电阻等。

CNFy[1:0]:端口x配置位(y = 0…7)
在输入模式(MODE[1:0]=00):
00:模拟输入模式
01:浮空输入模式(复位后的状态)
10:上拉/下拉输入模式
11:保留
在输出模式(MODE[1:0]>00):
00:通用推挽输出模式
01:通用开漏输出模式
10:复用功能推挽输出模式
11:复用功能开漏输出模式
------------
MODEy[1:0]:端口x的模式位(y = 0…7)
00:输入模式(复位后的状态)
01:输出模式,最大速度10MHz
10:输出模式,最大速度2MHz
11:输出模式,最大速度50MHz

CRH

32位端口配置高寄存器(GPIOx_CRH) (x=A..E)

用于配置高8位的GPIO口,每个GPIO口占用4个比特位,与CRL寄存器类似,用于设置引脚的模式、输入/输出类型、上下拉电阻等。

CNFy[1:0]:端口x配置位(y = 8…15)
------------
MODEy[1:0]:端口x的模式位(y = 8…15)

IDR

32位端口输入数据寄存器(GPIOx_IDR) (x=A..E)

用于读取GPIO口的输入状态,每个GPIO口占用一个比特位,当该比特位为1时,表示对应的GPIO输入电平为高电平;否则为低电平。

位31:16 保留,始终读为0。

位15:0 IDRy[15:0]:端口输入数据(y = 0…15) (Port input data)
这些位为只读并只能以字(16位)的形式读出。读出的值为对应I/O口的状态。

ODR

32位端口输出数据寄存器(GPIOx_ODR) (x=A..E)

用于读取GPIO口的输入状态,每个GPIO口占用一个比特位,当该比特位为1时,表示对应的GPIO输入电平为高电平;否则为低电平。

位31:16 保留,始终读为0。

位15:0 ODRy[15:0]:端口输出数据(y = 0…15) (Port output data)
这些位可读可写并只能以字(16位)的形式操作。
注:对GPIOx_BSRR(x = A…E),可以分别地对各个ODR位进行独立的设置/清除。

BRR、BSRR是原子操作,不会被中断操作打断

BSRR

端口位设置/清除寄存器(GPIOx_BSRR) (x=A..E)

也用于控制GPIO口的输出状态,每个GPIO口占用两个比特位,第一个比特位为0时代表置位(设置为1),为1时代表复位(设置为0),第二个比特位用于选择GPIO口,当该比特位被置为1时,对应的GPIO口输出电平被控制。

位31:16
BRy: 清除端口x的位y (y = 0…15) (Port x Reset bit y)
这些位只能写入并只能以字(16位)的形式操作。
0:对对应的ODRy位不产生影响
1:清除对应的ODRy位为0
注:如果同时设置了BSy和BRy的对应位, BSy位起作用。
------------
位15:0
BSy: 设置端口x的位y (y = 0…15) (Port x Set bit y)
这些位只能写入并只能以字(16位)的形式操作。
0:对对应的ODRy位不产生影响
1:设置对应的ODRy位为1

BRR

端口位清除寄存器(GPIOx_BRR) (x=A..E)

也用于控制GPIO口的输出状态,每个GPIO口占用一个比特位,当该比特位被置为1时,对应的GPIO口输出电平被复位(设置为0)。

位31:16 保留。

位15:0 BRy: 清除端口x的位y (y = 0…15) (Port x Reset bit y)
这些位只能写入并只能以字(16位)的形式操作。
0:对对应的ODRy位不产生影响
1:清除对应的ODRy位为0

LCKR

端口配置锁定寄存器(GPIOx_LCKR) (x=A..E)

用于锁定GPIO口的配置,防止在运行过程中对其进行修改。LCKR寄存器有16个比特位,每个GPIO口占用一个比特位,当该比特位被置为1时,对应的GPIO口的配置被锁定。

当执行正确的写序列设置了位16(LCKK)时,该寄存器用来锁定端口位的配置。位[15:0]用于锁
定GPIO端口的配置。在规定的写入操作期间,不能改变LCKP[15:0]。当对相应的端口位执行了
LOCK序列后,在下次系统复位之前将不能再更改端口位的配置。
每个锁定位锁定控制寄存器(CRL, CRH)中相应的4个位。

位31:17 保留。

位16
LCKK:锁键 (Lock key)
该位可随时读出,它只可通过锁键写入序列修改。
0:端口配置锁键位激活
1:端口配置锁键位被激活,下次系统复位前GPIOx_LCKR寄存器被锁住。
锁键的写入序列:
写1 -> 写0 -> 写1 -> 读0 -> 读1
最后一个读可省略,但可以用来确认锁键已被激活。
注:在操作锁键的写入序列时,不能改变LCK[15:0]的值。
操作锁键写入序列中的任何错误将不能激活锁键。
------------
位15:0
LCKy: 端口x的锁位y (y = 0…15) (Port x Lock bit y)
这些位可读可写但只能在LCKK位为0时写入。
0:不锁定端口的配置
1:锁定端口的配置

寄存器代码实现

LED控制

以PC4为例,LED 的负极连接到 GND,而正极连接到 PC4

void LED_Init(void)
{
    RCC->APB2ENR|=1<<4;    //使能时钟 PORTC
    GPIOC->CRL&=0XFFF0FFFF;//PC4 配置位清零
    GPIOC->CRL|=0X00030000;//PC4 推挽输出
    GPIOC->ODR|=1<<4;      //PC4 输出高电平,熄灭。等价于 GPIOC->ODR |= 0X10;
}
int main()
{
    GPIOC->BSRR = 0x10;//设置对应的 ODRy 位为 1,给高电平->熄灭。等价于 GPIOC->BSRR = 0x10<<16;
    GPIOC->BRR = 0x10; //清除对应的 ODRy 位为 0,给低电平->点亮
}
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 22天前 0

暂无评论

推荐阅读
  NmW0c5Yhg87p   13小时前   6   0   0 嵌入式
nEVDqNIaatqV