ios专题老司机iOS开发者iOS逆向工程

汇编(四)

2017-07-12  本文已影响798人  请叫我Hank

DS和[address]

mov bx,1000H
mov ds,bx
mov al,[0]

写几条指令,将al中的数据送入内存单元1000H中

mov bx,1000H
mov ds,bx
mov [0],al

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

写出下面指令执行后寄存器ax,bx,cx中的值

内存
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中的值

内存
mov ax,1000H
mov ds,ax
mov ax,11316
mov [0],ax
mov bx,[0]
sub bx,[2]
mov [2],bx
结果

mov指令

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

add和sub指令

数据段


练习

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

上一篇下一篇

猜你喜欢

热点阅读