4004|5

79

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

初学ARM,关于STM32存储器请教 [复制链接]

STM32F103ZE的启动设置里有从用户FLASH启动、系统FLASH启动、和RAM启动,通过外部BOOT0和BOOT1来设置,

我知道用户FLASH就是片内512k的程序存储空间,地址为0x08000000~0x0807ffff

RAM就是片内的64K数据存储器,地址为0x20000000~0x2000ffff

但系统FLASH是什么,在手册上看它的地址是从0x1ffff000~0x1ffff7ff 共2K,这个空间是用来做什么的,我们可以对它操作不。


先谢谢各位了。。。
此帖出自stm32/stm8论坛

最新回复

                                     详情 回复 发表于 2009-4-20 12:38
点赞 关注
 

回复
举报

74

帖子

0

TA的资源

一粒金砂(初级)

沙发
 

还有,当BOOT0和BOOT1都设置为1时,系统从RAM启动

这个功能是不是用来仿真调试程序的时候使用的,可RAM只是64K,如果要仿真的程序大于64K,那不是仿真不了了??

我现在用JLINK仿真,每次都是在仿真前编程FLASH,怎样设置可以让程序在仿真前DOWN到RAM运行。

注:仿真软件用的KEIL
此帖出自stm32/stm8论坛
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

板凳
 

哦,我知道了

但系统FLASH是什么,在手册上看它的地址是从0x1ffff000~0x1ffff7ff 共2K,这个空间是用来做什么的,我们可以对它操作不。
----------------------
这是STM32的一个BOOT,可以通过串口来烧FLASH。

刚验证了一下,用串口烧了一个程序,这个FLASH区应该是官方固化了的吧,用户不可操作,对不??

此帖出自stm32/stm8论坛
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

4
 

RX

1, 关于系统flash,你的理解是对的,内有一个已固化的boot loader程序,用户不可操作这段flash。

2,如果仿真的程序大于RAM的容量,那就不能在RAM里运行,可以把代码分段,在RAM里调试部分程序。

3,要在RAM里调试程序,需要
1)使用指定到RAM的link文件来编译代码
2)在代码中修改vector table的地址
3)BOOT引脚改为从RAM BOOT的模式
此帖出自stm32/stm8论坛
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

5
 

多谢楼上兄弟热心回复

1)使用指定到RAM的link文件来编译代码
-------------
这个在哪里设置??

2)在代码中修改vector table的地址
-----
更是不明白


汗~~~~~
此帖出自stm32/stm8论坛
 
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

6
 

也可以把程序放到外部RAM跑呀!扩个大点的RAM

                                  
此帖出自stm32/stm8论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表