汇编语言与接口技术
汇编语言与接口技术实验报告

汇编语言与接口技术实验报告学院:信息与电子工程学院专业:班级:学号:姓名:浙江科技学院2012-2013学年第1学期实验1 汇编语言程序设计一、实验目的1. 熟悉MASM 6.11汇编语言程序开发环境。
2. 掌握汇编语言程序的调试方法和常用的调试工具。
二、实验内容1. 安装MASM 6.11。
2. 设在内存中首地址为BLOCK的区域存有一批数据:61H,84H,93H,0C4H,17H,0FFH,52H,2AH。
分别按下列要求编写汇编语言程序:(1) 视该批数据为8位无符号数,采用冒泡法将其按升序排序;(2) 视该批数据为8位有符号数,采用冒泡法将其按升序排序。
三、实验要求1. 根据实验内容编写程序。
2. 上机调试程序。
3. 记录并分析程序运行结果。
五、程序代码1. 8位无符号数冒泡法排序程序如下:.model small.datan dw 8block db 61h,84h,93h,0c4h,17h,0ffh,52H,2ah .stack 60h.code.startupmov ax,@datamov ds,axmov cx,ndec cxloop1: mov dx,cxmov bx,0loop2: mov al,block[bx]cmp al,block[bx+1]jna continuexchg al,block[bx+1]mov block[bx],alcontinue: add bx,1loop loop2mov cx,dxloop loop1.exitend2、8位有符号数冒泡排序程序如下.model small.datan dw 8block db 61h,84h,93h,0c4h,17h,0ffh,52H,2ah .stack 60h.code.startupmov ax,@datamov ds,axmov cx,ndec cxloop1: mov dx,cxmov bx,0loop2: mov al,block[bx]cmp al,block[bx+1]jle continuexchg al,block[bx+1]mov block[bx],alcontinue: add bx,1loop loop2mov cx,dxloop loop1.exitend六、程序运行结果及分析在命令行debug,反汇编找到初始程序入口0017查看cup寄存器的内容实验2 系统中断接口实验一、实验目的1. 熟悉可编程中断控制器8259A的使用方法。
汇编语言与接口技术

把AX(16位)和AL(8位)中的数输出到指定端口
LEA
LEAr16(r16是16位通用寄存器),mem(mem是存储单元)
取有效地址指令
将有效地址(地址偏移值)送到通用寄存器,而不是将存储单元的内容送通用寄存器
LDS
LDSdest,src
装入地址指令
把src操作数所指的内存中连续4个字节单元内容的低16位数据存入dest指定的通用寄存器中,高16位存入DS中
汇编语言与接口技术
指令标识
指令格式
指令注释
指令名称
指令作用
注意点
MOV
MOV dest,src
dest<-src
MOV指令
数据传送
XCHG
XCHG dest,src
dest<->src
交换指令
交换两个操作数
IN
IN累加器,端口
输入指令
把一个字节/字由输入端口传送到AL/AX中
OUT
OUT端口,累加器
LES
LESdest,src
装入地址指令
把src操作数所指的内存中连续4个字节单元内容的低16位数据存入dest指定的通用寄存器中,高16位存入ES中
LAHF/SAHF
标志传送指令
取标志指令(LAHF)用于将标志寄存器的低8位送入AH和存标志指令(SAHF)将AH的内容送入标志寄存器的低8位
XLAT
src为16位寄存器或存储单元
POP
POP dest
栈顶的数据弹出到通用寄存器或存储器中
dest为16位寄存器或存储单元
CBW
字节扩展指令
将AL中的单字节数的符号扩展到AH中。
CWD
汇编语言与接口技术

汇编语言与接口技术汇编语言是一种低级程序设计语言,用于编写微处理器或计算机的机器语言指令。
它提供了直接控制硬件的能力,使得程序员可以更精确地控制计算机的操作。
接口技术则是指计算机系统中各个模块之间的通信和数据交换方式。
汇编语言的优势在于其对硬件的直接控制能力。
使用汇编语言可以充分利用计算机的资源,提高程序运行的效率。
此外,汇编语言可以精确地指定操作,使得程序更加灵活和可靠。
然而,相较于高级编程语言,汇编语言的编写和调试过程较为繁琐,需要具备一定的硬件和底层知识。
在汇编语言中,接口技术是必不可少的。
接口技术是指计算机硬件设备与外部设备或其他硬件设备之间的通信接口。
这些接口可以是物理接口,如端口、插槽、电路等,也可以是逻辑接口,如中断、DMA (直接内存访问)等。
通过接口技术,汇编语言程序可以与其他设备或模块进行数据交换,实现功能的扩展。
接口技术在计算机系统中发挥着重要的作用。
它可以使得各种硬件设备与计算机系统实现有效的沟通与协作。
例如,计算机的外部设备如打印机、鼠标和键盘等都需要通过接口与计算机进行连接,完成数据的输入输出。
此外,接口技术还可以将不同模块之间的数据传递和处理分离,提高系统的可维护性和可扩展性。
汇编语言与接口技术的结合可以带来更强大的功能和性能。
通过汇编语言的直接控制能力,程序员可以更好地优化程序,提高计算机的运行效率。
同时,接口技术可以扩展计算机系统的功能,与其他设备进行数据交换,实现更多的应用场景。
需要注意的是,在编写汇编语言程序时,必须遵循相应的编译与链接规范。
不同的处理器架构和操作系统可能有不同的汇编语言格式和指令集。
因此,程序员需要在了解具体系统的基础上,选择合适的格式来编写程序。
此外,汇编语言的编写过程需要仔细检查和验证,确保程序的正确性和可靠性。
总结而言,汇编语言与接口技术是紧密联系的。
汇编语言提供了直接控制硬件的能力,而接口技术则提供了计算机与其他设备之间的数据传递和交换方式。
汇编语言与接口技术(第三章)

