S32K144内存分配

news/2024/11/8 6:43:28/

本文将通过实际的工程代码介绍NXP S32K144单片机变量地址分配,应用笔记仅用于自己学习及大家参考。

示例代码如下:

uint8_t num_byte[4];
uint32_t num_word;
const uint32_t num_word_const = 0x1234;
uint32_t *point_heap;
int main(void)
{
uint8_t num_byte_stack;
static uint8_t num_byte_static;

point_heap = (uint32_t *)malloc(4);
*point_heap = 0x3421;
free(point_heap);

num_byte_stack = 0x11;

printf("num_byte addr is 0x%x\r\n",&num_byte);
printf("num_word addr is 0x%x\r\n",&num_word);
printf("num_word_const addr is 0x%x\r\n",&num_word_const);
printf("point_heap addr is 0x%x\r\n",&point_heap);
printf("point_heap is 0x%x\r\n",point_heap);
printf("num_byte_stack addr is 0x%x\r\n",&num_byte_stack);
printf("num_byte_static addr is 0x%x\r\n",&num_byte_static);
}

Link 文件 S32K144_64_flash.ld 配置如下

map文件如下:

堆空间设置为0x20000020 – 0x2000041f,大小为0x400。
栈空间设置为0x20006c00 – 0x20006fff,大小为0x400。

实验结果为:
num_byte addr is 0x20000014
num_word addr is 0x20000018
num_word_const addr is 0x7b8
point_heap addr is 0x20000010
point_heap is 0x20000028
num_byte_stack addr is 0x20006ff3
num_byte_static addr is 0x20000004
结论:
num_byte、num_word、num_byte_static和point_heap存储在内部RAM中。
num_byte_stack存贮在栈中。
point_heap申请到的内存在堆中。
num_word_const在内部flash中。

详细描述:
1.通过打印看出,num_byte(0x20000014)、num_word(0x20000018)、num_byte_static(0x20000004)和point_heap(0x20000010)并不在堆栈中,它们存储在内部RAM中。
这也验证了static关键字,在修饰函数内的局部变量时,这个变量将和全局变量一样存储在内部ram中。
同时也说明了,编译器分配内存时候,是先分配全局变量(和static修饰的局部变量),再分配栈,最后再分配堆的。具体全局变量的分配,先分配static修饰的局部变量,在分配指针地址,最后分配全局变量。

2.对于栈的内存分配,局部变量,也就是num_byte_stack(0x20006ff3)是存储在栈的范围内。
关于栈,再说一句,栈不仅仅保存了局部变量,它会在函数切换,中断发生时保存现场,保存ARM内核的寄存器。
3.堆的问题,简单来说:malloc申请的内存都在堆中。point_heap(0x20000028)指针指向的内存地址就在堆的范围内。
4.最后一个num_word_const(0x7b8),const修饰的变量是存储在内部flash中的,它的地址在内部flash范围内。
 


http://www.ppmy.cn/news/241123.html

相关文章

内存管理(一)——内存分配

前言 我们都知道,计算机工作的过程概括起来就是 CPU 去内存中读取指令并执行的过程,但是如果运行我们的程序直接操作物理内存,将会引发很多的问题(比如不同进程之间访问/修改的隔离、权限等等),所以爱操心…

DDR3地址及容量大小

DDR3 地址线 DDR3为减少地址线,把地址线分为行地址线和列地址线,在硬件上是同一组地址线;地址线和列地址线是分时复用的,即地址要分两次送出,先送出行地址,再送出列地址。 一般来说列地址线是10位&a…

STM32——根据地址计算存储空间的大小

首先要知道 1MB1024KB 1KB1024Byte 1Byte8bit 存储空间大小结束地址-起始地址1(用十进制来算,得到结果的单位是Byte) 十六进制与2进制转换表 十六进制2进制00000100012001030011401005010160110701118100091001A(10&#xf…

STL六大组件之——分配器(内存分配,好深奥的东西)

SGI设计了双层级配置器,第一级配置器直接使用malloc()和free(),第二级配置器则视情况采用不同的策略:当配置区块超过128bytes时,视之为“足够大”,便调用第一级配置器;当配置区小于128bytes时,视…

kmalloc分配大小的限制

原文地址:http://linux.chinaunix.net/techdoc/net/2009/04/28/1109237.shtml #################################################################################################################################### kmalloc是通过cache来实现的, 只不过每次…

采用链接分配方式进行外存分配时,可采用的两种形式及其特点。假定磁盘块大小为4K,对于128G的硬盘,其文件分配表FAT需占用多少存储空间?

采用链接分配方式进行外存分配时,可采用的两种形式及其特点。假定磁盘块大小为4K,对于128G的硬盘,其文件分配表FAT需占用多少存储空间? 隐式链接:除文件的最后一个盘快外,每个盘快中都存有指向下一个盘快的…

内存分配方式

一、内存分配方式 内存分配有三种方式: 1、从静态存储区分配。这种方式是在程序编译的时候已经分配好,并且这块内存在程序的整个运行期间都存在。如全局变量,static变量。 2、在栈上创建。在执行函数的时候,函数内局部变量的存储单…

kmalloc详解与分配大小的限制

kmalloc是通过cache来实现的, 只不过每次kmalloc的大小不同, 因此是从不同的cache中分配: /* include/linux/slab.h */ // 注意kmalloc是在头文件中定义的 static inline void *kmalloc(size_t size, gfp_t flags) {if (__builtin_constant_p(size)) { /*__builtin_constant_p…