《汇编语言》- 读书笔记 - 第13章-int 指令

《汇编语言》- 读书笔记 - 第13章-int 指令

  • 13.1 int 指令
  • 13.2 编写供应用程序调用的中断例程
    • 中断例程:求一 word 型数据的平方
      • 主程序
      • 中断处理程序
      • 执行效果
    • 中断例程:将一个全是字母,以0结尾的字符串,转化为大写
      • 主程序
      • 中断处理程序
      • 执行效果
  • 13.3 对 int、iret 和栈的深入理解
      • 主程序
      • 中断处理程序
      • 分析
      • 执行效果
  • 检测点 13.1
  • 13.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)=要计算的数据。
返回dxax 中存放结果的高 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*4+2],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*4+2],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

在这里插入图片描述

  1. sse 共 9 个字节。把它存进 bx,传给中断处理程序,
    在中断处理程序中我们就是利用它来算出 s 偏移量,来实现循环的。
  2. 从上面的截图可以看出 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*4+2],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 [bp+2],bx	; 分析:1lpret:	pop bp			; 还原寄存器iret 			; 分析:2 【重点】lpend:	nop
; --------------------- 中断处理程序 --------------------
; =======================================================
code ends
end start

分析

  • 分析1. 上面我们从 sp 拿到了栈顶内存地址存到 bp
    这里我们就直接修改这段内存中的偏移量了。当前栈中:[bp, ip, cs, flags]
    注意:这时的 bp 是栈顶,跟栈中备份的那个bp值可不是同一个东西了
    所以修改时使用的是 [bp+2] 指向中断前备份的 IP
  • 分析2. iret 是用来返回原程序,继续执行的。它会从栈中恢复中断前保存的寄存器状态,还原了CS:IP 就能实现继续执行中断前的下一条指令了。
pop IP
pop CS
popf

这里是本节的重点了:欺骗善良无知的iret

  1. 在中断触发前,IP 指向了标号 se 处。(在主程序中我已经计算出了ses之间的偏移)
  2. 中断过程中,会备份当前寄存器:pushf, push cs, push ip
  3. 中断处理程序中:我们在 add [bp+2],bx ; 分析:1 这句修改了栈中备份的IP的值。
    所以iret恢复后其实指向了标号 s,这也就实现了跳回去重新执行的效果。

执行效果

在这里插入图片描述

检测点 13.1

《汇编语言》- 读书笔记 - 检测点 13.1

13.4 BIOS 和 DOS 所提供的中断例程

  1. BIOS(基本输入输出系统)存储在系统板ROM中,包含以下内容:
    • 硬件系统检测初始化程序
    • 外部中断内部中断的中断例程
    • 用于对硬件设备进行I/O操作的中断例程
    • 其他与硬件系统相关的中断例程
  2. DOS操作系统同样提供了中断例程,这些例程是操作系统程序员提供的编程接口
  3. BIOS和DOS提供的中断例程包括许多子程序,它们实现了常见的编程功能。
  4. 程序员可以通过int指令直接调用:BIOSDOS中断例程来完成特定任务。
  5. 硬件设备相关DOS中断例程通常会进一步调用BIOS的中断例程以执行底层硬件操作。

13.5 BIOS 和 DOS 中断例程的安装过程

在8086架构的早期个人计算机系统中,BIOS和DOS中断例程的安装过程并非由用户程序直接执行安装,而是内置于系统的初始化过程中。以下是一个简化的概述:

BIOS中断例程的安装:

  1. 开机后,CPU 一加电,自动从FFFF:0000H地址处开始执行ROM中的代码(即BIOS)。
    (这个位置存放着一条跳转指令,它会跳转到ROM中的实际BIOS启动代码区域。)
  2. BIOS首先进行硬件自检(POST, Power-On Self-Test),检测和初始化硬件设备。
  3. BIOS建立中断向量表,将自身的中断处理程序入口地址填入到中断向量表对应的内存位置。
    (只需要有登记入口地址,因为中断处理程序本身已固化在BIOS的ROM中。)