汇编语言的应用场景
总结词
汇编语言在系统级编程、嵌入式系统、操作 系统内核开发等领域具有广泛应用。
详细描述
由于汇编语言具有高度的硬件控制能力,因 此它在系统级编程、嵌入式系统、操作系统 内核开发等领域具有广泛应用。在这些领域 中,程序员需要直接与硬件交互,控制硬件 资源,实现高效的性能优化。此外,汇编语 言在某些特定领域的应用也十分广泛,如加
详细描述
汇编语言是计算机程序设计语言中的一种,它直接对 应于计算机硬件指令集。汇编语言使用助记符来表示 计算机指令,这些助记符通常是英文缩写或简写,例 如MOV表示数据传输,ADD表示加法运算等。由于 汇编语言与机器指令集紧密相关,因此它具有高度的 硬件控制能力,允许程序员直接访问内存、寄存器和 I/O端口等硬件资源。
并行接口
并行接口是一种数据传输方式,它通过多个数据线同时 传输多个数据位。
并行接口的数据传输速率比串行接口快,但需要更多的 数据线,因此成本较高。
并行接口通常用于连接打印机、磁盘驱动器等高速设备, 因为这些设备需要大量数据传输。
并行接口的常见标准包括ECP、EPP和USB。
串行接口
01
02
03
04
01 02 03 04
DMA控制器是计算机中的一个重要组件,它负责管理直接内存访问 操作。
DMA控制器通过接收来自各种设备的DMA请求,并根据优先级和 DMA通道来决定哪个请求应该得到优先处理。
DMA控制器接口是DMA控制器与处理器之间的连接,它负责将 DMA请求传递给处理器,并处理处理器对DMA的处理结果。
数据类型
数据类型是指数据的取值范围和表示方式,包括整型、实型、字 符型等。
汇编语言与接口技术

第 5章
软件接口技术
• VXD
–VXD目的: • 为硬件提供多任务的支持, • 增强操作系统对于硬件设备的适应能力 –VXD中的X是指某类设备 (鼠标的虚拟设备驱动程序称 为VMD,通过VMD就可直接驱动鼠标;键盘的虚拟设备 驱动程序称为VKD )
• VMM
–位于虚拟设备驱动层VXD之上 –用户通过调用Win32的接口API函数,就可以通过VMM获 得系统内核及设备驱动的功能服务
第 5章 软件接口技术
NEAR
3.键盘服务
• 键盘ISR(键盘中断服务程序) INT 09H硬件中断 • 键盘DSR(键盘设备服务程序),INT 16H软件中断 – BIOS键盘服务包括3个子功能:0号功能、1号功能、 2号功能
第 5章
软件接口技术
子功能号 含 AH=0
义
出
口
参
数
从键盘输入一 AL=ASCII码(或0) 个字符 AH=扫描码(或扩展扫描码)
• 包括如下功能:
第 5章
软件接口技术
– – – –
– – – – – – – – –
DriveEnty 驱动程序入口 Dispatch entry point 分发入口 ISR(Interrupt Service Routine) 中断服务程序入口 DPC For ISR/Custom DPC 中断的延迟调用或定制延 迟调用入口 DPC For ISR/Custom DPC 中断的延迟调用或定制延 迟调用入口。 Complete Request 完成例程入口。 Cancel Reinitialize StartIo Unload IoTimer AdapterControl Time Dpc
第 5章 软件接口技术
汇编语言程序设计第五章 接口技术

