龙华建设网站,ppt模板免费下载哪个网站好,网站 wap 插件,深圳正能量电子网《汇编语言》- 读书笔记 - 第13章-int 指令 13.1 int 指令13.2 编写供应用程序调用的中断例程中断例程#xff1a;求一 word 型数据的平方主程序中断处理程序执行效果 中断例程#xff1a;将一个全是字母#xff0c;以0结尾的字符串#xff0c;转化为大写主程序中断处理程序… 《汇编语言》- 读书笔记 - 第13章-int 指令 13.1 int 指令13.2 编写供应用程序调用的中断例程中断例程求一 word 型数据的平方主程序中断处理程序执行效果 中断例程将一个全是字母以0结尾的字符串转化为大写主程序中断处理程序执行效果 13.3 对 int、iret 和栈的深入理解主程序中断处理程序分析执行效果 检测点 13.113.4 BIOS 和 DOS 所提供的中断例程13.5 BIOS 和 DOS 中断例程的安装过程BIOS中断例程的安装DOS中断例程的安装 13.6 BIOS 中断例程应用功能 02H 设置光标位置功能 09H 在光标位置显示字符 13.7 DOS 中断例程应用INT 21H功能 4CH返回码方式的终止进程功能 09H输出一个字符串到标准输出设备上 实验 13 编写、应用中断例程参考资料 13.1 int 指令
int n 指令的功能是引发 n 号中断过程从而执行 n号中断处理程序。 系统将一些具有一定功能的子程序以中断处理程序的方式提供给应用程序调用。 我们在编程的时候可以用 int 指令调用这些子程序。 当然也可以自己编写些中断处理程序供别人使用。 以后我们可以将中断处理程序简称为中断例程。
13.2 编写供应用程序调用的中断例程
中断例程求一 word 型数据的平方
问题一编写、安装中断 7ch 的中断例程。功能求一 word 型数据的平方。参数(ax)要计算的数据。返回dx、ax 中存放结果的高 16 位和低 16 位。应用举例求 2*3456^2 16C8000h 23,887,872
主程序
assume cs:code
code segmentstart: mov ax,3456 ; (ax)3456int 7ch ; 调用中断 7ch 的中断例程计算ax中的数据的平方; dx:ax 存放结果将结果乘以2add ax,ax ; 先加低位adc dx,dx ; 再加高位这里用了进位加法; 23887872mov ax,4c00hint 21h
code ends
end start中断处理程序
assume cs:code
code segmentstart: ; 安装 ; ------------------- 复制数据 -------------------mov ax,csmov ds,axmov si,offset sqr ;设置 ds:si 指向源地址mov ax,0mov es,axmov di,200h ;设置 es:di 指向目的地址mov cx,offset sqrend-offset sqr ;设置 cx为传输长度cld ;设置传输方向为正。movsb中si,di递增rep movsb ;重复复制数据次数由 cx 控制; ------------------- 复制数据 -------------------; ----------------- 设置中断向量 -----------------mov ax,0mov es,ax ; 段地址 0mov word ptr es:[7ch*4],200h ; 设置【中断处理程序】的偏移地址mov word ptr es:[7ch*42],0 ; 设置【中断处理程序】的段地址; ----------------- 设置中断向量 -----------------; 安装 mov ax, 4c00H ; 退出int 21H;
; --------------------- 中断处理程序 --------------------
; ax 的平方
; -------------------------------------------------------
; 参数ax 要计算的数据。
; 返回dx、ax 中存放结果的高 16 位和低 16 位。
; -------------------------------------------------------sqr: mul ax ; ax * ax 结果 dx高16位ax低16位iret ; 返回原程序。 pop IP, pop CS, popfsqrend: nop
; --------------------- 中断处理程序 --------------------
;
code ends
end start安装功能跟之前都是一样的只是改下值就行了。中断处理程序也很简单就是一个乘法就返回了。
执行效果 中断例程将一个全是字母以0结尾的字符串转化为大写
问题二编写、安装中断 7ch 的中断例程。功能将一个全是字母以0结尾的字符串转化为大写。参数ds:si指向字符串的首地址。应用举例将 data 段中的字符串转化为大写
主程序
assume cs:code
data segmentdb conversation,0
data endscode segmentstart: mov ax,datamov ds,axmov si,0int 7ch mov ax,4c00hint 21h
code ends
end start中断处理程序
assume cs:code
code segmentstart: ; 安装 ; ------------------- 复制数据 -------------------mov ax,csmov ds,axmov si,offset capital ;设置 ds:si 指向源地址mov ax,0mov es,axmov di,200h ;设置 es:di 指向目的地址mov cx,offset capitalend-offset capital ;设置 cx为传输长度cld ;设置传输方向为正。movsb中si,di递增rep movsb ;重复复制数据次数由 cx 控制; ---------------- 安装(复制数据) ----------------; ----------------- 设置中断向量 -----------------mov ax,0mov es,ax ; 段地址 0mov word ptr es:[7ch*4],200h ; 设置【中断处理程序】的偏移地址mov word ptr es:[7ch*42],0 ; 设置【中断处理程序】的段地址; ----------------- 设置中断向量 -----------------; 安装 mov ax, 4c00H ; 退出int 21H;
; --------------------- 中断处理程序 --------------------
; 将一个全是字母以0结尾的字符串转化为大写。
; -------------------------------------------------------
; 参数ds:si 指向字符串的首地址。
; -------------------------------------------------------capital: push cx ; 备份寄存器push sichange: mov cl,[si] ; 取字符mov ch,0 ; 高位不参与计算置 0 jcxz ok ; 如果取到 0 跳到 ok 循环结束and byte ptr [si],11011111b ; 否则字符转大写inc si ; si 指向下一字符jmp short change; 跳到开头继续循环ok: pop si ; 还原寄存器pop cxiret ; 返回原程序。 pop IP, pop CS, popfcapitalend: nop
; --------------------- 中断处理程序 --------------------
;
code ends
end start没什么新知识点都是之前学过的安装、遍历字符串、字符转大写。
执行效果 13.3 对 int、iret 和栈的深入理解
问题用 7ch 中断例程完成 loop 指令的功能 模拟 loop s参数bx 存 s 到 se 之间的位移 cx 循环次数返回无应用举例在屏幕中间显示80个“!”
主程序
assume cs:code
code segmentstart: mov ax,0b800hmov es,axmov di,160*12 ; 从第16向第一个字符开始正好一行80个字符mov bx,offset s-offset se ; 参数se到s的【位移】 -9mov cx,80 ; 参数循环80次; ES: 当前偏移量 000Eh 23 (-9) 14s: mov byte ptr es:[di],! ; add di,2int 7ch ; 实现 loop s 效果se: nop ; 当前偏移量 0017h 23mov ax,4c00hint 21h
code ends
end start从 s 到 se 共 9 个字节。把它存进 bx传给中断处理程序 在中断处理程序中我们就是利用它来算出 s 偏移量来实现循环的。从上面的截图可以看出 mov byte ptr es:[di],! 这一句被反编译成了两句。 2.1. 先是 ES: 看上去是设置默认数据段的意思 。 2.2. 因为第二句中 MOV BYIE PIR [DI],21 中没有写段地址只写了 [DI]
中断处理程序
assume cs:code
code segmentstart: ; ---------------- 安装(复制数据) ----------------mov ax,csmov ds,axmov si,offset lp ;设置 ds:si 指向源地址mov ax,0mov es,axmov di,200h ;设置 es:di 指向目的地址mov cx,offset lpend-offset lp ;设置 cx为传输长度cld ;设置传输方向为正。movsb中si,di递增rep movsb ;重复复制数据次数由 cx 控制; ---------------- 安装(复制数据) ----------------; ----------------- 设置中断向量 -----------------mov ax,0mov es,ax ; 段地址 0mov word ptr es:[7ch*4],200h ; 设置【中断处理程序】的偏移地址mov word ptr es:[7ch*42],0 ; 设置【中断处理程序】的段地址; ----------------- 设置中断向量 -----------------mov ax, 4c00H ; 退出int 21H ; 触发33号中断;
; --------------------- 中断处理程序 --------------------
; 模拟 loop s 效果
; -------------------------------------------------------
; 参数bx 下一句指令到 s 之间的位移
; 参数cx-1 循环次数
; -------------------------------------------------------lp: push bp ; 备份寄存器mov bp,sp ; 取栈顶所指的内存位置dec cx ; 计数 cx cx-1jcxz lpret ; cx 为 0 就跳出循环add [bp2],bx ; 分析1lpret: pop bp ; 还原寄存器iret ; 分析2 【重点】lpend: nop
; --------------------- 中断处理程序 --------------------
;
code ends
end start分析
分析1. 上面我们从 sp 拿到了栈顶内存地址存到 bp。 这里我们就直接修改这段内存中的偏移量了。当前栈中[bp, ip, cs, flags] 注意这时的 bp 是栈顶跟栈中备份的那个bp值可不是同一个东西了 所以修改时使用的是 [bp2] 指向中断前备份的 IP。分析2. iret 是用来返回原程序继续执行的。它会从栈中恢复中断前保存的寄存器状态还原了CS:IP 就能实现继续执行中断前的下一条指令了。
pop IP
pop CS
popf这里是本节的重点了欺骗善良无知的iret。
在中断触发前IP 指向了标号 se 处。在主程序中我已经计算出了se到s之间的偏移中断过程中会备份当前寄存器pushf, push cs, push ip 。中断处理程序中我们在 add [bp2],bx ; 分析1 这句修改了栈中备份的IP的值。 所以iret恢复后其实指向了标号 s这也就实现了跳回去重新执行的效果。
执行效果 检测点 13.1
《汇编语言》- 读书笔记 - 检测点 13.1
13.4 BIOS 和 DOS 所提供的中断例程
BIOS基本输入输出系统存储在系统板的ROM中包含以下内容 硬件系统的检测和初始化程序外部中断和内部中断的中断例程用于对硬件设备进行I/O操作的中断例程其他与硬件系统相关的中断例程 DOS操作系统同样提供了中断例程这些例程是操作系统向程序员提供的编程接口。BIOS和DOS提供的中断例程包括许多子程序它们实现了常见的编程功能。程序员可以通过int指令直接调用:BIOS或DOS的中断例程来完成特定任务。与硬件设备相关的DOS中断例程通常会进一步调用BIOS的中断例程以执行底层硬件操作。
13.5 BIOS 和 DOS 中断例程的安装过程
在8086架构的早期个人计算机系统中BIOS和DOS中断例程的安装过程并非由用户程序直接执行安装而是内置于系统的初始化过程中。以下是一个简化的概述
BIOS中断例程的安装
开机后CPU 一加电自动从FFFF:0000H地址处开始执行ROM中的代码即BIOS。 这个位置存放着一条跳转指令它会跳转到ROM中的实际BIOS启动代码区域。BIOS首先进行硬件自检POST, Power-On Self-Test检测和初始化硬件设备。BIOS建立中断向量表将自身的中断处理程序 的入口地址填入到中断向量表对应的内存位置。 只需要有登记入口地址因为中断处理程序本身已固化在BIOS的ROM中。
DOS中断例程的安装
硬件自检和初始化完成后调用 int 19h 进行操作系统的引导。 1.1. 在BIOS对 int 19h 中断做出响应时它首先从硬盘的第一个扇区即主引导记录MBR读取512字节的数据到内存特定位置如0x7C00。 1.2. MBR中的前446字节通常是机器码构成的操作系统引导程序Boot Loader该引导程序接着会被CPU执行。 1.3. 引导程序的任务是找到并加载实际的操作系统例如MS-DOS或更现代的操作系统的核心文件并将控制权转交给操作系统。当DOS启动时它会接管控制权并且根据需要重定向某些中断向量以便调用自己的中断例程来处理特定的服务请求。DOS通常会保留一部分中断向量用于调用原始的BIOS服务同时提供额外的中断服务例程以支持文件操作、磁盘读写等功能。
总之在8086环境下BIOS和DOS中断例程的安装是指在系统启动阶段由固件和操作系统自动完成中断向量表的填充和设置而不是程序员手动安装的过程。
《汇编语言》- 读书笔记 - 检测点 13.2.
13.6 BIOS 中断例程应用
功能 02H 设置光标位置
INT 10H显示服务 Video Service功能02H设置光标位置参数AH调用 02H 号子程序 BH显示页码 DH行(Y坐标) DL列(X坐标)返回无
assume cs:code
code segmentstart: mov ah,2 ; 设置光标位置mov bh,0 ; 显示页码第0页mov dh,5 ; dh 中放行号mov dl,12 ; dl 中放列号int 10hok: mov ax,4c00hint 21h
code ends
end start功能 09H 在光标位置显示字符
INT 10H显示服务 Video Service功能09H在当前光标处按指定属性显示字符参数AH功能号 09H AL字符内容BH显示页码BL颜色属性 CX字符重复个数返回无
assume cs:code
code segmentstart: mov ah,2 ; 设置光标位置mov bh,0 ; 显示页码第0页mov dh,5 ; dh 中放行号mov dl,12 ; dl 中放列号int 10hmov ah,9 ; 在光标位置显示字符mov al,a ; 字符内容mov bl,11001010b ; 颜色属性mov bh,0 ; 显示页码mov cx,20 ; 字符重复个数int 10hok: mov ax,4c00hint 21h
code ends
end start13.7 DOS 中断例程应用INT 21H
在8086架构下int 21h是DOS操作系统为应用程序提供的一种系统API。 通过调用int 21h并设置不同的AH寄存器值程序员可以请求执行多种操作如文件操作、设备I/O、内存管理等。 这些中断服务例程相当于DOS系统的函数库使得应用程序能够与操作系统进行交互和访问底层资源。
功能 4CH返回码方式的终止进程
INT 21HDOS 中断例程功能 4CH终止程序的执行并可返回一个代码参数AH功能号 4CH AL返回值返回无
mov ah,4ch ; 调用 4ch 号功能
mov al,00h ; 返回值
int 21h功能 09H输出一个字符串到标准输出设备上
INT 21HDOS 中断例程功能09H输出一个字符串到标准输出设备上。待显示的字符串以$作为其结束标志参数AH功能号09H DS:DX待输出字符的地址返回无
assume cs:code
data segmentdb Welcome to masm,$
data endscode segmentstart: mov ah,2 ; 设置光标位置mov bh,0 ; 第0页显示mov dh,5 ; dh 中放行号mov dl,12 ; dl 中放列号int 10hmov ax,datamov ds,axmov dx,0 ;ds:dx指向字符串的首地址 data:0mov ah,9int 21hok: mov ax,4c00hint 21h
code ends
end start实验 13 编写、应用中断例程
《汇编语言》- 读书笔记 - 第13章-实验13编写、应用中断例程
参考资料
DOS 中断参考手册