单片机运行相关

1. 类似51,AVR这类的单片机,程序只能在ROM或FLASH里运行。STC的芯片一般是标准51或增强51,用的是FLASH,程序只能在FLASH中运行。
2. ARM的程序即可以在FLASH里运行也可以在RAM里运行,不过能运行程序的FLASH只能使NorFlash,因为NANDFLASH的接口决定了其无法挂载在地址空间内。
3. 也就是说只要能挂载到ARM的程序地址空间的设备都可以直接放运行程序。否则其他存储设备只能存储程序或数据。如一般带LINUX或Wince的ARM板,一般会把主系统程序放在NorFlash或NANDFLASH中,上电后用Loader程序吧主系统程序加载到RAM或SDRAM的可执行地址去,然后跳到主程序去执行。

4. 计算机一般情况下系统存在硬盘里,系统启动时BIOS程序(在ROM里)先运行,然后从硬盘的系统分区里找到加载程序,加载到内存中(SDRAM),然后再由这段加载程序从磁盘中把系统加载进来。系统其实还可以存在光盘(所以可以从光盘启动)或网络计算机中(网吧里一般是这样)。大致就这个过程吧。具体的去网上查一下。


如果你有研究过单片机编程的分散加载机制,在编程中写过分散加载脚本。你问的第一个问题就解决了。
如果你有写过nand flash的驱动程序,你问的第二个问题就解决了。

STM32中的code可以不用拷贝到RAM中运行,也可拷贝到RAM中运行,这些不是技术问题,而是要看这段code
有没有加载到RAM中运行的必要。后面再解释。

nand flash不支持片上执行,不能在nand flash中执行程序,但nor flash支持。
但不能因此就断定STM32用的外置flash都是nor的。只要STM32带nand flash的控制器,就可以把nand中的code加载到RAM中运行。至于能不能用IO模拟nand 的接口协议,我没搞过不清楚。

首先,应该所有的单片机都是片内集成RAM和ROM(在加载域和运行域的角度看,Flash就是ROM)。
一般容量小的单片机,RAM和ROM都小,不会把flash中的代码加载到RAM中。
但有时确实需要加载,怎么办呢。就把code中比较关键的,调用很频繁的,对响应速度有要求的,就会加载到RAM中。
例如高频率中断的定时器中断ISR,就可以在分散加载脚本中修改这段code的运行域到RAM中。程序在刚上电后会在main函数之前加载这段code到RAM中。这样做的好处就是,这段code的执行速度快,我们知道ROM和RAM执行代码的速度比差距是很大的。RAM比ROM中执行速度快得多!
当然,如果你的RAM很大,你甚至可以把全部的Code加载到RAM中运行。

nand flash不是直接接到CPU的三总线上的,所以CPU不能直接从nand中取得可执行的指令,而是通过nand的控制器!
而nor是在总线上的,所以nor中的code可以直接执行。(nor的这个观点仅是我个人看法,仅供参考)。

再说外置RAM的问题,单片机在带SDRAM的控制器之后,就可以支持SDRAM了。
SDRAM在初始化好之后,SDRAM的使用方法和内置的SRAM没有差别。

如果你的单片机支持SDRAM和Nand flash,你可以把nand flash中的code加载到SDRAM中运行。
如果你知道怎么写分散加载脚本,这个功能分分钟就能实现。

对于x86的pc机和单片机等嵌入式开发系统程序的存储是截然相反的,  
即:  
x86的pc机cpu在运行的时候程序是存储在RAM中的,而单片机等嵌入式系统则是存于flash中  

 x86cpu和单片机读取程序的具体途径 

pc机在运行程序的时候将程序从外存(硬盘)中,调入到RAM中运行,cpu从RAM中读取程序和数据  
而单片机的程序则是固化在flash中,cpu运行时直接从flash中读取程序,从RAM中读取数据 

 造成这种差别的具体原因分析 

x86构架的cpu是基于冯.诺依曼体系的,即数据和程序存储在一起,而且pc机的RAM资源相当丰富,从几十M到几百M甚至是几个G,客观上能够承受大量的程序数据。  
单片机的构架大多是哈弗体系的,即程序和数据分开存储,而且单片的片内RAM资源是相当有限的,内部的RAM过大会带来成本的大幅度提高。 