Intel系列微机系统仅支持I/O独立编址方式。
3. 8086/8088的I/O端口访问
I/O端口地址空间:8086用于寻址外设端口的地址线为16条, 端口最多64K个,端口号为0000H ~ FFFFH。
IBM-PC/XT机在制造中只使用A9~A0 10位地址来表示I/O空间,因 此其I/O端口的地址为000H~3FFH,共1 KB。
个时钟周期采样中断请求输入引脚
三. DMA方式
DMA(Direct Memory Access)方式:是在外部设备和存储 器之间开辟直接的数据传送通路,数据传送不是靠执行I/O指 令,数据不经过CPU内的任何寄存器,也就不破坏任何寄存 器原来的内容,而是在存储器和外部设备之间的通路上直接 传送数据。这种I/O方式的实现主要是靠硬件(DMA控制器) 实现的。
就绪
读状态
N 就绪? Y
数据交换
二. 中断控制方式
CPU在执行程序 中,被内部或外 部的事件所打断, 转去执行一段预 先安排好的中断 服务程序;服务 结束后,又返回 原来的断点,继 续执行原来的程 序
主程序
中断请求 断点
继续执行
中断服务程序
对外设 进行处理
返回断点
中断传送与接口
中断传送是一种效率更高的程序传送方式 中断服务程序是预先设计好的 中断请求是外设随机向CPU提出的 CPU对请求的检测是有规律的:一般是在每条指令的最后一
FFFFF
优点:
对I/O端口的访问命令与对存储器单元访问相同,
不必使用专用I/O指令;
存储器
外设数目或I/O寄存器数几乎不受限制。 系统读写控制逻辑较简单。
空间
缺点:
I/O端口要占去部分存储器地址空间。 程序不易阅读。
汇编语言与接口技术期末复习题(含答案)

