【微机原理及接口技术】中断系统

【微机原理及接口技术】中断系统


文章目录

  • 【微机原理及接口技术】中断系统
  • 前言
  • 一、中断概述
    • 中断的基本概念
    • 中断处理过程
  • 二、8086/8088中断系统
    • 中断类型
    • 中断响应过程
    • 中断向量表
    • 内部中断服务程序
  • 总结


前言

本篇文章我们会讲到中断的概述,8086/8088中断系统。


一、中断概述

中断的基本概念

中断:指CPU在执行程序中,被内部或外部的事件所打断,转去执行一段预先安排好的中断服务程序;服务结束后,又返回原来的断点,继续执行原来的程序的过程。

中断系统的功能:

  • 1)能实现中断响应、中断服务及中断返回

  • 2)能实现中断优先权排队
    当多个中断源同时提出中断请求时

  • 3)能实现中断嵌套
    当中断处理过程中,又有新的中断提出请求时

中断处理过程

  • 中断请求
  • 中断判优
  • 中断响应:断点保护(同时标志寄存器保护)、
    关中断、转向中断处理
  • 中断处理:现场保护、中断服务、恢复现场
  • 中断返回:断点恢复(同时标志寄存器恢复)

中断服务是进行数据交换的实质性环节


二、8086/8088中断系统

8086/8088的中断系统采用向量中断机制
能够处理256个中断
用中断向量号0~255区别
可屏蔽中断还需要借助专用中断控制器Intel 8259A实现优先权管理

中断源

  • 引起CPU中断的事件——中断源。常见的中断源有:
    外部设备的请求
    由硬件故障引起的
    实时时钟
    由软件引起的
  • 中断源分为:外部中断(硬件中断)、内部中断(软件中断)
    内部中断:CPU内部执行程序出现异常引起的中断
    外部中断:CPU以外的设备、部件产生的中断
  • 8086/8088的外部中断信号:INTR、NMI
    INTR——可屏蔽中断请求,受IF标志的控制。IF=1时,执行完当前指令后CPU对它作出响应。
    NMI——非屏蔽中断请求,任何时候CPU都要响应此中断请求信号。

中断类型

在这里插入图片描述

中断指令:INT n, INTO, IRET

  • 内部中断
    除法错中断
    指令中断
    溢出中断
    单步中断
  • 外部中断
    非屏蔽中断
    可屏蔽中断

内部中断
内部中断的中断向量号已定

除法错中断:向量号为0
指令中断:向量号为n
其中,断点中断的向量号为3
溢出中断:向量号为4
单步中断:向量号为1

外部中断

非屏蔽中断:向量号为2
外部通过非屏蔽中断NMI请求,必须响应
非屏蔽中断主要用于处理系统的意外或故障
可屏蔽中断:向量号来自中断控制器
外部通过可屏蔽中断INTR请求,由IF控制是否响应;响应时产生INTA*信号
可屏蔽中断主要用于与外设交换数据
IF控制可屏蔽中断的响应

中断标志IF的状态

IF=0:可屏蔽中断不会被响应
关中断、禁止中断、中断屏蔽
系统复位,使IF=0
任何一个中断被响应时,使IF=0
执行指令CLI,使IF=0
IF=1:可屏蔽中断会被响应
开中断、允许中断、中断开放
执行指令STI,使IF=1
执行指令IRET恢复原IF状态

中断响应过程

在这里插入图片描述

