美文网首页
iOS逆向-汇编(四)

iOS逆向-汇编(四)

作者: Stone_熊小叔 | 来源:发表于2017-11-02 15:39 被阅读0次

DS和[address]

  • CPU要读写一个内存单元时,必须要先给出这个内存单元的地址,在8086中,内存地址由段地址和偏移地址组成

  • 8086中有一个DS段寄存器,通常用来存放要访问数据的段地址

    mov bx,1000H
    mov ds,bx
    mov al,[0]    al,低八位. [0]一个字节,中括号内部放的偏移地址
    第三句相当于 mov al,ds:[0] 从0这个地址取值
    
    • 上面3条指令的作用将10000H(1000:0)中的内存数据赋值到al寄存器中
    • mov al,[address]的意思将DS:address中的内存数据赋值到al寄存器中
    • 由于al是8位寄存器,所以是将一个字节的数据赋值给al寄存器
  • 8086不支持将数据直接送入段寄存器中,mov ds,1000H是错误的


写几条指令,将al中的数据送入内存单元1000H中
mov bx,1000H
mov ds,bx
mov al,[0]

字型数据的传递(2个字节)

写出下面指令执行后寄存器ax,bx,cx中的值
内存.png
mov ax,1000H
mov ds,ax      
mov ax,[0]
mov bx,[2]
mov cx,[1]
add bx,[1]
add cx,[2]
image.png

大小端

  • 大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中(高低\低高)(Big Endian)
  • 小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中(高高\低低) (Little Endian)
image.png

注意:ARM既可以工作在大端模式,也可以工作在小端模式

练习

写出下面指令执行后寄存器ax,bx,cx中的值
内存.png
mov ax,1000H
mov ds,ax
mov ax,11316
mov [0],ax
mov bx,[0]
sub bx,[2]
mov [2],bx
结果.png

mov指令

mov指令.png

注意:“mov 内存单元, 内存单元”是不允许的,比如mov[0], [1]

add和sub指令

add和sub指令

数据段

  • 对于8086来说,在编程时,可以根据需要,将一组内存单元定义为一个段
  • 我们可以将一组长度为N(N<=64KB)、地址连续、起始地址为16倍数的内存单元当做专门存储数据的内存空间,称为数据段。比如用123B0H ~ 123B9H这段内存空间来存放数据,我们就可以认为123B0H~123B9H是一个数据段,它的段地址为123BH,长度为10字节
  • 如何访问数据段中的数据?
    • 用DS存放数据段的段地址,再根据需要,用相关指令访问数据段中的具体单元

练习

各寄存器的初始值:CS=2000H,IP=0,DS=1000H,AX=0,BX=0;
1.写出CPU执行的指令序列(用汇编指令写出)
2.写出CPU执行完指令后,CS,IP和相关寄存器中的数值
3.再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些又是程序?

相关文章

  • iOS最新逆向进阶文章总汇!

    iOS 逆向 汇编相关iOS逆向:初识汇编[https://www.jianshu.com/p/777373e85...

  • iOS逆向-汇编(四)

    DS和[address] CPU要读写一个内存单元时,必须要先给出这个内存单元的地址,在8086中,内存地址由段地...

  • ARM汇编基础(iOS逆向)

    ARM汇编基础 在逆向一个功能的时候,往往需要分析大量的汇编代码,在iOS逆向中,ARM汇编是必须掌握的语言,本文...

  • ARM汇编基础(iOS逆向)

    ARM汇编基础 在逆向一个功能的时候,往往需要分析大量的汇编代码,在iOS逆向中,ARM汇编是必须掌握的语言,本文...

  • iOS汇编

    iOS逆向之旅(基础篇) — 汇编(一)— 汇编基础[https://www.jianshu.com/p/19a2...

  • IOS 逆向开发(二十一) 汇编-基础

    @[TOC](IOS 逆向开发(二十一) 汇编-基础) 1. 汇编简介 为啥要需要学习汇编? 大学都学习过汇编语言...

  • 逆向 越狱开发知识

    逆向、反汇编、越狱开发 、dylib 1.iOS逆向工程之Theos http://www.cnblogs.com...

  • 1.3 iOS应用逆向工程的工具

    iOS逆向工程的工具分为四大类:监测工具、反汇编工具(disassembler)、调试工具(debugger)、开...

  • iOS逆向

    iOS逆向工程的工具可以分为四大类:监测工具、反汇编工具(disassembler)、调试工具(debugger)...

  • iOS 逆向

    iOS安全攻防了解iOS 逆向, 需要了解汇编的知识Hook 钩子, 勾住某个方法, 从而修改方法的实现 逆向简介...

网友评论

      本文标题:iOS逆向-汇编(四)

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