c微机原理习题一、选择填空1、CPU执行OUT DX ,AL指令时,()的值输出到数据总线上。
A、AL寄存器B、AX寄存器C、DL寄存器D、DX寄存器2、连接主机与外设间的电路称为()。
A、接口B、端口C、数字电路D、转换电路3、地址译码的作用是()。
A、设计接口B、区分不同外设C、接至地址总线D、向外设输出数据4、中断控制器8259可管理()。
A、非屏蔽中断B、指令中断C、外部中断D、可屏蔽中断5、对INT N指令,其中断向量存放在内存从()开始的地址中。
A、DS*10H+N*4B、DS*10H+NC、0*10H+N*4D、0*10H+N6、8259的中断服务寄存器ISR的某一位如果置1,则表示()。
A、8259中断服务故障B、CPU正在执行中断服务程序C、外部设备可以请求中断服务D、中断服务程序刚执行完毕7、8086/8088CPU内部有一个始终指向堆栈顶部的地址指针是( )。
A、SPB、IPC、BPD、BX8、8086/8088CPU内部地址指针是( )。
A、20位B、8位C、16位D、24位9、8086存储段是存储器的一个逻辑单位,其长度可达()字节A、16KB、64KC、640KD、1M10、对于“未对准好”字,8086CPU需要()个总线周期完成对该字的访问。
A、1B、2C、3D、411、8086/8088能寻址内部存储器的最大地址范围为( )。
A、64KB、512KC、1MD、10M12、除法出错是属于()中断。
A、线路故障B、内部C、INTOD、单步13、中断传送方式下,当外部需要输入输出数据,向CPU发出中断请求信号,由接口电路使( )信号有效,引起中断响应。
A 、HLDAB 、INTRC 、HOLD D 、INTA14、DMA 数据传送,是由( )控制的。
A 、硬件控制器B 、程序C 、CPUD 、外设15、CPU 与外设交换信息时,是通过( )传送外设控制和外设状态信息的。
《微机原理、汇编语言与接口技术》韩晓茹(习题解答全套

地址总线AB是专门用来传送地址的,地址总线总是单向三态的。
控制总线CB用来传送控制信号和时序信号,制总线的传送方向由具体控制信号而定。
1.4衡量微型计算机系统的性能的指标有哪些?
答:衡量微型计算机系统的性能的指标有字长、主频、运算速度和主存容量和存取速度。字长是指微机系统中CPU一次能处理的二进制位数。CPU的主频,即CPU内核工作的时钟频率(CPU Clock Speed)。运算速度是指每秒钟所能执行的指令条数。主存储器容量指内部存储器能存放数据的最大字节数。存取速度指主存完成一次读/写所需要的时间。
2.3简述伪指令“EQU”与“=”之间有什么区别?
解:“EQU”伪指令不能重复定义,而“=”伪指令可以重复定义。
2.4画图说明下列语句分配的存储空间及初始化的数值
(1)FF1DB'0100',2+5,?,'ABC'
(2)FF2DW2 DUP(?),'A','BC',1000H,25H
(3)FF3DB2 DUP(1,2 DUP(2,3),4)
(3)LEA BX, BLOCK
MOV SI, 99*2
MOV AX,[BX+SI]
或:
LEA SI, BLOCK
MOV BX, 99*2
MOV AX,[BX+SI]
2.9已知:(BX)=1200H,(BP)=2400H,(SI)=0100H,(DI)=0200H,(SS)=1000H,(DS)=2000H,(ES)=3000H,变量VAR1对应地址为2000H,试分别指出下列指令中存储器的寻址方式及物理地址。
2.28086/8088 CPU中标志寄存器有哪两类标志?简述各标志位的含义。
(完整版)汇编语言与接口技术习题解答,推荐文档

习题一解答:1.3(1)[0.0000]原=0.0000 [0.0000]反=0.0000 [0.0000]补=0.0000(2)[0.1001]原=0.1001 [0.1001]反=0.1001 [0.1001]补=0.1001(3)[-1001]原=11001 [-1001]反=10110 [-1001]补=101111.4[N]反=1.0101 [N]原=1.1010 [N]补=1.0110 N=-0.10101.5(1)原码运算:比较可知,正数较大,用正数减负数,结果为正反码运算:01010011-00110011=[01010011]反+[-00110011]反=001010011 +[100110011]反=001010011+111001100=000100000补码运算:01010011-00110011=[01010011]补+[-00110011]补=001010011 +[100110011]补=001010011+111001101=000100000(2)原码运算:比较可知,负数较大,用负数减正数,结果为负反码运算:0.100100-0.110010=0.100100+[1.110010]反=0.100100+1.001101=1.110001补码运算:0.100100-0.110010=0.100100+[1.110010]补=0.100100+1.001110=1.1100101.6(1) (11011011)2=(219)10=(001000011001)BCD(2) (456)10=(010*********)BCD(3) (174)8=(124)10=(000100100100)BCD(4) (2DA)16=(730)10=(011100110000)BCD1.7(1)9876H看成有符号数时,默认为负数的补码,转换为十进制数是:-26506(2)9876H看成无符号数时,转换为十进制数是:390301.8(1)98的压缩BCD码为:10011000B(2)98的非压缩BCD码为:0000100100001000B1.9(1)[S1+S2]补=[S1]补+[S2]补=00010110+00100001=00110111,无溢出[S1-S2]补=[S1]补+[-S2]补=00010110+11011111=11110101,无溢出(2)[S1+S2]补=[S1]补+[S2]补=00010110+11011111=11110101,无溢出[S1-S2]补=[S1]补+[-S2]补=00010110+00100001=00110111,无溢出(3)[S1+S2]补=[S1]补+[S2]补=01100100+00011110=10000010,有溢出[S1-S2]补=[S1]补+[-S2]补=01100100+11100010=01000110,无溢出(4)[S1+S2]补=[S1]补+[S2]补=10011100+11100010=01111110,有溢出[S1-S2]补=[S1]补+[-S2]补=10011100+00011110=10111010,无溢出习题二解答:2.1答:8086有哪些寄存器组?各有什么用途?①通用寄存器AX、BX、CX、DX它既可用作16位寄存器,又可将它拆成高、低8位,分别作为两个独立的8位寄存器使用。
《汇编语言与接口专业技术》习题解答第三章

《汇编语言与接口技术》习题解答(第三章)————————————————————————————————作者:————————————————————————————————日期:问题:画图说明下列语句分配的存储空间及初始化的数据值解答:(1)byte_var DB 'ABC',10,10h,'EF',3 DUP(-1,?,3 DUP(4))(2)word_var DW 10h,-5,3 DUP(?)习题3.10‘A ’‘B ’‘C ’1010h ‘E ’‘F ’-1-444...41h 42h 43h 0ah10h 45h 46h ffh -04h 04h 04h3个10h 0FBh FFh ------10h-5??? 3.16 解:mov ah,1 ;只允许输入小写字母int 21hsub al,20h ;转换为大写字母mov dl,almov ah,2int 21h ;显示3.18 解:mov ax, bufXcmp ax, bufYjge donemov ax, bufY done:mov bufZ, ax3.19 解:.model small.stack.data bufXdw -7 signXdb ?.code.startupcmp bufX,0 ;test bufX,80hjl next ;jnz nextmov signX,0jmp donenext: mov signX,-1done: .exit 0end3.20 解:mov dl,’2’mov ax,bufXcmp ax,bufYje next1dec dlnext1: cmp ax,bufZje next2dec dlnext2: mov ah,2int 21h3.22 编制程序完成12H、45H、0F3H、6AH、20H、0FEH、90H、0C8H、57H和34H 等10个字节数据之和,并将结果存入字节变量SUM中(不考虑溢出和进位)。
汇编语言与接口技术

软盘系 统 硬盘系 统
键盘、LED显示器 、CR T 外部设 备 外围设 备 过程通 道 打印机 、绘图仪 、鼠标器 A/D 、 D/A I/O口开关 量 总线 电源 系统软 件 软件 程序设 计语言 机器语 言 汇编语 言 高级语 言(Bas ic 、 For tran 、 C 、 Pas cal)
第1章 微型计算机概述
3、78-81
16位微机
4、81-92
5、93以后
32位微机
64位微机
微型计算机特点
1、功能大大增强 2、可靠性极大提高 3、价格低 4、适应性强—稍变软件 5、周期短 见效快 6、体积小 重量轻 耗电省 7、维护方便
第1章
微型计算机概述
微型计算机分类
• 从技术角度 按位分:4位、 8位、 16位、 32位、64 位等 • 从工艺角度 分为:MOS工艺的通用微处理器—速度慢 功耗小 双极性TTL工艺的位片式—速度快 功耗大 • 按机器组成,分为: 位片式、单片式、多片式
汇编语言与接口技术
目 录
第1章 微型计算机概述 第2章 80X86微处理器
第3章 80X86的指令系统和寻址方式
第4章 80X86汇编语言程序设计
第5章 接口软件技术
第6章 串并行接口技术 第7章 中断和DMA技术
第8章 模/数和数/模转换技术
第9章 高速串行总线
第 1章
微型计算机概述
本章主要内容 微型机系统的概念与基本结构 计算机的软件、硬件、和发展情况。
第1章
微型计算机概述
一般计算机的结构
冯· 诺依曼结构:
•由运算器、控制器、存储器、输入设备和输出设备五 大部分组成 •数据和程序以二进制代码的形式不加区别地存放在存 储器中,存放位置由地址指定,地址码也是二进制形 式 •控制器根据存放在存储器中的指令序列(即程序)工 作,并由一个程序计数器(PC)控制指令的执行。控 制器具有判断能力,能够根据计算结果选择不同的动 作流程
汇编语言与接口技术实验

班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:实验六显示接口实验一、实验目的1. 了解数码管动态显示与静态显示区别2. 掌握数码管动态显示控制原理3. 掌握数码管动态显示编程二、实验原理图6.1 LED数码管显示电路图6.1为实验板数码管显示电路,本实验板所用数码管为共阴极型,需要显示的数据通过74HC573进行锁存。
图中U6是数码管位选锁存器,数据通过数据总线送至U6后,经SEGLE(P27)进行置位实现锁存;U7是数码管段选码输出,段选码通过数据总线送至U7后通过DIGLE(P26)置位进行锁存。
三、实验内容使用定时器T0中断方式设计一个时钟表,用两位数码管分别显示时、分、秒。
1)分析本实验控制原理,画出程序流程图。
2)根据实验要求,编写系统程序,并在实验板上进行调试;班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:四、实验分析及源程序#include "STC/STC15F2K60S2.H"#include <intrins.h>#define uint unsigned int#define uchar unsigned charsbit WEI_LATCH=P2^7;//数码管位选驱动锁存器锁存控制端sbit DUAN_LACTH=P2^6;//数码管段选驱动锁存器锁存控制端sbit LED_LATCH = P2^5;//led驱动锁存器控控制端sbit I2C_SCL = P2^0;sbit I2C_SDA = P2^1;uchar g_sec = 0;//存储秒uchar g_min = 0;//存储分uchar g_hour = 0;//存储小时uint int_time;//定时标志uchar uc_SegTable[] = //段选码{0x3f,0x06,0x5b,0x4f, /* 0、1、2、3 */0x66,0x6d,0x7d,0x07, /* 4、5、6、7 */0x7f,0x6f,0x77,0x7c, /* 8、9、A、B */0x39,0x5e,0x79,0x71, /* C、D、E、F */0x80,0x40,0x00 /* . 、- */};uchar uc_DigTable[] =//位选码{0xfe,0xfd,0xfb,0xf7,班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:0xef,0xdf,0xbf,0x7f};void timer0_init();//定时器0初始化void DisplaySeg(uchar uc_SegDuan,uchar uc_SegWei,uchar uc_PointDisp);//数码管显示函数void Delay();//延时函数void TubeDisplay();//显示时间void main(){timer0_init();//定时器0初始化LED_LATCH = 1;P0 = 0xff;//消除LED干扰LED_LATCH = 0;//E2ReadByte(0x00);while(1){if(TR0 == 1)//时钟正常运行时显示时间TubeDisplay();//将时间显示到数码管}}void timer0_init(){TMOD=0x01;TH0=(65536-50000)/256; //=50000微秒=50毫秒班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:TL0=(65536-50000)%256;EA=1; //开启总中断ET0=1; //打开定时器0中断TR0=1; //打开定时器0}void interserve(void ) interrupt 1{TR0=0; //关闭定时器T0int_time ++;if(int_time==20) //够20次中断,即1秒钟进行一次检测结果采样{int_time=0; //中断次数清0g_sec++; //秒加1if(g_sec==60){g_sec =0; //秒等于60就返回0,分钟金伟g_min++;if(g_min==60)//分等于60就返回0,小时进位{g_min=0;g_hour++;if(g_hour==24)//到24小时清0{g_hour=0;}}}班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:}TH0=(65536-46083)/256; //重新给计数器T0赋初值TL0=(65536-46083)%256;TR0=1; //启动定时器T0}void DisplaySeg(uchar uc_SegDuan,uchar uc_SegWei,uchar uc_PointDisp) {if(1 == uc_PointDisp){/* 将段显示出来*/P0 = uc_SegTable[uc_SegDuan] | 0x80;DUAN_LACTH = 1;DUAN_LACTH = 0;/* 选择某位*/P0 = uc_DigTable[uc_SegWei];WEI_LATCH = 1;WEI_LATCH = 0;}else{/* 将段显示出来*/P0 = uc_SegTable[uc_SegDuan];DUAN_LACTH = 1;DUAN_LACTH = 0;/* 选择某位*/班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:P0 = uc_DigTable[uc_SegWei];WEI_LATCH = 1;WEI_LATCH = 0;}}void Delay()//简单延时函数{uchar uc_Delay = 200;while(uc_Delay--);}void TubeDisplay(){DisplaySeg(g_hour / 10, 0, 0);//显示小时的十位Delay();DisplaySeg(g_hour % 10, 1, 1);//显示小时的个位,带小数点Delay();DisplaySeg(g_min / 10, 2, 0);//显示分的十位Delay();DisplaySeg(g_min % 10, 3, 1);//显示分的个位,带小数点Delay();DisplaySeg(g_sec / 10, 4, 0);//显示秒的十位Delay();DisplaySeg(g_sec % 10, 5, 0);//显示秒的个位,带小数点Delay();}班级:计科143 姓名:张磊学号:20141111095实验成绩:课程:汇编语言与接口技术实验六同组者:肖洋,马畅实验日期:五、实验结果及结论使用定时器T0中断方式设计一个时钟表,用两位数码管分别显示时、分、秒。
汇编语言与接口技术课件 h5-123 微机接口技术