单片机的程序能存储在RAM中吗 ?

通过上面的分析可得知:单片机的程序能存储于flash中是基于两点考虑,即体系结构和RAM资源的多少。因此,在技术不但进步片内RAM容量不断增多的今天,RAM资源已经不再是制约这种差别的主要因素,而对于体系机构我们只要更改cpu读取程序的方式就可以。  
将嵌入式系统的程序存于RAM中的具体做法  
“对于很多的嵌入式系统,其代码很多都存储在nor flash中,运行也是直接在flash中运行.我最近了解到我新公司的软件中的一段代码当时为了提高运行速度被加载到ram中运行.当时他们是花了很多时间来解决这个问题的.  
我仔细研究了一下链接脚本,用的是gnu的Linux的交叉工具链.地址分配是写在一个ld脚本中的.  
他们是这样实现的:  
1,将你需要在ram中运行的代码写在单独的一个c文件中,然后在脚本中设置其运行地址与存放地址分开.设置好必要的代码起始和结束的标志变量.  
2,在代码中将存放地址处的代码拷贝到运行地址中. 

这段代码倒是没什么问题,只是我有个更简单的办法:  
还记得全局变量是怎么初始化的吗? .data段是一个自动初始化的段(内核代码处理),我只需要将这个c文件产生的代码放置在.data段中,这段代码就可以被加载到ram运行了.我测试了一下运行良好. 

      
                      冯.诺依曼体系与哈佛体系的区别 

  二者的区别就是程序空间和数据空间是否是一体的。 早期的微处理器大多采用冯诺依曼结构,典型代表是Intel公司的X86微处理器。取指令和取操作数都在同一总线上,通过分时复用的方式进行的。缺点是在高速运行时,不能达到同时取指令和取操作数,从而形成了传输过程的瓶颈。  
哈佛总线技术应用是以DSP和ARM为代表的。采用哈佛总线体系结构的芯片内部程序空间和数据空间是分开的,这就允许同时取指令和取操作数,从而大大提高了运算能力。  
例如
STM320LF240x系列DSP是增强型的哈佛结构通过三组并行的总线访问多个存储空间。它们分别是:程序地址总线(PAB),数据地址读总线(DRAB)和数据地址写总线(DWRB)。


stm32内部是nor flash,直接执行代码。

1. 冯诺依曼结构和哈佛结构

 

  PC(x86)采用的是冯诺依曼结构,运行的时候即数据和程序都放在同一个存储器(ram)里,共用一条存储总线。具体 :当PC没电的时候,程序和数据存储在硬盘里,当pc上电的时候,在硬盘里运行的一段小程序把全部程序从硬盘搬运到ram中,然后程序开始在ram中运行;

 而嵌入式系统(arm,dsp)采用的哈佛结构,运行的时候程序存储在flash中,数据存储在ram中,所以cpu从flash中取指令,到ram中取数据,指令总线和数据总线也是分开的;

2者之所以采用不同的结构,主要因为PC的ram空间足够,而嵌入式的ram太小;

 

以下以stm32来说明:

(1)cpu根据boot0和boot1的硬件引脚决定从flash还是ram中启动,默认是从flash中启动;启动之后会搬运rw-data 到ram,但是不会搬运code;

(2)如果采用ram中运行,一般只能用作调试模式,因为掉电程序就丢失了;

(3)从系统启动其实就是isp,是固化在rom中的一段代码;

    参考:   http://www.chinadmd.com/file/tr6xa3uo3osurvuett6iv6cx_1.html  3中启动方式的区别;

   参考:   http://wenku.baidu.com/link?url=ilgM8Oky4ogqfmNX9f-nLN3-a7gpZmSnarJjXtrlhK3UgnSn8jQRyY9nJ-pUK4REqkbow185fFrVk8WU7KVfTiPlttW3bOfOeLn8HI3FkKC

                 在ram中调试的设置方法;(主要是把ram的一段设置为rom来用,注意程序的大小要小于ram)

 

 

