请问一下SRAM怎么用?

2019-07-14 18:12发布

不太清楚SRAM是如何工作的,是cpu自己将我们定义的buf、变量直接分配到这里面,还是需要使用什么函数来手动分配,记得有一个malloc函数,这是做什么的啊,堆和栈有什么区别啊
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
6条回答
hanbai795
1楼-- · 2019-07-15 01:31
回复第 2 楼 于2014-01-09 19:36:54发表:

最简单就是用 __attribute__((at(????))) 

愿闻其详
东少2016
2楼-- · 2019-07-15 06:25
st使用SRAM首先用一个分散加载文件,告诉编译你有哪些存储空气,包括ram 和ROM。然后malloc就从ram中分配内存。分散加载文件时arm 构架规定的
给你举个IAR 5.4的官方历程给你举个例子
1、iar工程打开后,从project-》option-》link看到link文件来自$PROJ_DIR$STM32F10x_FLASH.icf,对应安装目录的D:Program FilesIAR SystemsEmbedded Workbench 5.4armexamplesSTSTM32F10xstm32f10x_stdperiph_libProjectSTM32F10x_StdPeriph_ExamplesFSMCSRAMstm32f10x_flash.icf
这个文件下定义了几个预编译命令,告诉编译器ROM/RAM起始和终止地址在哪。
define symbol __ICFEDIT_intvec_start__ = 0x08000000;
/*-Memory Regions-*/
define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ;
define symbol __ICFEDIT_region_ROM_end__     = 0x0807FFFF;
define symbol __ICFEDIT_region_RAM_start__   = 0x20000000;
define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF;

/*-Sizes-*/__ICFEDIT_size_cstack__
define symbol    = 0x400;
define symbol __ICFEDIT_size_heap__     = 0x200;
/**** End of ICF editor section. ###ICF###*/
2、同时在这个文件
D:Program FilesIAR SystemsEmbedded Workbench 5.4armconfigideIcfEditorcortex_v1_0.xml文件里规定了堆栈和RAM ROM的位置是哪个地址。其中ROM是程序存放地址,RAM是分配内存的地址。


Start:
End:


__ICFEDIT_region_ROM_start__
__ICFEDIT_region_ROM_end__
The start address of the ROM region
The end address of the ROM region


__ICFEDIT_region_RAM_start__
__ICFEDIT_region_RAM_end__
The start address of the RAM region
The end address of the RAM region


3、以上几个文件综合起来生成一个分散加载文件,达到合理分配内存的目的。给你一个IAR工程例子D:Program FilesIAR SystemsEmbedded Workbench 5.4armexamplesSTSTM32F10xstm32f10x_stdperiph_libProjectSTM32F10x_StdPeriph_ExamplesFSMCSRAM
4、建议多看看arm分散加载,你还可以自己定义分散加载,规定每个文件编译好放在哪个地址, 哪个文件/变量分配在哪个地址。
5、DSP和ARM都可以使用这种方法,具体使用查看编译器手册。
6、在MDK中直接直接指定片外片内内存的。或者自己写一个分散加载文件,编译使用那个分散加载来编译。
东少2016
3楼-- · 2019-07-15 09:19
 精彩回答 2  元偷偷看……
小呆瓜子
4楼-- · 2019-07-15 12:32
回复第 4 楼 于2014-01-10 00:00:38发表:
st使用SRAM首先用一个分散加载文件,告诉编译你有哪些存储空气,包括ram 和ROM。然后malloc就从ram中分配内存。分散加载文件时arm 构架规定的
给你举个IAR 5.4的官方历程给你举个例子
1、iar工程打开后,从project-》option-》link看到link文件来自$PROJ_DIR$STM32F10x_FLASH.icf,对应安装目录的D:Program FilesIAR SystemsEmbedded Workbench 5.4armexamplesSTSTM32F10xstm32f10x_stdperiph_libProjectSTM32F10x_StdPeriph_ExamplesFSMCSRAMstm32f10x_flash.icf
这个文件下定义了几个预编译命令,告诉编译器ROM/RAM起始和终止地址在哪。
define symbol __ICFEDIT_intvec_start__ = 0x08000000;
/*-Memory Regions-*/
define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ;
define symbol __ICFEDIT_region_ROM_end__     = 0x0807FFFF;
define symbol __ICFEDIT_region_RAM_start__   = 0x20000000;
define symbol __ICFEDIT_region_RAM_end__     = 0x2000FFFF;

/*-Sizes-*/__ICFEDIT_size_cstack__
define symbol    = 0x400;
define symbol __ICFEDIT_size_heap__     = 0x200;
/**** End of ICF editor section. ###ICF###*/
2、同时在这个文件
D:Program FilesIAR SystemsEmbedded Workbench 5.4armconfigideIcfEditorcortex_v1_0.xml文件里规定了堆栈和RAM ROM的位置是哪个地址。其中ROM是程序存放地址,RAM是分配内存的地址。



Start:
End:


__ICFEDIT_region_ROM_start__
__ICFEDIT_region_ROM_end__
The start address of the ROM region
The end address of the ROM region


__ICFEDIT_region_RAM_start__
__ICFEDIT_region_RAM_end__
The start address of the RAM region
The end address of the RAM region


3、以上几个文件综合起来生成一个分散加载文件,达到合理分配内存的目的。给你一个IAR工程例子D:Program FilesIAR SystemsEmbedded Workbench 5.4armexamplesSTSTM32F10xstm32f10x_stdperiph_libProjectSTM32F10x_StdPeriph_ExamplesFSMCSRAM
4、建议多看看arm分散加载,你还可以自己定义分散加载,规定每个文件编译好放在哪个地址, 哪个文件/变量分配在哪个地址。
5、DSP和ARM都可以使用这种方法,具体使用查看编译器手册。
6、在MDK中直接直接指定片外片内内存的。或者自己写一个分散加载文件,编译使用那个分散加载来编译。
还是不明白
 
 
045086068
5楼-- · 2019-07-15 17:37
先把SRAM驱动起来。再把数据存到里面
freesea123
6楼-- · 2019-07-15 21:30
 你可以参考一下现成的代码,网上一大把

一周热门 更多>