位带操作原理

发布者:rockstar7最新更新时间:2025-03-10 来源: jianshu关键字:位带操作  SRAM  STM32 手机看文章 扫描二维码
随时随地手机看文章
  • 什么是位带操作
    某块存储区域(如SRAM)支持位带操作就被称为位带区,这个位带区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。
    2.位带别名映射方法
    以STM32的SRAM的位带区举例,说明位带别名的映射规则
    对于 SRAM 位带区的某个比特,记它所在字节地址为 A,位序号为 n(0<=n<=7),则该比特 在别名区的地址为:
    AliasAddr= 0x22000000+((A‐0x20000000)8+n)4 =0x22000000+ (A‐0x20000000)32 + n4

  • 实例



有了上面的代码,我们就可以像 51/AVR 一样操作 STM32 的 IO 口了。比如,我要 PORTA 的第七个 IO 口输出 1,则可以使用 PAout(6)=1;即可实现。我要判断 PORTA 的第 15 个位是否等于 1,则可以使用 if(PAin(14)==1)...;就可以了


关键字:位带操作  SRAM  STM32 引用地址:位带操作原理

上一篇:NRF24L01/SI24R1广播通讯
下一篇:使用STM32CubeMX和Keil MDK编写简单的LED点灯程序

推荐阅读最新更新时间:2026-03-25 13:36

关于STM32中的(bit-band)操作说明
支持了位带操作后,可以使用普通的加载/存储指令来对单一的比特进行读写。在 CM3 中,有两个区中实现了位带。其中一个是 SRAM 区的最低 1MB 范围,第二个则是片内外设区的最低 1MB范围。这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。 位带操作的概念其实 30 年前就有了,那还是8051 单片机开创的先河,如今,CM3 将此能力进化,这里的位带操作是 8051 位寻址区的威力大幅加强版。 CM3 使用如下术语来表示位带存储的相关地址: 位带区:支
[单片机]
关于<font color='red'>STM32</font>中的<font color='red'>位</font><font color='red'>带</font>(bit-band)<font color='red'>操作</font>说明
STM32操作
一、带位操作 位带操作就是将 位带区 中的每一位(bit)膨胀成位带别名区中的一 个 32 位的字 ,通过访问位 带别名区中的字 就实现了访问位带区中位的目的.可以使用指针来访问位带别名区的地址,从而实现访问 位带区内位的 目 的。 1.1、什么是带位操作 51单片机通过关键字sbit对单片机IO口进行位定义的过程即带位操作。 1.2、STM32如何实现带位操作 每个比特为膨胀成一个32位字,当访问这些字的时候就达到访问比特的目的。 举例:BSRR 寄存器有 32 个位,那么可以映射到 32 个地址上,当我们去访问这 32 个地址就达到访问 32 个比特的目的。 STM32F1 中有两个区域支持位带操作,一个是 S
[单片机]
<font color='red'>STM32</font><font color='red'>带</font><font color='red'>位</font><font color='red'>操作</font>
STM32中的(bit-band)操作
//位带操作,实现51类似的GPIO控制功能 //具体实现思想,参考 CM3权威指南 第五章(87页~92页). //IO口操作宏定义 #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF) 5)+(bitnum 2)) #define MEM_ADDR(addr) *((volatile unsigned long *)(addr)) #define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum)) //IO口地址映射 #define GPIOA_ODR_Addr
[单片机]
剖析STM32的FLASH和SRAM的使用情况
01前言 STM32片上自带FLASH和SRAM,简单讲FLASH用来存储程序的,SRAM是用来存储运行程序中的中间变量。本文详细分析下如何查看程序中FLASH和SRAM的使用情况。 本文开发工具: keil5 芯片: STM32F105VCT6 02FLASH和SRAM介绍 FLASH存储器又成为闪存,它与EEPROM都是掉电后数据不丢失的存储器,但是FLASH的存储容量都普遍的大于EEPROM,在存储控制上,最主要的区别是FLASH芯片只能一大片一大片地擦除,而EEPROM可以单个字节擦除。 SRAM是静态随机存取存储器。它是一种具有静止存取功能的内存,不需要刷新电路即能保存它内部存储的数据。STM32F1系列可以通过
[单片机]
剖析<font color='red'>STM32</font>的FLASH和<font color='red'>SRAM</font>的使用情况
STM32 外部 SRAM
简介:STM32F103ZET6 自带了 64K 字节的 SRAM,对一般应用来说,已经足够了,不过在一些对内存要求高的场合,STM32 自带的这些内存就不够用了。比如跑算法或者跑 GUI 等,就可能不太够用。 IS62WV51216简介 IS62WV51216是ISSI(IntegratedSiliconSolution,Inc)公司生产的一颗16位宽512K(512*16,即1M字节)容量的CMOS静态内存芯片。该芯片具有如下几个特点: l高速。具有45ns/55ns访问速度。 l低功耗。 lTTL电平兼容。 l全静态操作。不需要刷新和时钟电路。 l三态输出。 l字节控制功能。支持高/低字节控制
[单片机]
STM32 DMA 应用之(一)SRAM 与flash 间数据传输
一、为什么要用DMA? DMA 全称:Direct MemoryAccess 就是可以直接内存存取; 正是它可以直接操作内存所以具备以下优点: 而无需经过CPU去操作内存的存取,这样可以解放CPU出来干其他的事情; 因为他可以进行存储器时间的数据传输,而不需经过cpu,所以大大加快了数据传输速度—是一种高速的数据传输; 二.DMA有几种传输数据方式: (1)内存到 内存之间的;即:SRAM?à SRAM (2)内存到 外设之间的; (例如:串口收到的数据 从数据寄存器 à 内存) (3) 外设到内存之间的; 三.传输的数据宽度是怎样的,数据是什么样的形式传输?DMA 能传输多大的数据量? A. 数据源地址到数据目的地址 传
[单片机]
stm32 FSMC-外扩SRAM IS62WV51216
引脚定义 FSMC配置步骤 1.使能对应引脚GPIO时钟 2.配置GPIO引脚模式 3.使能FSMC时钟 4.FSMC初始化 5.存储器块使能 举例 #define Bank1_SRAM3_ADDR ((u32)(0x68000000)) //首地址0x60000000,每块0x40000000 void SRAM_gpio_init() { GPIO_InitTypeDef gpiof = { GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_12
[单片机]
<font color='red'>stm32</font> FSMC-外扩<font color='red'>SRAM</font> IS62WV51216
STM32 SRAM启动的 KeiL 配置
BOOT 引脚改成从SRAM 启动,即 BOOT0=1,BOOT1=1 如果使用ST提供的库函数 3.5 打开(system_stm32f10x.c) #define VECT_TAB_SRAM 2.x 可以通过调用以下两个函数切换中断向量表的指向。 NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x00); NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0); KEIL 的配置 (SYM32F103C8T6 (64kFlash/20kSram);
[单片机]
<font color='red'>STM32</font> <font color='red'>SRAM</font>启动的 KeiL 配置
小广播
最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

厂商技术中心

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2026 EEWORLD.com.cn, Inc. All rights reserved