至于linux中从flash搬运到ram中之后,ram的link地址怎么从flash改变,每个函数的地址有时怎样在ram中寻址的,这是另外一个问题,需要学习和研究,

可以度娘 “stm32内存管理” 或者 “c语言内存分区”


http://blog.csdn.net/jj163zhuangzi/article/details/47088843



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/243587.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《心欢喜,灵快乐》出版

深圳女作家、画家崔文僮的散文绘画集出版。该书是她观察生活、体验人生、感悟艺术的真实记录。著名女作家徐小斌看了她的文章和绘画,写道:“‘生活家’这个概念令人非常感兴趣。文僮决定做一个‘有追求’的‘生活家’,这本身就十分有趣&#…

Sublime Text快捷命令

到页面底部:Ctrl End 这个快捷键可以将光标移动到当前页面的底部。 到页面顶部:Ctrl Home 这个快捷键可以将光标移动到当前页面的顶部。 批量注释:Ctrl / (Windows/Linux) 或 Cmd / (Mac) 这个快捷键可以在选中的行上添加或删除注释…

SPI-Flash页写实验

SPI-Flash页写实验 `timescale 1ns / 1ps module flash_pp_ctrl(input wire sys_clk,//系统时钟,频率50MHZ input wire sys_rst_n,//复位信号,低电平有效 input wire key,//按键输入信号 output reg cs_n,//片选信号 output reg sck,//串行时钟 output reg mosi //主输出从输…

散文绘画集《心欢喜,灵快乐》研讨会在京举行

中国作家网2009年07月28日15:53消息:7月28日,深圳女作家崔文僮创作的散文绘画集《心欢喜,灵快乐》研讨会在京举行。与会的评论家、画家和编辑们就崔文僮的散文和绘画进行了深入的分析和热烈讨论,专家们认为:作为一个非…

spi flash驱动

移植需要更改sendrcv函数里面内容,宏定义内容 #define DRV_SPI_FLASH_WRITE_ENABLE (0x06) //Write Enable #define DRV_SPI_FLASH_WRITE_DISABLE (0x04) //Write Disable #define DRV_SPI_FLASH_READ_STATUS_REG …

C++的int初始化

&#xfeff;int MyInt(56);std::cout<<"MyInt"<<MyInt<<std::endl;int MySecondInt int(); //int变量可以这样初始化std::cout<<MySecondInt<<std::endl;//那么可不可以这样初始化呢? int MyThirdInt(int());//error!!! now…

基于I2C协议的EEPROM驱动控制

基于I2C协议的EEPROM驱动控制 `timescale 1ns / 1ps module i2c_ctrl #(parameter DEVICE_ADDR = 7b1010_000,//i2c设备地址 parameter SYS_CLK_FREQ = 26d50_000_000,//输入系统时钟频率 parameter SCL_FREQ = 18d250_000 //i2c设备scl时钟频率 ) (input wire sys_clk,/…

做一个幸福的“生活家”:谈《心欢喜,灵快乐》

蝴蝶 工笔 放慢时间&#xff0c;静下心情&#xff0c;感受平常的生活&#xff0c;学习和体会生活带给我们的小小幸福&#xff0c;这或许是现代人很难做到的一种状态。正如我非常欣赏的法国女钢琴家埃莱娜格瑞莫所说&#xff1a;“谁能让我们幸福&#xff1f;如果不是我们自身&…

main函数相关

在历史上&#xff0c;大多数UNIX系统对main函数提供了三个参数&#xff0c;原型如下&#xff1a; int main(int argc, char *argv[], char *env[] ); 其中第三个参数是环境表地址。 ANSI C规定main函数只有两个参数&#xff0c;而且第三个参数与全局变量environ相比也没有带来更…

导演李大为婚礼全过程(一)

新锐导演李大为于昨日&#xff08;8月1日&#xff09;在北京北郊的拉斐特城堡举行隆重婚礼。新娘是赵怡然。李大为曾执导过电视剧《金粉世家》《红粉世家》和电影《走着瞧》&#xff0c;其中《走着瞧》入围了去年的东京电影节&#xff0c;在今年的上海国际电影节上获得了包括最…

