首页 > 编程语言 >8086 汇编学习 Part 9

8086 汇编学习 Part 9

时间:2024-05-05 09:03:17浏览次数:16  
标签:汇编 8086 中断 RAM 端口 屏蔽 Part CPU CMOS

端口的读写

CPU 的邻居

  1. CPU 内部的寄存器
  2. 内存单元
  3. 端口(各种接口卡、网卡,显卡,主板上的接口芯片等)
  • 各种芯片工作时,都有一些寄存器由 CPU 读写
  • 从 CPU 角度,将各寄存器当端口,并统一编制
  • CPU 用统一的方法与各种设备通信
    屏幕截图 2024 05 03 230106

读写端口的指令

  • 在对 \([0,255]\) 的端口进行读写时,端口号用立即数给出
  • 在对 \([256,65535]\) 的端口进行读写时,端口号放在 DX 中
  • IN 和 OUT 指令中,只能用 AX 或 AL 来存放从端口中读入的数据或要发送到端口的数据。
  • 访问 8 位端口时用 AL ,访问 16 位端口时用 AX

I/O 端口分配

屏幕截图 2024 05 03 230951

IN

功能

CPU 从端口读取数据

格式

IN 数据 , 端口号

执行时与总线相关的操作

  1. CPU 通过地址线将地址信息发出
  2. CPU 通过控制线发出端口读命令,并选中端口所在的芯片,并通知要从中读取数据
  3. 端口所在的芯片将对应端口中的数据通过数据总线送入 CPU

OUT

功能

CPU 往端口写入数据

格式

OUT 端口号 , 数据

CMOS RAM 芯片关于端口读写的操作

CMOS RAM 芯片

  1. 包含一个实时钟和一个有 128 个存储单元的 RAM 存储器
  2. 128 个字节的 RAM 中存储:内部实时钟、系统配置信息、相关的程序(用于开机时配置系统信息)
  3. CMOS RAM 芯片靠电池供电,关机后其内部的实时钟仍可正常工作,RAM 中的信息不丢失
  4. 该芯片内部有两个端口,端口地址为 70H 和 71H,CPU 通过这两个端口读写 CMOS RAM
  5. 70H 地址端口,存放要访问的 CMOS RAM 单元的地址
  6. 71H 数据端口,存放从选定的单元中读取的数据,或要写入到其中的数据
  7. 读取 CMOS RAM 要先将要读取的单元地址送入 70H 地址端口,再从数据端口 71H 读出指定单元的内容

CMOS RAM 中存储的时间信息

内容
地址 00 01 02 03 04 05 06 07 08 09
  • 当前时间在 CMOS RAM 中用 6 个字节存放,用 BCD 码存放
  • 6 个信息的长度都为 1 个字节

外设的连接与中断

CPU 在执行指令过程中,可以检测到发送过来的中断信息,引发中断过程,处理外设的输入。

外中断 :由外部设备发生的事件引起的中断

  • 几乎所有由外设引发的外中断,都是可屏蔽中断
  • 不可屏蔽中断在系统中有必须处理的紧急情况发生时用来 CPU 的中断信息

可屏蔽中断

  • 可屏蔽中断时 CPU 可以不响应的外中断
  • CPU 是否响应可屏蔽中断,要看标志寄存器 IF 位的设置
  • 当 CPU 检测到可屏蔽中断信息时,如果 IF = 1,则 CPU 在执行完当前指令后响应中断,引发中断过程;如果 IF = 0,则不影响可屏蔽中断。

不可屏蔽中断

  • 不可屏蔽中断是 CPU 必须响应的外中断
  • 当 CPU 检测到不可屏蔽中断信息时,则在执行完当前指令后,立即响应,引发中断过程
  • 对于 8086 CPU 不可屏蔽中断的中断类型码固定为 2

外中断处理过程

可屏蔽中断所引发的中断过程

  1. 取中断类型码(可屏蔽中断信息来自于 CPU 外部,中断类型码通过数据总线送入 CPU)
  2. 标志寄存器入栈,IF = 0 , TF = 0(将 IF 置 0 的原因是 :进入中断处理程序后,禁止其他的可屏蔽中断,如果在中断处理程序中需要处理可屏蔽中断,可以用指令将 IF 置 1)
  3. CS 和 IP 入栈
  4. \((IP) = (中断类型码 \times 4)\) ,\((CS) = (中断类型码 \times 4)\)

