zoukankan      html  css  js  c++  java
  • Part3_lesson3---ARM伪指令学习

    1、ARM机器码

    对elf格式的文件进行反汇编可得到相应汇编文件的机器码:

    arm-linux-objdump -D -S start.elf

    机器码的解析,可以参考文件ARM Architecture Reference Manual的The ARM Instruction Set章节。

    2、定义类伪指令

    伪指令前面加上"."号是GNU的一个特点!!

    .global:标明一个全局的符号。

    .data:标明接下来的数据会存放到数据段里面去。即,这是一个数据段。

    那么在数据段当中能够定义什么样的数据呢?

    .ascii:定义一个字符串类型的数据

    .byte:定义一个字节类型的数据

    .word:定义一个字的数据。

    以上在定义数据的时候一定要有一个标号!!如下:

    数据段的起始位置:0x30010084

    equ伪指令类似于C语言中的宏定义

    align主要用来控制对齐:

    没有使用align的情况:

    使用arm-linux-readelf -a start.elf

    使用align的情况:

    3、操作类伪指令

    ldr伪指令与前面的实际的存储器访问指令同名;

    对于mov指令而言,它能够使用的立即数不能够超过二进制的8位。因为它超出了这个长度所以报错了。

    为什么?这个跟mov指令的机器码相关!

    那么大于8位的数,用ldr,如

    ldr r0,=0x1fff   不过ldr也可以用于小于8位的数。

    执行一个反汇编:

    nop指令是一个空操作:

  • 相关阅读:
    静态方法中访问类的实例成员
    静态初始化块
    Java字段初始化的规律
    java中函数重载
    哈姆雷特观后感 一把辛酸泪
    枚举
    验证码
    四则运算
    JAVA输出中+号的作用以及如何使用
    dev控件ASPxComboBox设置ReadOnly="true"后
  • 原文地址:https://www.cnblogs.com/gary-guo/p/5734412.html
Copyright © 2011-2022 走看看