STM32 GPIO 寄存器的配置

cnblogs 2024-08-28 17:45:00 阅读 93

配置 CRL CRH,数据 IDR ODR,置位/复位 BSRR,复位 BRR,锁定 LCKR。

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个比特位,用于设置引脚的模式、输入/输出类型、上下拉电阻等。

<code>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,给低电平->点亮

}



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。