佚名通过本文主要向大家介绍了stm32 ram flash,stm32 ram调试,stm32 ram大小,stm32扩展ram,stm32的ram等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题: stm32中的程序是在RAM里还是flash里执行?
描述:
不是nand flash不能运行程序吗?难道32里用的是nor flash?
解决方案1:
楼上各位大侠的留言都看完了,学习了,感谢感谢。 解决方案2:
stm32内部是nor flash,直接执行代码。 解决方案3:
如果你有研究过单片机编程的分散加载机制,在编程中写过分散加载脚本。你问的第一个问题就解决了。
如果你有写过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中运行。
如果你知道怎么写分散加载脚本,这个功能分分钟就能实现。
解决方案4:
描述:
stm32单片机
stm32中的Code在程序运行时要不要拷贝到RAM里执行呢?还是直接从Flash中取程序指令执行?不是nand flash不能运行程序吗?难道32里用的是nor flash?
解决方案1:
楼上各位大侠的留言都看完了,学习了,感谢感谢。 解决方案2:
STM32里有ROM和RAM,ROM就是flash,程序是下载到里面。
当STM32执行程序时,是把ROM中的数据,程序“搬运”到RAM中然后再执行的,一般的指令存储在ROM。
就比如电脑,RAM是运行内存,ROM是硬盘,cpu不是直接执行在硬盘上的程序,而是将硬盘的程序拷贝到运行内存里面,然后在运行内存中执行。
互相学习,有错误望指出,虚心受教,希望能帮到你。
stm32内部是nor flash,直接执行代码。 解决方案3:
stm32中的Code在程序运行时要不要拷贝到RAM里执行呢?还是直接从Flash中取程序指令执行?
不是nand flash不能运行程序吗?难道32里用的是nor flash?
如果你有研究过单片机编程的分散加载机制,在编程中写过分散加载脚本。你问的第一个问题就解决了。
如果你有写过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中运行。
如果你知道怎么写分散加载脚本,这个功能分分钟就能实现。
解决方案4:
代码不一定要在RAM中才能执行,CPU从一个存储器件中读取指令并执行,主要看的是该存储器能否实现随机读取(访问任意地址)。基于这个原理很多flash被修改成可以直接执行程序。STM是如何修改的,没有研究过。见过一种做法是,做一个缓冲区(只用来缓冲执行代码)将FLASH的代码读到该区中,有点类似MPU的感觉。
对于RAM,最初设计是用来存放变量的,可以说是栈空间,由CPU的SP指针指向。
以PC机为例(主流操作系统也是这样),将代码从硬盘从读取,存放到内存中(DDR),系统则会将该内存定义为READ ONLY也就是ROM的意思。对CPU来说,该区域并不是什么DDR或者RAM,只是一个可以随机读取代码的存储器,当然CPU也不关心这个是ROM,DDR,还是FLASH。
是norflash,不能直接从ram中运行,选项中有一个init区域可以选成ram。你直接把程序运行指针指向ram的话会出错。