再说BSS段的清理
以前遇到一个裸机程序不能改变全局变量值的问题,最后迷迷糊糊解决了:手动添加了一个链接脚本,清理了BSS段。问题得以解决,就认定是BSS段清理的问题,全局变量在BSS段中。
但是现在看这个结论下的有点不全面。根据名著上说BSS段是放未初始化或者初始化为0的全局变量(经手动证实无误),我不想着有问题了。那么把这个功劳全归于BSS段的清理似乎有点勉强了。
为了验证一下,重新翻出以前的裸机程序,再来看看,这次只添加一个链接脚本,不清理BSS段,结果发现程序也是正常的,这下就彻底的证实了我的假设。原来功劳是“链接脚本”的。但是这位链接脚本是在u-boot中提取的没有仔细分析。
现在退回到没有解决这个问题之前,经过《
实例说明C语言中初始化和未初始化的全局变量所在不同的段》这个文章,确定初始化为0的全局变量是存在BSS段的,想到查看一下用objdump生成的dis文件,看到下图所示:
全局变量g_val的链接地址是0x8080(32.125k)超出了CPU内部的内存大小(4k)。再看一下加上链接脚本的g_val的链接地址:
可以看到链接地址是小于4k的。所以能够改动了。