之前一直很奇怪一个问题,每次写好单片机程序之后,用烧录软件进行烧录时,能看到烧录文件也就是 hex 的文件大小:
我用的单片机芯片是 STM32F103C8T6,程序储存器(flash)只有 64K。
从上图可以看出,hex 有 128K。
我有两点疑问,
1. 只是一个很简单的平衡小车程序而已,有 128K,这么大吗?
2. 就算有 128K,能下载到只有 64K 容量的单片机中去?
这可能是一道送命题!
下面开始我们的探索之旅,以 STM32 开发为例。在 keil 中进行程序编译之后,在界面部分:
很多朋友估计看到这界面,也只关心 2 个点:
第一、自己编写的程序是否正确生成了 hex!第二、自己编写的程序有没有错误,有没有警告!
在图中红线部分:
有 4 个:Code、RO-data、RW-data、ZI-data。
Code:表示所要执行的代码,程序中所有的函数都位于此处。
RO-data:表示只读数据,程序中所定义的全局常量数据和字符串都位于此处。
RW-data:表示已初始化的读写数据,程序中定义并且初始化的全局变量和静态变量位于此处。
ZI-data:表示未初始化的读写数据,程序中定义了但没有初始化的全局变量和静态变量位于此处。
从描述中可以得出:
1. 下载到单片机 FLASH 的程序是:Code+RO-data+RW-data(上图中数据为字节数,kb=byte/1024);
hex=(39546+5862+12428)/1024=56.48
2. 运行在 RAM 中的数据是:RW-data+ZI-data;
原来 window 下显示的 hex 大小,并非是我们下载到单片机中的 hex 大小。
关于为什么显示不同,这又是一个十分有趣的问题,有兴趣的朋友可以一起探讨下。
最后,貌似 C8T6 这个芯片的资源差不多被榨干了,要考虑换芯片了。