1.清bss的引入(为什么要清bss)

我们先举个例子:

#include "s3c2440_soc.h"
#include "uart.h" char g_Char = 'A'; //.data
char g_Char3 = 'a';
const char g_Char2 = 'B'; //.rodata
int g_A = 0; //bss
int g_B; //bss int main(void)
{
uart0_init(); puts("\n\rg_A = ");
printHex(g_A);
puts("\n\r"); while (1)
{
putchar(g_Char);
g_Char++; /* nor启动时, 此代码无效 ,重定位到sdram的baseaddr后有效*/ putchar(g_Char3);
g_Char3++;
delay(1000000);
}
return 0;
}

我们把程序烧进去,然后打印g_A,但是发现g_A这个值并不是0,而是一个随机值。为什么呢?

这个时候我们做完了重定位,把代码copy到了sdram上,然后sdram上紧接着的地址就是.bss的基地址了,这时候bss段的这块内存没有经过任何处理,所以是随机的。

那么我们重定位完代码后需要进行清除sdram上.bss段的数据,因为我们知道bss是未初始化和初始值为0的全局变量。

2.怎么清bss

当然只需要往bss段写入全0就ok了,我们编写链接脚本如下:

 SECTIONS
{
. = 0x30000000; . = ALIGN(4);
.text :
{
*(.text)
} . = ALIGN(4);
.rodata : { *(.rodata) } . = ALIGN(4);
.data : { *(.data) } . = ALIGN(4);
__bss_start = .;
.bss : { *(.bss) *(.COMMON) }
_end = .;
}

再编写start.s,清除bss段的代码如下:

/* 清除BSS段 */
ldr r1, =__bss_start
ldr r2, =_end
mov r3, #0
clean:
strb r3, [r1]
add r1, r1, #1
cmp r1, r2
ble clean bl main
halt:
b halt

我们把程序再烧进去,然后打印g_A,但是发现g_A的值是0了。本质上就是对重定位后的bss段数据清0.

最新文章

  1. iOS开发阶段技能总结
  2. git删除push到远程服务器的commit
  3. WEB安全--CSRF防御
  4. POI 中的CellRangeAddress 参数
  5. mysql 运行sql脚本文件
  6. css中单位px,em,rem的区别
  7. Git学习05 --分支管理02
  8. 构造函数,This关键字
  9. 新awk整理
  10. 手摸手教你微信小程序开发之自定义组件
  11. 手把手教你全家桶之React(一)
  12. Oracle物化视图的创建及使用
  13. IDEA开发工具的学习
  14. 我在Python学习中遇到的问题一
  15. MySQL高可用架构-MHA环境部署记录
  16. 反射,内省,BeanUtil的区别
  17. 3Sum(or k_Sum)
  18. [转]微信JSAPI 微信内置JSAPI 2015年1月官方正式API接口,分享完整实例
  19. SDWebImage第三方库使用注意的一些问题
  20. net网站发布-允许更新此预编译站点 及修改发布后内容

热门文章

  1. HDU4117 GRE WORDS(AC自动机+线段树维护fail树的dfs序)
  2. F#周报2019年第50期
  3. telnet远程登陆
  4. 【CSS】346- 你所不知道的 CSS 阴影技巧与细节
  5. docker-数据管理的备份与恢复
  6. chrome 浏览器的使用技巧
  7. 基于JavaScript google map集成流程
  8. pythpn爬虫--来一波美女,备好纸巾了!
  9. NIO Buffer 内部机理使用姿势
  10. CCF-CSP题解 201903-2 二十四点