iOS之底层汇编(五)

编写一个完整的汇编语言

  • 汇编语言由2类指令组成

    assume cs:code
    code segment
      mov ax,1122H
      mov bx,3344H
      add ax,bx
    
      mov ah,4cH
      int 21H
    code ends
    end
    
    • 汇编指令
      如mov、add、sub等
      有对应的机器指令,可以被编译为机器指令,最终被CPU执行
    • 伪指令
      如assume、segment、ends、end等
      没有对应的机器指令,由编译器解析,最终不被CPU执行
  • 注释以分号开头


    汇编注释

伪指令 - segment,ends,end

assume cs:code
code segment
  mov ax,1122H
  mov bx,3344H
  add ax,bx

  mov ah,4cH
  int 21H
code ends
end
  • segment和ends的作用是定义一个段,segment代表一个段的开始,ends代表一个段的结束,使用格式为
段名 segment
     :
段名 ends
  • 一个有意义的汇编程序中,至少要有一个段作为代码段存放代码
  • assume
    • 将用作代码段的code段和CPU中的CS寄存器关联起来
  • end
    • 编译遇到end是,就结束对源程序的编译
  • 下面2句代码的作用是退出程序
mov ah,4cH
int 21H
  • 也可以写成
mov ax,4c00H
int 21H

中断

  • 中断
    • 中断是由于软件的或硬件的信号,使得CPU暂停当前的任务,转而去执行另一段子程序
      -也就是说,在程序运行过程中,系统出现了一个必须由CPU立即处理的情况,此时,CPU暂时终止当前程序的执行转而处理这个新事件的过程就叫做中断
  • 中断的分类
    • 硬中断(外中断),由外部设备(比如网卡、硬盘)随机引发的,比如当前网卡收到数据包的时候,就会发出一个中断
    • 软中断(内中断),由执行中断指令产生的,可以通过程序控制触发

从本质上来讲,中断是一种电信号,当设备有某种事件发生时,它就会产生中断,通过总线把电信号发送给中断控制器。如果中断的线是激活的,中断控制器就把电信号发送给处理器的某个特定引脚。处理器于是立即停止自己正在做的事,跳到中断程序的入口点,进行中断处理。

中断过程
  • 可以通过int n产生中断
    • n是中断码,内存中有一张中断向量表,用来存放中断码对应的中断处理程序的入口地址
    • CPU在接收到中断信号后,暂停当前正在执行的程序,跳转到中断码对应的中断向量表地址处,去执行中断处理程序
  • 常见中断(中断向量表)
    • int 10H用于执行BIOS中断
    • int 3是"断点中断",用于调试程序
    • int 21H用于执行DOS系统功能调用,AH寄存器存储功能号

DOS系统功能调用

  • DOS系统功能调用
    • 由DOS提供的一组实现特殊功能的子程序供程序员在编写自己的程序时调用,以减轻编程的工作量
    • 涉及屏幕显示、文件管理、I/O管理等等
    • 每个子程序 都有一个功能号,所有的功能调用的格式都是一致的。调用的步骤大致如下
      • 系统功能号送到寄存器AH中
      • 入口参数送到指定的寄存器中
      • 用int 21H指令执行功能调用
      • 根据出口参数分析功能调用执行情况
;----数据段----
data segment
    string db 'Hello World!$'
data ends
mov ax,data
mov ds,ax   ;设置ds为数据段

mov ah,9H   ;功能号9H代表在屏幕显示字符串
mov dx,offset string   ;ds:  dx代表字符串地址
int 21H  ;执行DOS系统功能调用

emu8086常用快捷键

  • F5:调试运行
  • F4:重新加载
  • F8:下一步(单步执行)
  • F9:直接一步到位运行整个程序
  • Ctrl + F8:跳过前面代码,断点到单击选中的代码那行



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