5.2
中断控制
12
5.2.1 基本中断控制方式 中断的概念:当I/O设备需要MPU服务时通过 其接口发出中断请求信号,MPU在收到中断请求 后,中断正在执行的程序,保护断点,转去为相 应外设服务,执行一个相应的中断服务子程序; 中断服务结束,恢复断点,返回原来被中断的程 序继续执行。 特点: I/O设备与MPU并行工作,MPU处于 被动工作方式。 节省MPU时间,提高效率,实时响应。适用 于数据采集、处理和控制系统。 但需中断逻辑电路支持,硬件较复杂。
17
2.中断向量式(硬件):
方法: 菊花链优先级判决;
并行优先级判决 。
特点:由中断源的中断向量转入服务程序, 响应快,但硬件开销大。
18
19
5.2.3 80X86实方式中断 1.中断向量表: 物理地址00000~003FFH处、表长1KB字节的 一块区域; 每个表项占4个字节,存放一个中断向量(中 断服务程序的入口地址); 可存储256个中断向量,中断类型号0~255 (8位)。 每个中断向量的前两个字节为中断服务程序 的入口偏移地址,后两个字节装入的是入口段地 址。 ( P197表5.1 、 表5.2)
5.3 8259A可编程中断控制器
37
5.3 8259A可编程中断控制器
(1)初始化命令字ICW1 (A0=0,标志:D4=1)
(2)初始化命令字ICW2 (A0=1)
26
保护方式中断寻址
27
保护方式下当处理器决定响应本次中断/异常 请求时,执行以下序列操作: ①若中断处理的MPU控制权转换涉及到特权 级改变的话,则当前的SS和ESP这两个寄存器的 内容要压入(系统)堆栈予以保存。 ②标志寄存器EFLAGS的内容也压入此堆栈。 ③TF和IF标志被清除(有些情况IF不清除)。 ④当前的代码段寄存器CS和指令指针EIP的内 容压入堆栈。 ⑤如果中断发生伴随有错误码,则错误码也 被压入堆栈。 保护方式中断与实方式中断的返回方式相似, 均使用IRET或IRETD指令从中断服务程序返回。
汇编语言与接口技术 第1章 基础知识

