iOS之底层汇编(四)

DS和[address]

  • CPU要读写一个内存单元时,必须要先给这个内存单元的地址,在8086中,内存地址由段地址和偏移地址组成。
  • 8086中有一个DS段寄存器,通常用来存放要访问数据的段地址
    mov bx,1000H
    mov ds,bx
    mov al,[0]
    
    • 上面3条指令的作用将10000H(1000:0)内存数据赋值到al寄存器中
    • mov al,[address]的意思是将DS:address中的内存数据赋值到al寄存器中
    • 由于al是ax的低8位寄存器,所以将一个字节的数据赋值给al寄存器
  • 8086不支持将数据直接送入段寄存器中,即mov ds,1000H是错误的

写几条指令,将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]
执行过程

大小端

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


注意: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指令

数据段

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

练习

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

mov ax,6622H
jmp 0ff0:0100 ;(段地址0ff0 x 16  = ff00  然后加上偏移地址0100 = 10000H)
mov ax,2000H
mov ds,ax
mov ax,[0008]
moc ax,[0002]

计算CS和IP的数值根据iOS之底层汇编(三)的代码段CS和IP

  • 注意IP是增加后执行指令的

你可能感兴趣的:(iOS之底层汇编(四))