美文网首页
iOS逆向4基础篇--汇编指令

iOS逆向4基础篇--汇编指令

作者: hello_iOS程序媛 | 来源:发表于2018-04-22 21:26 被阅读0次

    注意:ARM64开始,取消32位的 LDM,STM,PUSH,POP指令! 取而代之的是ldr\ldp str\stp
    ARM64里面 对栈的操作是16字节对齐的!!

    关于内存读写指令

    注意:读/写 数据是都是往高地址读/写

    str(store register)指令

    将数据从寄存器中读出来,存到内存中.

    ldr(load register)指令

    将数据从内存中读出来,存到寄存器中

    此ldr 和 str 的变种ldp 和 stp 还可以操作2个寄存器.

    堆栈操作练习

    使用32个字节空间作为这段程序的栈空间,然后利用栈将x0和x1的值进行交换.

    sub    sp, sp, #0x20    ;拉伸栈空间32个字节
    stp    x0, x1, [sp, #0x10] ;sp往上加16个字节,存放x0 和 x1
    ldp    x1, x0, [sp, #0x10] ;将sp偏移16个字节的值取出来,放入x1 和 x0
    

    [sp, #-0x10] -- 表示sp减16个字节处的地址

    bl和ret指令

    bl标号

    • 将下一条指令的地址放入lr(x30)寄存器
    • 转到标号处执行指令

    ret

    • 默认使用lr(x30)寄存器的值,通过底层指令提示CPU此处作为下条指令地址!

    ARM64平台的特色指令,它面向硬件做了优化处理的

    x30寄存器存放的是函数的返回地址.当ret指令执行时刻,会寻找x30寄存器保存的地址值!

    注意:在函数嵌套调用的时候.需要x30入栈!


    bl指令 -- 如下指令会导致指令死循环,关于为什么会死循环会在基础篇--函数本质里进行解释.

    _A:
        mov x0,#0xa0
        mov x1,#0x00
        add x1, x0, #0x14
        mov x0,x1
        bl _B
        mov x0,#0x0
        ret
    
    _B:
        add x0, x0, #0x10
        ret
    

    相关文章

      网友评论

          本文标题:iOS逆向4基础篇--汇编指令

          本文链接:https://www.haomeiwen.com/subject/lcqhlftx.html