STM32位段(位带、bit-band)疑点分析
STM32的位带基本原理可以参考下面这个链接的文章
STM32位带操作全解89 赞同 · 14 评论文章正在上传…重新上传取消
我这里主要把我遇到的一个疑点分享出来,方便大家遇到同样问题的时候能够找到原因。
我在一个项目中用到了STM32L43X芯片,在准备使用位带对GPIO操作的时候发现无效。
STM32L43X是M4内核的,本身是具备位带功能的。下面是STM32L43X位带所在地址
#define SRAM1_BB_BASE (0x22000000UL) /*!< SRAM1(96 KB) base address in the bit-band region */
#define PERIPH_BB_BASE (0x42000000UL) /*!< Peripheral base address in the bit-band region */
经过多方资料查看,最后才发现问题所在。位带是将SRAM1或者外设存储空间的头1M映射到位带空间的32M中。SRAM1前1M的存储空间的地址是0x20000000UL~0x200FFFFFUL,对应的32M位带空间是0x22000000UL~0x23FFFFFFUL。外设寄存器前1M的存储空间的地址是0x40000000UL~0x400FFFFFUL,对应的32M位带空间是0x42000000UL~0x43FFFFFFUL。也就是说只有外设寄存器地址映射到0x40000000UL~0x400FFFFFUL的外设可以进行位带操作。STM32L43X对应外设空间如下
#define PERIPH_BASE (0x40000000UL) /*外设起始地址 */
#define APB1PERIPH_BASE PERIPH_BASE
#define APB2PERIPH_BASE (PERIPH_BASE + 0x00010000UL)
#define AHB1PERIPH_BASE (PERIPH_BASE + 0x00020000UL)
#define AHB2PERIPH_BASE (PERIPH_BASE + 0x08000000UL)
可以看到APB1、APB2、AHB1所属外设是在这个范围内的,可以进行位带操作。而AHB2所属外设不在这个范围,不能进行位带操作。对于STM32系列芯片,相同的外设有可能放在不同的外设空间当中。例如,STM32F407的GPIO寄存器是映射在AHB1空间的,而STM32L43X的GPIO寄存器是映射在AHB2空间的。所以STM32L43X的GPIO不能进行位带操作。