前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >第1阶段——关于u-boot目标文件start.o中.globl 和.balignl理解(3)

第1阶段——关于u-boot目标文件start.o中.globl 和.balignl理解(3)

作者头像
诺谦
发布2018-01-03 16:17:02
6650
发布2018-01-03 16:17:02
举报
文章被收录于专栏:Linux驱动Linux驱动

汇编程序中以.开头的名称并不是指令的助记符,不会被翻译成机器指令,而是给汇编器一些特殊指示,称为伪操作.

代码语言:javascript
复制
.globl _start  

作用:声明一个_start全局符号(Symbol), 这个_start这个符号要被lds链接脚本用到

代码语言:javascript
复制
.balignl 16,0xdeadbeef

作用:以当前地址开始,在地址为16的倍数的指令位置的上一个指令填入为0xdeadbeef的内容。

实例,在start.o中有以下几段:

代码语言:javascript
复制
1 .globl _start                             // .globl定义一个全局符号"_start",表明_start这个符号要被链接器用到 
2 _start:	                                  //_start:系统复位设置,以下共8种不同的异常处理
3 b reset                                   //复位异常             0x0
4 ldr	pc, _undefined_instruction          //未定义的指令异常       0x4
5 ldr	pc, _software_interrupt             // 软件中断异常          0x8 
6 ldr	pc, _prefetch_abort                 //内存操作异常           0xc
7 ldr	pc, _data_abort                     //数据异常               0x10
8 ldr	pc, _not_used                       //未使用                 0x14
9 ldr	pc, _irq                            //中断IRQ异常            0x18
10 ldr	pc, _fiq                          //快速中断FIQ异常        0x1c
11 
12 _undefined_instruction:	.word undefined_instruction         //0x20
13 _software_interrupt:	.word software_interrupt               //0x24
14 _prefetch_abort:	.word prefetch_abort                  // 0x28
15 _data_abort:	.word data_abort                          //0x2c
16 _not_used:	.word not_used                              //0x30
17 _irq:	.word irq                                       //0x34
18 _fiq:	.word fiq                                       //0x38
19 
20 .balignl 16,0xdeadbeef                                  //0x3c 

在第1行中".globl _start":

使用.globol声明全局符号_start,在 board/100ask24x0/u-boot.lds中ENTRY(_start)这里用到_start是一个符号,符号在汇编程序中代表一个地址,然后在lds链接脚本中通过这个_start全局符号来跳转到_start所在的地址来进行复位异常处理。

第20行中 .balignl 16,0xdeadbeef:

它的意思就是在以当前地址开始,在地址为16的倍数的指令位置的上一个指令填入为0xdeadbeef的内容,

此时当前地址刚好0x3c=60,由于ARM每个指令间隔4个字节,且64%16=0,所以在0x3c中填入0xdeadbeef。仿真如下图所示,可以看出在0X3C处填入了0xdeadbeef. 它们的作用就是为内存做标记,插在那里,这个位置往前有特殊作用的内存,禁止访问。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-07-14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档