ST32单片机学习之路(4)-存储器、寄存器

一、STM2寻址范围

32位的单片机可以有32根地址线(每根地址线有两种状态:导通或不导通)。

单片机内存地址访问的存储单元是按字节编址的(而不是bit)。

STM32寻址大小:2^32= 4G(字节)

STM32寻址范围:0x0000 0000 ~ 0xFFFF FFFF

二、存储器映射

存储器指可以存储数据的设备,本身没有地址信息,对存储器分配地址的过程称为存储器映射。

图 1 H7存储区功能划分

图 2 H7 的Block 0区存储块功能和地区范围

图 3 H7 的Block 1区存储块功能和地区范围

DTCM RAM,用于数据存取,特点是速度很快,和内核一样。

AXI SRAM,位于D1域,数据带宽是64bit,挂在AXI总线上。

SRAM1SRAM2SRAM3区,位于D2域,数据带宽是32bit,挂在AHB总线上。

SRAM1:用于D2域中的DMA缓冲,也可以当D1域断电后用于运行程序代码。

SRAM2:用于D2域中的DMA缓冲,也可以用于用户数据存取。

SRAM3:主要用于以太网和 USB 的缓冲。

SRAM4,位于D3域,数据带宽是32bit,挂在AHB总线上。可以用于D3域中的DMA缓冲,

也可以当D1D2域进入DStandby待机方式后,继续保存用户数据。

Backup SRAM,位于D3域,数据带宽是32bit,挂在AHB总线上。主要用于系统进入低功

耗模式后,继续保存数据(Vbat引脚外接电池)。

三、寄存器

寄存器是单片机内部一种特殊的内存,可以实现对单片机各个功能的控制。

3.1、分类

大类

小类

说明

内核寄存器

内核相关寄存器

包含R0~R15、xPSR、特殊功能寄存器等

中断控制寄存器

包含NVIC和SCB相关寄存器,NVIC有:ISER、ICER、ISPR、IP等;SCB有:VTOR、AIRCR、SCR等

SysTick寄存器

包含CTRL、LOAD、VAL和CALIB四个寄存器

内存保护寄存器

可选功能,STM32F103没有

调试系统寄存器

ETM、ITM、DWT、IPIU等相关寄存器

外设寄存器

包含GPIO、UART、IIC、SPI、TIM、DMA、ADC、DAC、RTC、I/WWDG、PWR、CAN、USB等各种外设寄存器

3.2、寄存器计算

某个寄存器 地址,由三个参数决定:1、总线基地址(BUS_BASE_ADDR);2,外设基于总线基地址的偏移量(PERIPH_OFFSET);3,寄存器相对外设基地址的偏移(REG_OFFSET)。可以表示为:

寄存器地址 = BUS_BASE_ADDR + PERIPH_OFFSET + REG_OFFSET

图 4 总线基地址

图 4 总线基地址表中APB1的基地址,也叫外设基地址,表中的偏移量就是相对于外设基地址的偏移量。

外设基于总线基地址的偏移量(PERIPH_OFFSET),这个不同外设偏移量不一样,可在STM32H743存储器映射图查询具体的偏移量,以GPIO为例,其偏移量如下图所示:

图 5  GPIO外设基地址及相对总线偏移量

上表的偏移量,就是外设基于APB2总线基地址的偏移量(PERIPH_OFFSET)。

知道外设基地址,再找到具体某个寄存器相对外设基地址的偏移量就可知道该寄存器的实际地址了,以GPIOB的相关寄存器为例,下图所示:

图 6 GPIOB寄存器相对外设基地址的偏移量

上表的偏移量,就是寄存器基于外设基地址的偏移量(REG_OFFSET)。

因此,我们根据前面的公式,很容易可以计算出GPIOB_ODR的地址:

GPIOB_ODR地址 = AHB4总线基地址 + GPIOB外设偏移量 + 寄存器偏移量

所以得到:

GPIOB_ODR 地址 = 0X5802 0000 + 0X0400 + 0X14 = 0X5802 0414

3.3寄存器映射

寄存器映射主要涉及两个组成部分:外设寄存器结构体类型定义和寄存器映射,包括3个步骤:

1、外设寄存器结构体类型定义

2、外设基地址定义

3、寄存器映射(通过将外设基地址强制转换为外设结构体类型指针即可)

GPIO为例,其寄存器结构体类型定义如下:

GPIO外设基地址定义如下:

GPIO外设寄存器映射定义如下:

以上三部分代码,就完成了STM32H743内部GPIOA~GPIOK的寄存器映射,其原理其实是比较简单的,包括两个核心知识点:1,结构体地址自增;2,地址强制转换。

结构体地址自增,第一步就定义了GPIO_TypeDef结构体类型,其成员包括:MODEROTYPEROSPEEDRPUPDRIDRODRBSRRLCKRAFR[2],每个成员是uint32_t 类型,也就是4个字节,这样假设:MODER地址是0的话,OTYPER就是0X04OSPEEDR就是0X08PUPDR就是0X0C,以此类推。

地址强制转换,以GPIOB为例,GPIOB外设的基地址为:GPIOB_BASE0X5802 0400),

我们使用 GPIO_TypeDef 将 该 地 址 强 制 转 换 为 GPIO 结 构 体 类 型 指 针 : GPIOB ,这样 GPIOB->MODER的地址就是:GPIOB_BASE0X5802 0400),GPIOB->OTYPER的地址就是: GPIOB_BASE + 0X040X5802 0404),GPIOB->OSPEEDR的地址就是:GPIOB_BASE + 0X080X5802 0408),以此类推。

stm32h743xx.h 寄存器映射说明

STM32H743所有寄存器映射都在stm32h743xx.h里面完成,包括各种基地址定义、结构体定义、外设寄存器映射、寄存器位定义(占了绝大部分)等。

图 7 stm32h743xx.h文件主要组成部分





文章的内容来自正点原子的部分课件及网络资源。若有侵权,请联系作者删除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值