iOS逆向-汇编(四)

2017-11-02  本文已影响0人  Stone_熊小叔

DS和[address]


写几条指令,将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

大小端

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指令

数据段

练习

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

上一篇 下一篇

猜你喜欢

热点阅读