一个数据的不同含义
31H 数值: 3×16 + 1 = 49 D ASCII码: 字符‘1’ BCD码: 两个十进制数据3、1; 指令操作码: XOR 0FFH 数值 255 无符号数: -127(原码) 带符号数: -1(补码) 指令操作码: JMP 一个数据本身 没有什么性质, 具体是什么值 要看使用者按 照什么规则解 释它!
运算、存储时,位数不足可以进行数据位数扩展;
2013年7月17日星期三 15
1.3.1 数值数据
原码 符号位:0—正,1—负; 数值位:与数据真值相同; 反码 正数: 与原码相同; 负数: 符号位——1; 数值位——真值数值各位取反; 补码 正数: 与原码相同; 负数: 符号位——1; 数值位——真值数值各位取反,末位加1; 2013年7月17日星期三
第1章 基础知识
1.1 微型计算机概述 1.2 汇编语言及特点 1.3 数据表示
2013年7月17日星期三
1
1.1 微型计算机概述
1. 微型计算机系统的层次 2. 微型计算机的发展概况 3. 微型计算机的结构与组成 4. 微型计算机的主要性能指标 5. 微型计算机的应用
2013年7月17日星期三
2013年7月17日星期三 12
1.3 数据表示
1.3.1 数值数据 1.3.2 机器数的运算 1.3.3 字符数据
2013年7月17日星期三
13
数据的分类
按数制分: 十进制(D)、二进制(B)、十六进制(H); 按数据格式分: 真值、机器数; 按小数点位置是否固定分: 定点数(定点小数和定点整数)、浮点数; 按能否表示负数分: 无符号数、有符号数; 字符表示 ASCII码、BCD码(8421码)
汇编语言课件第27章USB接口

