野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 10486|回复: 1

关于STM32的程序执行过程问题

[复制链接]
发表于 2015-1-10 10:40:28 | 显示全部楼层 |阅读模式
火哥的书上说,程序先是倒到RAM中运行的,但是我看了看8051的core结构,它的运行也是分别取指令取数据的,然后找到《Cortex-M3权威指南.pdf》上图,下面是原文载录如下:
Cortex‐M3是一个32位处理器内核。内部的数据路径是32位的,寄存器是32位的,存储器接
口也是32位的。CM3采用了哈佛结构,拥有独立的指令总线和数据总线,可以让取指与数据访问
并行不悖。这样一来数据访问不再占用指令总线,从而提升了性能。为实现这个特性,  CM3内部
含有好几条总线接口,每条都为自己的应用场合优化过,并且它们可以并行工作。



从这里可以看出,程序运行时取指令和数据是分别进行的,要是程序倒到RAM中,就必须得统一编址了,然后再分别寻址。
00.jpg

主题推荐

回复

使用道具 举报

 楼主| 发表于 2015-1-10 10:43:03 | 显示全部楼层
一般的单片机的SRAM并不是太大,如果向PC机一样,把程序倒到SRAM中,这样单片机的数据存储器就必须做的比ROM大,但是现实恰恰相反,也许这也是单片机采用哈佛结构的原因,省SRAM吧,说的也许不对,大家多讨论下把!
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-11-24 23:29 , Processed in 0.036934 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表