MCU_STM32的位带操作 — bit banding[通俗易懂]

MCU_STM32的位带操作 — bit banding[通俗易懂]位带操作STM32芯片除了通用的寄存器访问,还有一个比较有意思的位带操作。这个位带的意思,就是每个比特(bit)位膨胀成一个32位的字(word),当访问这些字的时候就达到了访问“位”的目的,这就是位带操作!位带操作一个典型的特点,就是把1个位映射到32位,在程序处理中方便操作具体位,典型的如RCC寄存器,需要逐位操作的地方比较多,直接寄存器操作的话,程序的可读性不强;位带操作的缺…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

位带操作

STM32芯片除了通用的寄存器访问,还有一个比较有意思的位带操作。

这个位带的意思,就是每个比特(bit)位膨胀成一个32位的字(word),当访问这些字的时候就达到了访问“位”的目的,这就是位带操作!

位带操作一个典型的特点,就是把1个位映射到32位,在程序处理中方便操作具体位,典型的如RCC寄存器,需要逐位操作的地方比较多,直接寄存器操作的话,程序的可读性不强;

位带操作的缺点也很明显,就是在时间上开销也要稍大一些,因为不可避免要对位带映射进行计算。

Cortex-M4的手册中有这样一个例子:

参考地址:http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0337h/Behcjiic.html

 

MCU_STM32的位带操作 -- bit banding[通俗易懂]

原文的映射解释是这样的,

The alias word at 0x23FFFFE0 maps to bit [0] of the bit-band byte at 0x200FFFFF: 0x23FFFFE0 = 0x22000000 + (0xFFFFF*32) + 0*4.

The alias word at 0x23FFFFFC maps to bit [7] of the bit-band byte at 0x200FFFFF: 0x23FFFFFC = 0x22000000 + (0xFFFFF*32) + 7*4.

The alias word at 0x22000000 maps to bit [0] of the bit-band byte at : 0x22000000 = 0x22000000 + (0*32) + 0*4.

The alias word at 0x2200001C maps to bit [7] of the bit-band byte at 0x20000000: 0x2200001C = 0x22000000 + (0*32) + 7*4.

解释一下,即:

0x200FFFFF的bit[0] 位带字节映射计算: = 0x22000000 + (0xFFFFF*32) + 0*4 = 0x23FFFFE0
0x200FFFFF的bit[7] 位带字节映射计算: = 0x22000000 + (0xFFFFF*32) + 7*4 = 0x23FFFFFC
0x20000000的bit[0] 位带字节映射计算: = 0x22000000 + (0x0*32) + 0*4 = 0x22000000
0x20000000的bit[7] 位带字节映射计算: = 0x22000000 + (0x0*32) + 7*4 = 0x2200001C

关于程序

我找了个常用的具体的例子,比如这个函数,在STM32F407中是对RCC_CR中的第19位CSSON进行操作,程序如下,一目了然,

void HAL_RCC_EnableCSS(void) { *(__IO uint32_t *) RCC_CR_CSSON_BB = (uint32_t)ENABLE; }

理解:

首先有关RCC_CR_CSSON_BB的定义是这样的,

#define PERIPH_BB_BASE 0x42000000UL
#define AHB1PERIPH_BASE (PERIPH_BASE + 0x00020000UL)
#define RCC_BASE (AHB1PERIPH_BASE + 0x3800UL)
#define RCC_OFFSET (RCC_BASE – PERIPH_BASE) //计算结果也就是 = 0x00020000UL + 0x3800UL
#define RCC_CR_OFFSET (RCC_OFFSET + 0x00U)
#define RCC_CSSON_BIT_NUMBER 0x13U
#define RCC_CR_CSSON_BB (PERIPH_BB_BASE+(RCC_CR_OFFSET * 32U)+(RCC_CSSON_BIT_NUMBER * 4U))

这些数据去哪里找

这里,PERIPH_BB_BASE的映射地址是0x42000000,前面例子中的SRAM映射地址是0x22000000,具体可参考STM32的编程参考手册PM0214,如下图