对以前的改进MFC略缩图控件改进

以前写了一篇日记&#xff0c; 显示略缩图&#xff0c;见 《自绘列表框控件显示略缩图----再稍微改进点点。。》 http://blog.csdn.net/hemmingway/article/details/7483619 这次给他加点改进&#xff0c;就是增加删除被勾选的图片。。。 增加两个函数&#xff1a; CString …

VHDL程序结构

VHDL程序结构 --设计库和程序包调用 library IEEE; use IEEE.STD_LOGIC_1164.ALL; --电路端口说明和定义-VHDL实体描述部分 entity MUX41A is -- Port ( );PORT(a,b,c,d : IN STD_LOGIC;s0,s1 : IN STD_LOGIC;y : OUT STD_LOGIC ); end MUX41A; --结构体说明部分 arch…

导演李大为婚礼全过程(二)

新郎和新娘一起在垒成金字塔的酒杯里倒香槟酒。由此喜宴真正开始。 老巫启贤前晚刚品了“快女”&#xff0c;一早又风尘仆仆飞至北京。 偶与西门。 喜宴大厅前制作精美的指示牌 台湾导演丁仰国刚执导完《一起去看流星雨》&#xff0c;与其酷似徐若萱的二女儿。我们去年曾在台北…

stm32内存分配

https://www.cnblogs.com/yanghong-hnu/p/4705755.html http://blog.csdn.net/c12345423/article/details/53004747 http://blog.csdn.net/spdian/article/details/52963829 bss段&#xff1a; bss段&#xff08;bss segment&#xff09;通常是指用来存放程序中未初始化的全…

同步/异步移动文件列表框选中的文件

&#xfeff;//PlayBackDlg.hCStringArray m_ArrayFiles;HANDLEm_hThreadMoveFiles;//异步移动文件句柄unsigned int ThreadID;void OnRefresh();void OnMoveTo(); //这个同步移动文件void OnMoveToAsync(); //使用线程, 异步//PlayBackDlg.cpp//m_listVideo…

小女人的建筑大梦

去年在台北&#xff0c;好友台湾恒兆出版公司的总编辑郑花束女士以及一家旅游杂志的女主编请我与深圳作家千夫长一起吃饭。两个台湾女人领着两个蒙古男人来到了一家奇特的餐厅——“伍角船板”。黄昏里&#xff0c;餐厅怪异夸张的外形让我惊奇。餐厅主体结构是两个狂舞的女孩的…

VHDL程序基本构建

VHDL程序基本构建 实体和端口模式 VHDL实体是整个设计实体(即独立的电路功能结构)的重要组成部分,其功能是对这个设计实体与外部电路进行接口描述。 实体说明单元的一般语句结构如下:ENTITY 实体名 IS[GENERIC (参数名 : 数据类型);][PORT(端口表 : 数据类型);]END ENTI…

“像你一样”与海容天天:OPEN国际行为艺术展十周年

8月5日。OPEN国际行为艺术展十周年在北京798艺术区开幕。来自欧美、日本、中国的艺术家参展。其中有费尔南多雷耶斯马塔、詹克诺尔、中岛美、田中洋平、吴方洲、杨青等&#xff0c;将近一百人。这个题为“像你一样”的行为艺术是美国艺术家托马斯史蒂文森的作品。内容是他给一个…

父进程和子进程之间

fork后父子进程共享资源 Unix环境高级编程中8.3节中说&#xff0c;“子进程是父进程的副本。例如&#xff0c;子进程获得父进程数据空间、堆和栈的副本。注意&#xff0c;这是子进程所拥有的副本。父进程和子进程并不共享这些存储空间部分。父进程和子进程共享正文段。” 书中还…

VHDL文字规则

VHDL文字规则 数字 "=>" 有“于是,then” 的意思 d1 <= 10#170#; --向d1赋值10#170#(十进制表示,等于170) d2 <= 16#FE#; --(十六进制表示,等于254) d1 <= 2#1111_1110#; --(二进制表示,等于254) d1 <= 8#376#; --(八进制表示,等于254) d1 &…