本文将通过实际的工程代码介绍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范围内。 ?
|