DOS中断例程的安装:

  1. 硬件自检和初始化完成后,调用 int 19h 进行操作系统的引导。
    1.1. 在BIOSint 19h 中断做出响应时,它首先从硬盘的第一个扇区(即主引导记录MBR)读取512字节的数据到内存特定位置(如0x7C00)。
    1.2. MBR中的前446字节通常是机器码构成的操作系统引导程序(Boot Loader),该引导程序接着会被CPU执行。
    1.3. 引导程序的任务是找到并加载实际的操作系统,例如MS-DOS或更现代的操作系统的核心文件,并将控制权转交给操作系统。
  2. 当DOS启动时,它会接管控制权,并且根据需要重定向某些中断向量,以便调用自己的中断例程来处理特定的服务请求。
  3. 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 start

在这里插入图片描述

13.7 DOS 中断例程应用(INT 21H)

在8086架构下,int 21hDOS操作系统为应用程序提供的一种系统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 中断参考手册

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/267183.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JavaEE】_Spring MVC项目之建立连接

目录 1. Spring MVC程序编写流程 2. 建立连接 2.1 RequestMapping注解介绍 2.2 RequestMapping注解使用 2.2.1 仅修饰方法 2.2.2 修饰类与方法 2.3 关于POST请求与GET请求 2.3.1 GET请求 2.3.2 POST请求 2.3.3 限制请求方法 1. Spring MVC程序编写流程 1. 建立连接&…

TCP为什么要三次握手?

TCP三次握手协议是为了在不可靠的互联网环境中可靠地建立起一个连接,三次握手可以确保两端的发送和接收能力都是正常的。 那么,为什么是三次而不是二次或四次握手呢? 为什么不是二次握手? 如果是二次握手,即客户端发…

Qt5.9.9交叉编译(带sqlite3、OpenSSL)

1、交叉编译工具链 这里ARM平台是ARM CortexA9的,一般交叉编译工具链demo板厂商都会提供,若未提供或想更换新版本的交叉编译工具链可参考以下方式获取。 1.1 下载适用于ARM CortexA9的交叉编译工具链 Linaro Releases下载gcc4的最新版xxxx-i686_arm-li…

蓝桥杯-单片机组基础7-存储器映射扩展与PWM脉冲调制(附小蜜蜂课程代码)

蓝桥杯单片机组备赛指南请查看这篇文章:戳此跳转蓝桥杯备赛指南文章 本文章针对蓝桥杯-单片机组比赛开发板所写,代码可直接在比赛开发板上使用。 型号:国信天长4T开发板(绿板),芯片:IAP15F2K6…

蓝桥杯练习系统(算法训练)ALGO-993 RP大冒险

资源限制 内存限制:64.0MB C/C时间限制:200ms Java时间限制:600ms Python时间限制:1.0s 问题描述 请尽情使用各种各样的函数来测试你的RP吧~~~ 输入格式 一个数N表示测点编号。 输出格式 一个0~9的数。 样例输入 0 样…

设计模式-结构型模式-外观模式

外观模式(Facade),为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。[DP] 首先,定义子系统的各个组件接口和具体实现类: // 子系统组件接…

Linux:gcc的基本知识

gcc 是一个将C语言文件变成可执行文件的工具。 在Linux中,如果需要将一个C语言文件变得可以执行,那么除了这个文件本身的内容是C语言编写的内容外,还需要gcc这个编译工具进行编译才行。 gcc 使用的格式方法:gcc 要编译的文件 //在该代码下…

云天励飞战略投资神州云海,布局机器人市场

日前,AI上市企业云天励飞(688343.SH)完成了对深圳市神州云海智能科技有限公司(以下简称“神州云海”)的B轮战略投资。 公开资料显示,自2015年于深圳创立以来,神州云海始终聚焦人工智能与服务机器人广阔的应用市场,依托自主的核心算法能力,深耕机器人硬件本体研发,整合上下游产…

Linux系统——LAMP架构

