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

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

.globl _start  

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

.balignl 16,0xdeadbeef

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

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

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. 它们的作用就是为内存做标记,插在那里,这个位置往前有特殊作用的内存,禁止访问。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏FreeBuf

如何进行Linux平台共享库替换

*本文原创作者:gaearrow,本文属FreeBuf原创奖励计划,未经许可禁止转载 。 共享库基础知识 程序由源代码变成可执行文件,一般可以分解为四个步骤...

2098
来自专栏各种机器学习基础算法

python中关于'gbk' codec can't encode character u'\xxx'的问题

问题: 使用webdriver中获取网页数据流的时候,然后print driver.find_element_by_id('').text,出现如下错误 Uni...

31210
来自专栏Pulsar-V

CTF随笔(一)

WEB01 XSS水题 直接提交poc吧 http://xxx.com/xss1.php?bug="></h2><h1+onclick="alert()">s...

5657
来自专栏Astropeak

Emacs Helm: 使用关键字搜索、获取、执行任何东西

1214
来自专栏从零开始学自动化测试

Selenium2+python自动化44-元素定位参数化(find_element)

前言 元素定位常用的有八种方法,这个能看到这一篇的小伙伴都知道了,那么有没有一种方法,可以把常用的八种定位合为一种呢?也就是把定位的方式参数化,如id,name...

3205
来自专栏丑胖侠

《Drools7.0.0.Final规则引擎教程》第4章 4.3 定时器

定时器 规则用基于 interval(间隔)和cron的定时器(timer),替代了被标注过时的duration 属性。timer属性的使用示例: time...

2109
来自专栏IMWeb前端团队

Nodejs基础:路径处理模块path总结

模块概览 在nodejs中,path是个使用频率很高,但却让人又爱又恨的模块。部分因为文档说的不够清晰,部分因为接口的平台差异性。 将path的接口按照用途归类...

1805
来自专栏有趣的django

Django rest framework源码分析(1)----认证

一、基础 1.1.安装 两种方式: github pip直接安装 pip install django-rest-framework 1.2.需要先了解的一...

44611
来自专栏陈树义

Wins批处理基本语法

在Windows平台下,批处理可以和Wins系统很好地结合,处理一些简单的任务,比如:重复删除某种类型的文件;开机执行一些特定的命令等。 本文主要介绍批处理的基...

33310
来自专栏地方网络工作室的专栏

Python3 初学实践案例(8)使用 sqlite3 数据库存储生成的密码,prettytable 的使用

Python3 初学实践案例(8)使用 sqlite3 数据库存储生成的密码,prettytable 的使用 在前面我用 python 脚本实现的 cli 版本...

2555

扫码关注云+社区