1.ISA总线:(Industry Standard Architecture,工业标准体系结构) ISA总线是IBM PC/AT机(CPU是80286)所用的系统 总线经过标准化之后的名称。IEEE将ISA总线作为IEEE P996标准推荐,这是一个16位兼8位的总线标准。 ISA总线具备24根地址总线和16根数据总线以及很 多控制信号。无论PC中使用的微处理器是Pentium、386 、486、或者是AMD产品,只要具有ISA总线插槽,总线 的设计和使用都相同,即执行ISA总线规范的电路称为 ISA总线接口。
27.1 总线简介
27.1.1 主设备与从设备
计算机中的许多设备互联在一起,通过总线(地 址总线、数据总线、控制总线)互相通信。当一个设备 想与另一个设备通信时: 1.它发送的地址信号将该设备与其他设备区别开来 ,这是因为分配给每个设备的地址是唯一的。 2.它还要发送读、写信号表明它的意图。 发起并控制通信过程的设备成为主设备,而负责回 应的设备成为从设备。 在X86PC中,典型的主设备的例子是CPU,内存是典 型的从设备。
27.2 通用串行总线USB概要
B最多支持127台物理设备的连接。 7.占用主机资源(I/O端口地址,中断)少。USB总线及其所连接的设 备只占用相当一台传统设备所需的资源。 B是一种基于信息的协议总线。对总线上传输信息的格式、组织 、应答方式等有一系列的规定,即协议,USB设备必须遵循这些协 议。 B总线采用集中控制,所有的传输都是由位于主机中的USB主控制 器引发的,因此总线上的信息传输不会引起冲突。 B不给系统的电源添加负担。将USB连接到PC并不需要PC的电源 提供大量的电力。每个新接入的设备需要的功率不超过500mW。更 重要的是,USB接口安装在PC机的外部,这就使得设备可自提供电 源,从而将主板要为每个设备提供电源的负担解脱出来。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第 5章
软件接口技术
5.2 DOS系统下的接口调用
• DOS系统是单用户的操作系统DOS系统提 供给用户的编程界面大体有如下几种:
– 裸机层软件开发,利用芯片或板卡(适配器)支持的 寄存器或内存数据区编程。需要用户非常清楚设备的 硬件细节,编程较复杂,但软件实现速度最快。 – BIOS级软件开发,利用BIOS基本输入输出系统所提 供的一些服务功能编程。 – 系统功能级软件开发,利用DOS系统提供的系统功能 编程。
第 5章
软件接口技术
• 接口软件(驱动软件)的功能
– – – – 1.接口初始化 2.分析与检查功能调用 3.完成相关硬件的功能调用 4.异常情况的处理
第 5章
软件接口技术
5.1.2 驱动软件的运行方式
• 1.无条件同步方式 • 2.异步查询方式 • 3.中断方式
第 5章
软件接口技术
• 无条件同步方式
第 5章 软件接口技术
2.视频服务
• INT l0H
– AH寄存器选择视频服务功能 – 待写的字符或像素值一般在AL寄存器中传递。 – 功能调用保存BX、CX、DX及段寄存器的值。其他寄 存器的内容(特别是SI、DI)不保存
– X坐标(列号)在CX(图形功能)中或DL(正文功能) 中传递
– 显示页在BH中传递,显示页从零开始计数
第 5章
软件接口技术
例如:利用BIOS视频服务的AH=0CH子功能实现写 像素点。 – 调用子程序之前,需要用DX保存行号,CX保 存列号,AL保存颜色值,这是0CH子功能要求 的。
WRITINGPIXEL PUSH MOV INT POP WRITINGPIXEL PROC AX AH,0CH 10H AX ENDP
第 5章 软件接口技术
NEAR
3.键盘服务
• 键盘ISR(键盘中断服务程序) INT 09H硬件中断 • 键盘DSR(键盘设备服务程序),INT 16H软件中断 – BIOS键盘服务包括3个子功能:0号功能、1号功能、 2号功能
第 5章
软件接口技术
子功能号 含 AH=0
义
出
口
参
数
从键盘输入一 AL=ASCII码(或0) 个字符 AH=扫描码(或扩展扫描码)
第 5章 软件接口技术
5.1.4 接口软件及层次结构
应用软件
操作系统
驱动软件
硬件层
图5.1接口软件的层次接口
第 5章
软件接口技术
应用软件
应用软件
应用环境
DOS 用户空间 内核空间 设备管理 BIOS 驱动软件
硬件层
硬件层
A)dos系统的调用层次
B) Windows的调用层 次
图5.2 设备调用层次
第 5章 软件接口技术
5.2.1 BIOS功能级软件接口及实现
1.BIOS级软件接口概述 •
BIOS基本输入输出系统由一批子程序组成,负责管
理系统内的输入输出设备
• 直接为DOS操作系统和应用程序提供底层设备驱动服 务。
• 大多数的驱动程序以软件中断方式调用 , 少数由硬件 中断调用。
第 5章
软件接口技术
表5.1 常用BIOS服务功能
BIOS服务
打印屏幕服务 视频服务 软盘服务 硬盘服务 串行通信服务 系统服务 键盘服务 并行打印机服务 日期时间服务
功能号
05H 10H 13H 13H 14H 15H 16H 17H 1AH
功
能
将当前视频页内容送到默认打印机 为显示适配器提供I/O支持 提供软盘的读、写、格式化、初始化、 诊断 提供硬盘的读、写、格式化、初始化、 诊断 为串行适配器提供字符输入/输出 系统级子服务 为键盘提供I/O支持 为并行打印机提供I/O支持 设置和读取时间、日期、声源等
D7
=1,不忙,打印机可用 =1,打印机表示响应 =1,打印机无纸 =1,打印机选中
D6
D5
D4
D3
D2
D1
D0
=1,打印机出现超时错误 未定义 未定义 =1,打印机出错
第 5章
软件接口技术
5.2.2 DOS功能级软件接口及调用实例
AH=1
判断键盘有无 ZF=0 有键按下,键代码保存在 字符输 AX中 ZF=1 无键按下
当前键盘特殊 AL=KB-FLAG的变量 键状态
AH=2
第 5章
软件接口技术
4.并行打印机服务 • INT 17H
–0号功能(给打印机传送—个字符) –1号功能(初始化打印机) –2号功能(读打印机状态) • 均可通过AH返回打印机状态字节
第 5章
软件接口技术
5.1.3 接口缓冲区
• 1.CPU中的通用寄存器
– 适用于交互数据较少的情况,最快、最方便、最简 单可靠的方式。
• 2.公用存储区
– 公用存储区是由外设调用者和外设双方都可寻址的 一块连续内存块,用于双方的数据交互。
• 3.堆栈
– 堆栈是一种后进先出的数据结构。 – 使用堆栈时,要特别注意栈中各个数据项的先后次 序,以及堆栈指针的设置和恢复操作。
第5章 软件接口技术
第 5章
软件接口技术
• 本章的内容有:
– 接口概述 – DOS和Windows下的接口调用方法 – COM编程技术
第 5章
软件接口技术
5.1 接口概述
5.1.1 接口的功能 • 一般来说,由于CPU在与I/O设备进行数 据交换时通常存在:
– – – – 速度不匹配, 时序不匹配, 信息格式不匹配 信息类型不匹配
– 可在任意时刻对硬件进行驱动,不必考虑硬件的接 受能力 – 这只有在硬件的执行速度很快,在任意时机都能响 应驱动软件的驱动控制时才有可能。 – 只在非常简单或速度非常高的系统中才可能存在。
第 5章
软件接口技术
• 异步查询方式
– 驱动程序应该对外设硬件的状态进行查询,在适当 的时机进行硬件功能的驱动或结果的取回。 – 使用异步查询方式时,外设硬件必须能根据硬件的 运行情况,将状态送给驱动程序,以供驱动程序查 询。 – 由于驱动程序必须在程序中反复判断外设的硬件状 态,等待硬件确定工作状态的到来,因此程序的运 行效率不高。
第 5章
软件接口技术
• 中断方式
– 驱动程序分为两个部分 – 第一部分负责对外设硬件的启动驱动,完成之后, 这部分驱动程序就退出运行,CPU转而执行其他的 应用程序 – 第二部分:中断服务程序。透明地窃取应用程序的 极少量执行时间。 – 中断运行方式是效率最高的调用方式,但要求硬件 必须有产生中断源的能力,并且需要占用系统的一 些软、硬件中断控制资源。