KEIL查看ARM-Cortex M架构soc的内核寄存器之 MSP

  

参考下图stm32l475的参考手册:

MSP指向地址基地址为0x20000000的内存处。参考STM32L475的memory map可知MSP指向的是SRAM的一块地址。并且由上面的编译信息可知,偏移量是0x480, 正好等于 RW-data + ZI-data 的值。

 参考下图的内存模型:

可知MSP指向的是内存中bss段的最上方。

 

影响ZI-data值的因素:

影响ZI-data值的因素:

一是Stack_Size的值;   注意,Stack_Size增加1,ZI-data会增加4,因为当前是32位处理器。

二是Heap_Size的值(这个有前提条件:必须在程序中确确实实使用了malloc,否则会被编译器优化,不会把单片机启动汇编文件设置的Heap_Size计算入ZI-data。在上图中,程序中不使用malloc,ZI-data的值是1192。使用malloc申请了10个int对应的内存后,ZI-data多占用了512字节的内存空间。 这512字节的内存空间恰好就是我们设置的0x200大小的Heap_Size。)

 

其他验证渠道:

 

 

江湖很大,你我相遇在此有一定缘分,可以考虑加个QQ群聊聊人生,技术离不开生活,生活离不开聊聊。

 

.

posted @ 2019-03-15 15:57  一匹夫  阅读(4231)  评论(0编辑  收藏  举报