Chinaunix首页 | 论坛 | 博客
  • 博客访问: 378031
  • 博文数量: 263
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1975
  • 用 户 组: 普通用户
  • 注册时间: 2014-08-05 09:59
文章分类

全部博文(263)

文章存档

2015年(166)

2014年(97)

分类:

2014-09-10 20:46:34

.balignl 16,0xdeadbeef

      0xdeadbeef,是个单词组,首先要弄明白.balignl的意思,这个其实应该算是一个伪操作符,是编译器来实现其功能的。.balignl是.balign的变体,.balign是意思是,在以当前地址开始,地址计数器必须是以第一个参数为整数倍的地址为尾,在前面记录一个字节长度的信息,信息内容为第二个参数。

.balign 8, 0xde

它的意思就是以当前地址开始,在地址为8的倍数的地址前面(<8的倍数的地址处)写入0xde(1byte)。如果当前地址正好是8的倍数,则没有东西被写入到内存。

那么以此类推,.balignw则表示第二个参数存入的内容长度为一个字长,即16位,所以一般有这样的形式出现:

.balignw 4,0x368d

因为现在填入的内容为16位了,那就存在以下几种情况

1.当前地址没有偏移就满足了以4为倍数的地址

2.当前地址偏移了1个字节就满足了要求

3.当前地址偏移了2个字节就满足了要求

4.当然地址编移了3个字节就满足了要求

当没有偏移的时候,地址中间肯定没有办法填上信息;
当偏移1个字节的时候,地址中间空隙不够,所以写入的数值,是末定义,也就是说,写入的什么值,不清楚;
当偏移为2个字节的时候,地址中间的空隙正好写入半字长的数据,所以就填上了;
当偏移为3个字节的时候,地址中间的空隙大于所要写入的1word数据。手册上给的定义是末定义,我的理解是:这个未定义是指这三个偏移的地址整体的内容是末知的。但是其中必定含有要写入的那个字(2bytes),只是另一个被填充的字节内容不知道而已

所以以此类推,

.balignl,这个指令用来填与一个双字,即内容长度为双字,即4个字节的长度,如果仔细分析一下填入的情况就知道,如果想要0xdeadbeef一定填到当前地址后面某个部分,就一定得是偏移量为16字节才行,这样才能保证在任何情况下,偏移的地址所留的空隙都能填入所要填的内容。

那0xdeadbeef是什么意思呢?类似这样的值很多,像0xabababab,它的作用大概就是为内存做标记,有点儿像个小旗子,放到那里,表示从这个位置往后,就是干什么的内存,这个位置往前,禁止访问。

注:

    1:伪操作是指编译后不会产生机器码的一类指令。在编写汇编(或其它)语言时,有一些环境参数类的信息要告诉计算机(编译器),如程序的起始地址、堆栈区、内存保留区等,就是通过伪指令来表达的,源程序经过编译生成可执行的程序(机器码)后,源程序就完成使命了,程序运行时会按照源程序定义的环境执行指定的操作的。程序运行时会按照源程序定义的环境执行指定的操作的。

     2:(word)两个byte称为一个word,所以字大小应该是16位bit,共两字节; 双字(double word :DWORD 两个字,四个字节,32bit写ARM文件中的规定不同。

阅读(703) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~