STM32L4位带操作,STM32L4不能位带操作的原因

STM32L43X的位带操作在尝试用于GPIO时无效,原因是GPIO寄存器位于AHB2外设空间,而STM32L43X的位带只支持映射在0x40000000UL~0x400FFFFFUL地址范围内的外设,如APB1、APB2、AHB1。因此,AHB2外设如GPIO无法进行位带操作。
摘要由CSDN通过智能技术生成

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不能进行位带操作。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值