例:8086CPU,若NMI、除法错中断和INTR同时产生,则CPU执行完当前指令后对中断请求的检测顺序为( D
A. NMI、除法错中断、INTR B. NMI、INTR、除法错中断
C. INTR、除法错中断、NMI D. 除法错中断、NMI、INTR

中断向量表

  • 中断向量:中断服务程序的入口地址(首地址)
  • 入口地址含有段基址CS和偏移地址IP(32位)
  • 每个中断向量的低字是偏移地址高字是段基址,需占用4个字节
  • 256个中断占用1KB区域,就形成中断向量表
  • 8086/8088中断向量号范围:0H~FFH
  • 8086/8088中断向量表物理地址范围:00000H~003FFH
    在这里插入图片描述
    向量号为n的中断向量物理地址=n×4

内部中断服务程序

  • 编写内部中断服务程序与编写子程序类似
    利用过程定义伪指令PROC/ENDP
    第1条指令通常为开中断指令STI
    最后用中断返回指令IRET
  • 主程序需要调用中断服务程序
    调用前,需要设置中断向量
    利用INT n指令调用中断服务程序

中断向量的读取与设置
读取中断向量
入口参数:AH=35H,
AL=中断类型号(中断向量号)
出口参数:ES:BX=中断向量
设置中断向量
入口参数:AH=25H,
AL=中断类型号(中断向量号),
DS:DX=要设置的中断向量

例:
编写80H号中断服务程序
功能:显示以“0”结尾的字符串
利用显示器功能调用INT 10H
字符串缓冲区首地址为入口参数

;数据段
intoff dw ?
intseg dw ?
intmsg db ‘A Instruction Interrupt !’
db 0dh,0ah,0
;保存中断向量
mov ax,3580h
int 21h
mov intoff,bx;保存偏移地址
mov intseg,es;保存段基地址
;设置中断向量
push ds
mov dx,offset new80h
mov ax,seg new80h
mov ds,ax
mov ax,2580h
int 21h
pop ds
;调用中断服务程序
mov dx,offset intmsg ;入口参数
int 80h
;进入中断服务程序
new80h proc
sti ;开中断
push ax ;保护现场
push bx
push si
;显示字符串
mov si,dx
new1: mov al,[si] ;显示的字符AL
cmp al,0
jz new2
mov bx,0 ;显示的页号和前景色
mov ah,0eh ;功能号
int 10h
inc si
jmp new1
;退出中断服务程序
new2: pop si ;恢复现场
pop bx
pop ax
iret ;中断返回
new80h endp
;主程序结束
mov dx,intoff ;设置80H中断向量
mov ax,intseg
mov ds,ax
mov ax,2580h
int 21h
mov ah,4ch ;返回操作系统
int 21h


总结

到这里这篇文章的内容就结束了,谢谢大家的观看,如果有好的建议可以留言喔,谢谢大家啦

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Mysql疑难报错排查 - Field ‘XXX‘ doesn‘t have a default value

项目场景: 数据库环境 :mysql8; 工程使用:MyBatisPlus 表情况: 问题描述 某一个插入语句使用了 MyBatisPlus 的 save 方法,因为end_time1 end_time2都并没有值,所以在MyBatisPlus默认情况下,…

SQL优化系列-快速学会分析SQL执行效率(下)

1 show profile 分析慢查询 有时需要确定 SQL 到底慢在哪个环节,此时 explain 可能不好确定。在 MySQL 数据库中,通过 profile,能够更清楚地了解 SQL 执行过程的资源使用情况,能让我们知道到底慢在哪个环节。 知识扩展&#xff1…

强化用户登录接口:解决登录接口被攻击导致掉线卡顿!

一、引言 用户登录接口是任何Web应用的核心部分,它负责身份验证和授权流程。然而,这些接口也常常成为黑客攻击的目标,尤其是当涉及到动态请求处理时。动态请求通常指的是根据用户输入生成的请求,这为诸如SQL注入、XSS攻击和CSRF攻…

华为 2024 届实习校园招聘-硬件通⽤(大部分硬件技术工程师岗位适用)/单板开发——第四套

华为 2024 届实习校园招聘-硬件通⽤(大部分硬件技术工程师岗位适用)/单板开发——第四套 部分题目分享,完整版带答案(有答案和解析,答案非官方,未仔细校正,仅供参考)(共12套&#x…

Unity Vuforia

首先在unity2019版本里可以在windows->PackageManager里搜Vuforia EngineAR; (unity2021版本里搜不到) 在官网注册账号: 添加识别图等; 将导出的unitypackage包导入unity中。 unity里导入package之后,新建场景&am…

【CentOS 7】挑战探索:在CentOS 7上实现Python 3.9的完美部署指南

【CentOS 7】挑战探索:在CentOS 7上实现Python 3.9的完美部署指南 大家好 我是寸铁👊 总结了一篇【CentOS 7】挑战探索:在CentOS 7上实现Python 3.9的完美部署指南详细步骤✨ 喜欢的小伙伴可以点点关注 💝 前言 此篇教程只适用于p…

HarmonyOS(二十四)——Harmonyos通用事件之触摸事件

1.触摸事件。 触摸事件是HarmonyOS通用事件的一种事件之一,当手指在组件上按下、滑动、抬起时触发。 名称是否冒泡功能描述onTouch(event: (event?: TouchEvent) > void)是手指触摸动作触发该回调,event返回值见下面TouchEvent介绍。 2. TouchEve…

Ubuntu下安装和配置Redis

目录 1、更新软件包 2、安装Redis 3、启动 Redis临时服务 4、测试Redis服务 5、配置redis服务 6、Redis服务控制命令 1、更新软件包 执行sudo apt-get update更新软件包 sudo apt-get update2、安装Redis 执行sudo apt-get install redis-server 安装命令 sudo apt i…

Apple - Image I/O Programming Guide

翻译自:Image I/O Programming Guide(更新时间:2016-09-13 https://developer.apple.com/library/archive/documentation/GraphicsImaging/Conceptual/ImageIOGuide/imageio_intro/ikpg_intro.html#//apple_ref/doc/uid/TP40005462 文章目录 …

docker网络详解

1. 网络模式 1.1 网络结构 当安装Docker以后,会自动创建三个网络。可以使用docker network ls命令列出这些网络。 $ docker network ls NETWORK ID NAME DRIVER SCOPE 440aefe8afa3 bridge bridge local aa8d6325580f host host …

RAG检索增强生成(1)-大语言模型的外挂数据库

Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks Lewis P, Perez E, Piktus A, et al. Retrieval-augmented generation for knowledge-intensive nlp tasks[J]. Advances in Neural Information Processing Systems, 2020, 33: 9459-9474. RAG结合了信息检…

linux网络 dns域名解析

目录 DNS 域名体系结构 如何实现域名解析 正向解析 反向解析 主从服务器解析 bond 网卡 DNS 是域名系统的简称 域名和ip地址之间的映射关系 互联网中 IP地址是通信的唯一标识 逻辑地址 访问网站 域名 IP地址不好记 域名朗朗上口 好记 域名解析的目的就是为了实现 访…

七天进阶elasticsearch[one]

elasticSearch 概述 Elasticsearch是一个近实时的搜索平台。这意味着,从索引一个文档直到这个文档能够被搜索到有一个很小的延迟(通常是一秒) 集群 一个集群就是由一个或多个节点组织在一起, 它们共同持有你全部的数据&#x…

代码签名证书:软件安全的守护神

在数字化日益普及的今天,软件安全问题愈发受到人们的关注。而在这其中,一个常被提及但可能不为大众所熟知的名词——“代码签名证书”,实际上在软件安全领域扮演着举足轻重的角色。今天,我们就来聊聊代码签名证书对软件安全到底有…

kali扩容

通过wmware虚拟机–>设置–>添加40G容量的硬盘。 ──(root㉿kali)-[~/桌面] fdisk -lDisk /dev/sda: 40 GiB, 42949672960 bytes, 83886080 sectors …

【关于傅里叶变换的一系列问题】

1. 为什么频率分辨率是 f s N \frac{f_s}{N} Nfs​​? 因为采样率 f s {f_s} fs​ 决定了最大频率范围(奈奎斯特频率)。时域信号长度 𝑁决定了频域中的离散点数。DFT对长度为 𝑁的时域信号进行变换,得到…

C++的类和new和delete和菱形继承机制

文章目录 参考虚函数使用虚函数的class结构相关实现源码IDA反编译子类虚表和父类虚表调用函数菱形继承 参考 https://showlinkroom.me/2017/08/21/C-%E9%80%86%E5%90%91%E5%88%86%E6%9E%90/ https://www.cnblogs.com/bonelee/p/17299985.html https://xz.aliyun.com/t/5242?t…

【操作与配置】MySQL安装及启动

【操作与配置】MySQL安装及启动 下载MySQL 进入官网,选择社区版下载 在windows安装 选择不登陆下载 安装MySQL 双击官方安装包 选择“Developer Default”(默认)即可 Execute,安装完成后next TCP/IP端口等,默认即可…

ArrayList集合

Java学习笔记(新手纯小白向) 第一章 JAVA基础概念 第二章 JAVA安装和环境配置 第三章 IntelliJ IDEA安装 第四章 运算符 第五章 运算符联系 第六章 判断与循环 第七章 判断与循环练习 第八章 循环高级综合 第九章 数组介绍及其内存图 第十章 数…

nginx动静分离和反向代理

一、动静分离 动静分离指的是将动态内容和静态内容分开处理。动态内容通常由后端应用程序生成,例如PHP、Python或Node.js,静态内容则包括图片、CSS、JavaScript等文件。 例子: #代理服务器一 server{listen 80;server_name www.dj.com;r…