STM32的CRL CRH ODR BRR BSRR寄存器(逐句解析)

2023-10-24 08:59

本文主要是介绍STM32的CRL CRH ODR BRR BSRR寄存器(逐句解析),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 一 端口配置寄存器(GPIOx_CRL GPIOx_CRH

这两个寄存器都是 GPIO 口配置寄存器, CRL 控制端口的低八位, CRH 控制端口的
高八位。寄存器的作用是控制 GPIO 口的工作模式和工作速度。
每组 GPIO 下有 16 IO 口,一个寄存器共 32 位,每 4 个位控制 1 IO如图
所以才需要两个寄存器完成。
比如 GPIOA_CRL 的复位值是 0x44444444 4 位为一个单位都是 0100,一共八个0100 ,以寄存器低四位说明一下。
首先位 1 0 00 即:设置  PA0 为输入模式,如图
3 2 01 即:设置为浮空输入模式,如图
所以假如 GPIOA_CRL 的值是 0x44444444 ,那么 PA0~PA7 都是设置为输入模式,而
且是浮空输入模式。也就是说每一个框内设置的都是00:输入模式   01:浮空输入模式
上面这 2 个配置寄存器就是用来配置 GPIO 的相关工作模式和工作速度,它们通过不同的
配置组合方法,就决定我们所说的 8 种工作模式。
00 :模拟输入模式
01 :浮空输入模式 ( 复位后的状态 )
10 :上拉 / 下拉输入模式
在输出模式 (MODE[1:0]>00)
00 :通用推挽输出模式
01 :通用开漏输出模式
10 :复用功能推挽输出模式
11 :复用功能开漏输出模式
当MODE选择00,CNF为选择10时,代表着上拉/下拉输入模式。到底是上拉还是下拉呢?此时需要PxODR(端口输出数据寄存器)来确定,0为下拉输入,1为上拉输入。

二 端口输出数据寄存器(GPIOx_ODR

该寄存器用于控制 GPIOx 的输出高电平或者低电平。
也就是说既能控制管脚为高电平,也能控制管脚为低电平。管脚对于位写1,GPIO 管脚为高电平,写 0 则为低电平。不过缺点是:会因中断而打断,关闭中断明显会延迟或丢失一事件的捕获,所以控制GPIO的状态最好还是用BSRR和BRR。

三 端口输入数据寄存器(GPIOx_IDR

IDR寄存器低16位,每个位控制该组GPIO口的一个IO口,对应的是该IO口的输入电平。在输入模式下,可以读取I/O端口的电平值;在输出模式下,也可以读取I/O端口的电平值(在开漏输出时,读取到的I/O端口的电平值,不一定就是输出的电平值)

四 端口置位/复位寄存器(GPIOx_BSRR

该寄存器也用于控制 GPIOx 的输出高电平或者低电平。
问:既然ODR 和 BSRR都用于控制GPIOx的输出高电平或低电平,为什么有了 ODR 寄存器,还要这个 BSRR 寄存器呢?
答:因为 BSRR 是只写权限,而 ODR 是可读可写权限。BSRR 寄存器 32 位有效。
对于低 16 位( 0- 15),往相应的位写 1(BSy=1) ,那么对应的 IO 口会输出高电平,往相应的位写 0(BSy=0) , 对 IO 口没有任何影响,
16 位( 16-31 ),对相应的位写 1(BRy=1) 会输出低电平,写 0(BRy=0) 没有任何影响, y=0~15 。 也就是说,对于 BSRR 寄存器,你写 0 的话,对 IO 口电平是没有任何影响的。
因此要设置某个IO 口电平,只需要相关位设置为 1 即可。而 ODR 寄存器,要设置某个 IO 口电平, 首先需要读出来 ODR 寄存器的值,然后对整个 ODR 寄存器重新赋值来达到设置某个或者某些 IO 口的目的,而 BSRR 寄存器直接设置即可,这在多任务实时操作系统中作用很大。 BSRR寄存器还有一个好处,就是 BSRR 寄存器改变引脚状态的时候,不会被中断打断,而 ODR 寄存器有被中断打断的风险。

五 端口位清除寄存器(GPIOx_BRR) 

该寄存器只能改变管脚状态为低电平。 往相应的位写 1(BRy=1) ,那么对应的 IO 口会输出低电平,往相应的位写 0(BSy=0) , 对 IO 口没有任何影响,

GPIOx为(0..15)中任意接口
有了GPIOx->BRR清除寄存器,并且与GPIOx->BSRR高16为功能相同
假如你想在一个操作中对GPIOE的位1置'1',位15置'0',则使用BSRR非常方便:
GPIOE->BSRR = 0x80000002;
低16位中的0002将位1置‘1’( 低 16 ,对相应的位写 1 ,那么对应的 IO 口会输出高电平)高16位中的8000将位15置清零( 16 ,对相应的位写 1,那么对应的 IO 口会输出低电平),一步就可以做到。
如果没有BSRR的高16位,则要分2次操作,结果造成位1和位15的变化不同步
GPIOE->BSRR = 0x02;
GPIOE->BRR = 0x8000;

这篇关于STM32的CRL CRH ODR BRR BSRR寄存器(逐句解析)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/274094

相关文章

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Spring MVC使用视图解析的问题解读

《SpringMVC使用视图解析的问题解读》:本文主要介绍SpringMVC使用视图解析的问题解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC使用视图解析1. 会使用视图解析的情况2. 不会使用视图解析的情况总结Spring MVC使用视图

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提

Java中的runnable 和 callable 区别解析

《Java中的runnable和callable区别解析》Runnable接口用于定义不需要返回结果的任务,而Callable接口可以返回结果并抛出异常,通常与Future结合使用,Runnab... 目录1. Runnable接口1.1 Runnable的定义1.2 Runnable的特点1.3 使用Ru