目录 一、LAMP架构组成 1.LAMP定义 2.各组件的主要作用 3.CGI和FastCGI 3.1CGI 3.3CGI和FastCGI比较 4.PHP 4.1PHP简介 4.2PHP的Opcode语言 4.3PHP设置 二、LAMP架构实现 1.编译安装Apache httpd服务 2.编译安装Mysql 3.编译安装PHP 4.安装论坛 5.搭建博客 W…

C++基于多设计模式下的同步异步日志系统day2

📟作者主页:慢热的陕西人 🌴专栏链接:C基于多设计模式下的同步&异步日志系统 📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言 主要内容实现了日志代码设计的实…

前端学习第三天-css基础

1. CSS简介 从HTML被发明开始,样式就以各种形式存在。不同的浏览器结合它们各自的样式语言为用户提供页面效果的控制。最初的HTML只包含很少的显示属性。 随着HTML的成长,为了满足页面设计者的要求,HTML添加了很多显示功能。但是随着这些功能…

nginx出现 “414 request-uri too large”

nginx出现 “414 request-uri too large” 1.修改传参方式 POST 2.字段能变成后端获取就自己获取,不用前端传 3.修改nginx配置,添加client_header_buffer_size 512k;large_client_header_buffers 4 512k;配置

机器学习 -- 梯度下降算法加深

梯度下降算法 在机器学习中,梯度下降算法常用于最小化代价函数(或损失函数),以此来优化模型的参数。代价函数衡量的是模型预测值与实际值之间的差异。通过最小化这个函数,我们可以找到模型预测最准确的参数。 代价函…

qt 基于百度API的人脸识别

百度云官网:点击跳转 一、创建应用 跳转进去,可以看到以下界面: 点击红色圈内的“去创建”,创建自己的项目。可以看到以下界面: 输入“应用名称”,并勾选“人脸对比”,还要到页面的最后输入“应…

WPF 滑动条样式

效果图&#xff1a; 浅色&#xff1a; 深色&#xff1a; 滑动条部分代码&#xff1a; <Style x:Key"RepeatButtonTransparent" TargetType"{x:Type RepeatButton}"><Setter Property"OverridesDefaultStyle" Value"true"/&g…

MariaDB MaxScale实现mysql8读写分离

目录 1.MaxScale 是干什么的&#xff1f; 2.MaxScale 实验环境 3.实现数据库主从复制 4.创建用户 1) 创建监控用户 2) 创建路由用户 5.docker 安装MaxScale 6.配置maxscale 使用 maxctrl list servers 命令查看运行状态 查看注册服务 使用 maxctrl list listeners Read-…

k8s单机部署zookeeper

&#xff08;作者&#xff1a;陈玓玏&#xff09; 拉取镜像&#xff1a;docker pull zookeeper&#xff1b;编辑yaml&#xff1a; apiVersion: v1 kind: Service metadata:name: zookeeperlabels:app: zookeeper spec:ports:- name: clientport: 2181protocol: TCPtargetP…

H.266参考软件VTM各版本的性能差异

VTM&#xff08;VVC Test Model&#xff09;&#xff0c;是H.266视频编码标准的参考软件&#xff0c;即是VVC spec.的一种参考实现&#xff0c;代码里包括了H.266的软件编码器和软件解码器实现&#xff0c;代码地址如下&#xff1a; https://vcgit.hhi.fraunhofer.de/jvet/VVCS…

S1---FPGA硬件板级原理图实战导学

视频链接 FPGA板级实战导学01_哔哩哔哩_bilibili FPGA硬件板级原理图实战导学 【硬件电路设计的方法和技巧-哔哩哔哩】硬件电路设计的方法和技巧01_哔哩哔哩_bilibili&#xff08;40min&#xff09; 【高速板级硬件电路设计-哔哩哔哩】 高速板级硬件电路设计1_哔哩哔哩_bil…

外包干了3个月,技术倒退明显...

先说情况&#xff0c;大专毕业&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&#xf…