MCU_STM32的位带操作 -- bit banding[通俗易懂]

 

其次,在STM32F405xx/STM32F407xx的datasheet表10中,有说明RCC寄存器地址为0x40023800-0x40023BFF,

所以,RCC_CR_CSSON_BB 的计算就是0x42000000UL + 0x00023800*32 + 0x13*4

 

参考资料

STM32F405/407 datasheet下载地址:

https://www.st.com/resource/en/datasheet/stm32f405og.pdf

STM32F4编程手册(STM32 Cortex®-M4 MCUs and MPUs programming manual)下载地址:

https://www.st.com/content/ccc/resource/technical/document/programming_manual/6c/3a/cb/e7/e4/ea/44/9b/DM00046982.pdf/files/DM00046982.pdf/jcr:content/translations/en.DM00046982.pdf

Cortex-M3 Technical Reference Manual (Cortex-M3的手册)下载地址:

http://infocenter.arm.com/help/topic/com.arm.doc.ddi0337e/DDI0337E_cortex_m3_r1p1_trm.pdf

Cortex-M4 Technical Reference Manual (Cortex-M4的手册)下载地址:

http://infocenter.arm.com/help/topic/com.arm.doc.ddi0439b/DDI0439B_cortex_m4_r0p0_trm.pdf

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182618.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 一周时间背完四六级单词

    一周时间背完四六级单词

    2021年5月1日
    134
  • 浏览器缓存机制详解

    浏览器缓存浏览器缓存的知识是前端工程师必须要掌握的,因为这些知识直接影响到你的页面的用户体验,影响到你的页面的加载策略。接下来将要详细的讲述浏览器缓存的概念和原理,新人要仔细阅读,甚至要多次反刍,

    2021年12月24日
    38
  • 什么是SSH 以及常见的ssh 功能

    什么是SSH 以及常见的ssh 功能什么是SSH?简单说,SSH是一种网络协议,用于计算机之间的加密登录。如果一个用户从本地计算机,使用SSH协议登录另一台远程计算机,我们就可以认为,这种登录是安全的,即使被中途截获,密码也不会泄露。最早的时候,互联网通信都是明文通信,一旦被截获,内容就暴露无疑。1995年,芬兰学者TatuYlonen设计了SSH协议,将登录信息全部加密,成为互联网安全的一个基本解决方案,迅速在全世界获得推广,目…

    2022年7月13日
    14
  • 怎样和领导汇报工作,更容易获得升职加薪?谈谈和领导汇报的艺术

    怎样和领导汇报工作,更容易获得升职加薪?谈谈和领导汇报的艺术

    2022年2月14日
    48
  • iOS关于地图定位基础(二)[通俗易懂]

    iOS关于地图定位基础(二)[通俗易懂]在前一篇文章 iOS关于地图定位基础(一) 中我们主要总结了 iOS里面利用原生 CoreLocation 框架实现基本定位功能和一些注意点,侧重点主要是iOS8+之后的定位授权与授权状态的使用。接下来本篇文章主要是讲解如何利用 CoreLocation 框架实现地理定位的具体实现。(PS:下文涉及我自定义的指南针Demo请去我的GitHub仓库查看源码https://github.com/IML

    2022年7月26日
    6
  • 一文概括常用图像处理算法

    一文概括常用图像处理算法本文总结了11种常用的图像处理算法,包含了预处理算法以及检测算法,并介绍了一些常用的开发库。一、算法(预处理算法、检测算法)在采集完图像后,首先会对图像进行预处理操作。1、图像变换(空域与频域、几何变换、色度变换、尺度变换)2、图像增强3、纹理分析(取骨架、连通性)4、图像分割5、图像特征6、图像/模板匹配7、色彩分析8、图像数据编码压缩和传输9、表面缺陷目标识别算法10、图像分类(识别)11、图像复原二、现有的视觉检测软件/库三、HSV颜色识别-HSV基本颜色分量范围

    2022年5月13日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号