不可屏蔽中断的中断过程(不必取中断码,固定为2)

  1. 标志寄存器入栈,IF = 0,TF = 0
  2. CS 和 IP 入栈
  3. (IP) = (8) ,(CS) = (0AH)

标签:汇编,8086,中断,RAM,端口,屏蔽,Part,CPU,CMOS
From: https://www.cnblogs.com/AlwaysBeShine/p/18173199

相关文章

  • 内联函数、引用、汇编
    内联函数内联函数是一种特殊的C++函数,编译器会将它的代码直接插入到调用它的位置,而不是像普通函数那样进行函数调用。这可以减少函数调用的开销,从而提高性能。#include<iostream>usingnamespacestd;intfunc(intv1,intv2){ returnv1+v2;}inlineintfunc1......
  • C语言转写成MIPS指令集汇编以及MIPS指令集汇编中函数调用时栈的变化
    一、问候语欢迎你来到我的博客!二、C语言代码分析  这段C语言代码共有3个函数组成。set_array函数传入1个int类型的变量num,并创建了1个int类型临时变量i和1个临时int类型数组array,里面含有10个单位,此函数主要目的是调用compare函数,并将num和i传入该函数中,得到其函数返回值......
  • 统一场理论公式推导和笔记——part6
    三十九,统一场论能量方程1,能量的定义:能量是质点在空间中【或者质点周围空间本身】相对于我们观察者在某个空间范围内【由于时空同一化,也可以说在某一个时间段内】运动的运动量。能量和动量的定义是类似的,反映质点和空间相对于我们观察者的运动程度,所不同的是,动量是矢量,能量是标......
  • 统一场理论公式推导和笔记——part5
    三十七,运动电荷的磁场产生引力场1,匀速直线运动电荷的磁场产生引力场统一场论核心是变化的引力场可以产生电场,反过来,变化的电磁场也可以产生引力场。==》根据爱因斯坦的广义相对论,变化的电磁场确实可以产生引力场,尽管理论上变化电磁场会产生引力场,但由于电磁场的能量相对较小,......
  • 8086 汇编学习 Part 6
    用MUL指令做乘法格式MUL寄存器MUL寄存单元8位乘法16位乘法被乘数(默认)ALAX乘数8位寄存器或内存单元16位寄存器或内存字单元结果AXDX(高位)和AX(低位)模块化程序设计调用子程序:CALL指令返回:RET指令实质流程转移指令,它们都修改......
  • M3位带地址映射和汇编对比
    01.位带概述位带操作简单的说,就是把每个比特膨胀为一个32位的字,当访问这些字的时候就达到了访问比特的目的,比如说GPIO的ODR寄存器有32个位,那么可以映射到32个地址上,我们去访问这32个地址就达到访问32个比特的目的。这样我们往某个地址写1就达到往对应比特位写1......
  • kafka核心概念Broker、Topic、Partition和Replication
    在Kafka中,Broker、Topic、Partition和Replication是四个核心概念,它们各自扮演了不同的角色并共同协作以确保数据的可靠性、可扩展性和高性能。以下是关于这四个概念的详细解释:Broker(代理)*Broker是Kafka集群中的一个节点,负责存储和转发消息。Kafka集群由多个Broker组成。*Brok......
  • 8086 汇编学习 Part 5
    流程转移背景一般情况下指令是顺序地逐条执行的,而在实际中,常需要改变程序的执行流程。转移指令可以控制CPU执行内存中某处代码的指令。可以修改IP,或同时修改CS和IP的指令。分类按转移行为分类段内转移:只修改IP(例如JMPAX)段间转移:同时修改CS和IP(例......
  • 统一场理论公式推导和笔记——part4
    三十二,核力场的定义方程所有的场都可以通过引力场变化而得到。核力场和电磁场一样也可以用引力场的变化来表示。==》这个就非常关键了,万有引力场【简称引力场】,回忆下定义:o点在空间点p处产生的引力场A【数量为a】:a=常数乘以Δn/Δs,A=-gkΔn(R/r)/Ωr² =-gkΔnR/Ω......
  • 41天【代码随想录算法训练营34期】第九章 动态规划part03 (● 343. 整数拆分 ● 96.
    343.整数拆分classSolution:defintegerBreak(self,n:int)->int:dp=[0]*(n+1)dp[2]=1foriinrange(3,n+1):forjinrange(1,i//2+1):dp[i]=max(dp[i],(i-j)*j,dp[i-j]*j)......