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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ssh配置免密码登录(linux免密登录)

    由于公司的生产环境有很多台Linux的CentOS服务器,为了方便机子(假设两台机子A,B)互相之间免密ssh,scp命令操作,配置如下1.在A、B上分别创建本机的公钥和私钥,输入命令后连续三次回车ssh-keygen-trsa2.查看公私钥的文件生成情况cd~/.ssh/ls看到列表有2个文件:文件说明:id_rsa:生成的私钥文件id_rsa.pub:生成的公钥文件3….

    2022年4月14日
    34
  • 计算机应用模块数量如何填写,职称计算机考试科目、模块数量介绍

    计算机应用模块数量如何填写,职称计算机考试科目、模块数量介绍原标题:职称计算机考试科目、模块数量介绍全国计算机应用能力考试坚持”实事求是,区别对待,逐步提高”的原则,不同地区、不同部门根据本地区、本部门的实际情况,确定适合本地区、本部门的考试范围要求。1、不同地区和部门自主确定应考科目数量在对专业技术人员计算机应用能力的具体要求上,各省、自治区、直辖市人事厅(局)和国务院有关部门干部(人事)部门应结合本地区、本部门的实际情况,确定本地区、本部门在评聘专业技…

    2022年5月5日
    111
  • socks4代理网络渗透测试实验

    socks4代理网络渗透测试实验实验目的:利用2级代理功能对3层网络进行渗透测试靶机ubantu192.168.31.207192.168.1.129ubantu192.168.1.100192.168.2.10windows2009192.168.2.100192.168.首先访问192.1…

    2022年6月14日
    36
  • python3 gil锁_python锁有哪几种

    python3 gil锁_python锁有哪几种前言python的使用者都知道Cpython解释器有一个弊端,真正执行时同一时间只会有一个线程执行,这是由于设计者当初设计的一个缺陷,里面有个叫GIL锁的,但他到底是什么?我们只知道因为他导致pyt

    2022年7月28日
    3
  • java在线播放_Java实现视频在线播放flv视频

    java在线播放_Java实现视频在线播放flv视频1、首先使用Idea创建一个SpringBoot项目。2、在application.properties文件下加入以下代码,进行DEBUG日志输出,配置pom.xml文件:#logging日志配置logging.level.root=WARNlogging.level.org.springframework.web=DEBUG4.0.0com.exampledemo0.0.1-SNAPSHOTj…

    2022年9月22日
    2
  • Python画图

    Python画图帮别人实现rubberfriction的运算公式。公式不是我专业的内容,完全不懂,只是照着公式用python计算并画图。做出的图,与论文中的图进行对比,完全一致。之所以用python,是因为mat

    2022年7月5日
    24

发表回复

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

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