现在的位置: 首页 > 技术文章 > 裸机开发 > 正文

STM32F10x的存储器映射与复位

2013年11月30日 裸机开发 ⁄ 共 1872字 ⁄ 字号 暂无评论 ⁄ 阅读 270 次

先来看两张图:

CORTEX-M3内核的存储器映射

CORTEX-M3内核的存储器映射

stm32实际系统映射

stm32实际系统映射

一、存储器映射

1、统一编址,程序存储器、数据存储器、外设寄存器组织在一个4GB的地址空间。

2、小端格式

3、映像(stm32f107,256KB产品)

存储器映像

存储器映像

可以看到,所谓的256KB闪存,是指主存储,片上FLASH如下图所示:

片上FLASH

片上FLASH

介绍了片上的资源后,来看他们的地址映像。芯片将4GB的空间,划分为8个512MB的块(block),这些块有些是整块不用的,芯片对地址的安排可以参考数据手册,memory mapping章节中的那个图。只有block1、2、3、7是使用的。

地址中block7是核内的外设对应的地址,block2是其他外设对应的地址。block1的低地址64KB是片上SRAM,block0则如下图

block0

block0

option bytes即是选项字节;system memory就是系统存储,也即片上ROM;这两部分就是所谓信息块。Flash就是指主存储,有256KB。

再往下看alias to flash or system memory.....这个区域256KB就是启动开始的区域。这个区域并没有一个自己的存储器,只是根据BOOT0、BOOT1的接法来选择哪个存储器映射到这个地址上。如下图

boot

boot

选择用户闪存启动,是典型的做法;选择系统存储器,则在ST烧写进去的自举程序引导下,通过USART1下载程序;选择从SRAM执行代码则方便调试,比较快。

二、复位

CM3将复位视作异常,优先级最高的异常。

stm32f1有三种复位:系统复位、电源复位、备份区复位。

前两种是真正的复位,对他的响应由硬件完成,这个响应对软件流的影响是这样的:程序指针指向0x0000 0004,这个单元存储的是复位服务子程序(或者汇编叫子过程),同时从0x0000 0000获取堆栈顶的地址。不同的复位类型还有对其他寄存的不同复位方式,这就完成了复位。而备份区复位则不然,The backup domain has two specific resets that affect only the backup domain(参考手册6.1 reset章节)

零地址存放的是堆栈顶的地址,之后就是以Reset_Handler打头的向量表。

上面所说的向量表的存储从零地址开始,这是缺省的情况,可以通过NVIC的一个寄存器来重定向向量表。(权威指南7.3向量表)

三、flash读写


void flashwrite(u16 data)
{
FLASH_Unlock();
while(FLASH_GetFlagStatus(FLASH_FLAG_BSY)==1);
FLASH->CR|=0x00000001;    //set PG
*((u16 *)0x0803F800)=data;
while(FLASH_GetFlagStatus(FLASH_FLAG_BSY)==1);
lxj= *((u16 *)0x0803F800);
FLASH_Lock();
}

void flashread()
{
FLASH_Unlock();
while(FLASH_GetFlagStatus(FLASH_FLAG_BSY)==1);
// FLASH->CR|=0x00000001;    //set PG
// *((u16 *)0x0803F800)=data;
// while(FLASH_GetFlagStatus(FLASH_FLAG_BSY)==1);
lxj= *((u16 *)0x0803F800);
FLASH_Lock();
}

flash必须先擦再写

给我留言

留言无头像?



×