已阅读5页,还剩24页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
.微机系统实验报告班 级: 031214 学 号: 03121370 姓 名: 孔玲玲 地 点: E-II-312 时 间: 第二批 ;.实验一 汇编语言编程实验一、实验目的(1) 掌握汇编语言的编程方法(2) 掌握DOS功能调用的使用方法(3) 掌握汇编语言程序的调试运行过程二、实验设备PC机一台。三、实验内容(1) 将指定数据区的字符串数据以ASCII码形式显示在屏幕上,并通过DOS功能调用完成必要提示信息的显示。(2) 在屏幕上显示自己的学号姓名信息。(3) 循环从键盘读入字符并回显在屏幕上,然后显示出对应字符的ASCII码,直到输入“Q”或“q”时结束。(4) 自主设计输入显示信息,完成编程与调试,演示实验结果。考核方式:完成实验内容(1)(2)(3)通过, 完成实验内容(4)优秀。实验中使用的DOS功能调用: INT 21H表3-1-1 显示实验中可使用DOS功能调用AH 值功 能调 用 参 数结 果1键盘输入并回显AL=输出字符2显示单个字符(带Ctrl+Break检查)DL=输出字符光标在字符后面6显示单个字符(无Ctrl+Break检查)DL=输出字符光标在字符后面8从键盘上读一个字符AL=字符的ASCII码9显示字符串DS:DX=串地址,$为结束字符光标跟在串后面4CH返回DOS系统AL=返回码四、实验步骤(1) 运行QTHPCI软件,根据实验内容编写程序,参考程序流程如图3-1-1所示。(2) 使用“项目”菜单中的“编译”或“编译连接”命令对实验程序进行编译、连接。(3) “调试”菜单中的“进行调试”命令进入Debug调试,观察调试过程中数据传输指令执行后各寄存器及数据区的内容。按F9连续运行。(4) 更改数据区的数据,考察程序的正确性。5、 实验程序DATA SEGMENTBUFFER DB 03121370konglingling:,0AH,0DH,$BUFFER2 DB aAbBcC,$BUFFER3 DB 0AH,0DH,$DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AXmov ah,09hmov DX,OFFSET BUFFERint 21hMOVSI,OFFSET BUFFER2lab1:cmp BYTE PTR SI,$je lab2MOVAL,DS:SIANDAL,0F0H;取高4位MOVCL,4SHRAL,CLCMPAL,0AH;是否是A以上的数JBC2ADDAL,07HC2:ADDAL,30HMOVDL,AL;show character MOVAH,02HINT21HMOVAL,DS:SIANDAL,0FH;取低4位CMPAL,0AHJBC3ADD AL,07HC3:ADDAL,30HMOVDL,AL;show character MOVAH,02HINT21Hadd SI,1jmp lab1lab2:mov ah,09hmov DX,OFFSET BUFFER3int 21hmov ah,01hint 21hcmp al,qje lab3mov BL,ALANDAL,0F0H;取高4位MOVCL,4SHRAL,CLCMPAL,0AH;是否是A以上的数JBC4ADDAL,07HC4:ADDAL,30HMOVDL,AL;show character MOVAH,02HINT21HMOV AL,BLANDAL,0FH;取低4位CMPAL,0AHJBC5ADD AL,07HC5:ADDAL,30HMOVDL,AL;show character MOVAH,02HINT21Hjmp lab2lab3:mov ah,4chint 21hCODE ENDSend START6、 实验结果实验二 数码转换实验一、实验目的(1) 掌握不同进制数及编码相互转换的程序设计方法。(2) 掌握运算类指令编程及调试方法。(3) 掌握循环程序的设计方法。二、实验设备PC机一台。三、实验内容及说明(1) 重复从键盘输入不超过5位的十进制数,按回车键结束输入;(2) 将该十进制数转换成二进制数;结果以2进制数的形式显示在屏幕上;(3) 如果输入非数字字符,则报告出错信息,重新输入;(4) 直到输入“Q”或q时程序运行结束。(5) 键盘输入一字符串,以空格结束,统计其中数字字符的个数,并在屏幕显示。考核方式:完成实验内容(1)(2)(3)(4)通过, 完成实验内容(5)优秀。转换过程参考流程如图3-2-2所示。十进制数可以表示为:Dn*10n+Dn-1*10n-1+D0*100=S Di*10i其中Di代表十进制数1、2、3、9、0。上式可以转换为:S Di*10i=(Dn*10+Dn-1)*10+ Dn-2)*10+ D1)*10+ D0由上式可归纳出十进制数转换为二进制数的方法:从二进制数的最高位Dn开始做乘10加次位的操作。依此类推,则可求出二进制数结果。表3-3-1 数码转换对应关系十六进制BCD码二进制机器码ASCII码七段码共阳共阴00000000030H40H3FH10001000131H79H06H20010001032H24H5BH30011001133H30H4FH40100010034H19H66H50101010135H12H6DH60110011036H02H7DH70111011137H78H07H81000100038H00H7FH91001100139H18H67HA10141H08H77HB101142H03H7CHC110043H46H39HD110144H21H5EHE111045H06H79HF111146H0EH71H4、 实验程序;PAGE60,132;本实验将输入的ASCII码转换为二进制,要求输入位数小于5DATASEGMENTMES DB0AH,0DH,The Ascii code of Decimal code are: $MSG1 DB 0AH,0DH,0AH,0DH,0AH,0DH,Please Input(Exit:q/Q):$MSG2 DB 0AH,0DH,Input: $MSG3 DB 0AH,0DH,Input Error, Please input again!,0AH,0DH,$;BIN DB 2 DUP(0)BUFDB30H,30H,30H,31H,35HDB10H DUP(0)NDW0DATAENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOVAX,DATAMOVDS,AXMOVES,AXMOV DI,OFFSET BUFCLCMOV DX,OFFSET MSG1 MOV AH,09H ;显示字符串 INT 21H MOVDX,OFFSET MSG2MOVAH,09HINT21HA1: MOVAH,01H;接收键盘输入INT21HCMP AL,Q JZ EXIT CMP AL,q JZ EXIT CMP AL,39HJA ERRORINCNSTOSB;将输入数据存放在BUF缓冲区中CMPAL,13JNEA1MOVCX,NDECCXMOV BX,000AHMOV SI,OFFSET BUFMOVAH,0MOVDX,0LODSBCMPCX,1JEA3SUB AL,30H;将BUF中数据转换为二十进制数DECCXA2:IMUL BXMOVDX,AXLODSBMOVAH,0A3:SUB AL,30HADDAX,DXLOOP A2MOV SI,AXMOVDX,OFFSET MESMOVAH,09HINT21HINCSI;显示高字节CALLSHOWDECSI;显示低字节CALLSHOWMOV N,0 LOOP STARTSHOWPROCNEARMOVAL,DS:SIANDAL,0F0H;取高4位MOVCL,4SHRAL,CLCMPAL,0AH;是否是A以上的数JBC2ADDAL,07HC2:ADDAL,30HMOVDL,AL;show character MOVAH,06HINT21HMOVAL,DS:SIANDAL,0FH;取低4位CMPAL,0AHJBC3ADD AL,07HC3:ADDAL,30HMOVDL,AL;show character MOVAH,06HINT21HRETSHOWENDPEXIT: MOV AX,4C00H INT 21H ERROR: MOVDX,OFFSET MSG3MOVAH,09HINT21HJMP START CODE ENDS END START5、 实验结果实验三 基本IO口扩展实验一、实验目的了解TTL芯片扩展简单I/O口的方法,掌握数据输入输出程序编制的方法。二、实验内容说明74LS244是一种三态输出的8总线缓冲驱动器,无锁存功能,当G为低电平时,Ai信号传送到Yi,当为高电平时,Yi处于禁止高阻状态。其引脚图如下:74LS273是一种带清除功能的8D触发器, 1D8D为数据输入端,1Q8Q为数据输出端,正脉冲触发,低电平清除,常用作8位地址锁存器。其引脚图如下:本实验要求用74LS244作为输入口,读取开关状态,并将此状态通过74LS273连接到发光二极管显示。具体实验内容如下:(1) 当开关Yi为低电平时对应的发光二极管点亮,Yi为高电平时对应的发光二极管灭。(2) 当开关Yi全为高电平时,发光二极管Qi从左至右轮流点亮。(3) 当开关Yi全为低电平时,发光二极管Qi从右至左轮流点亮。(4) 自主设计控制及显示模式,完成编程调试,演示实验结果。 编程方法见IO(样例程序).txt.(在编译环境下程序名后缀为.asm且不能含有汉字)考核方式:完成实验内容(1)(2)(3)通过。 完成实验内容(4)优秀三、实验原理图图3-2-1 74LS244与74LS273扩展I/O口原理图实验连线图:图3-2-2 扩展I/O口连线图四、实验步骤(1)实验连线: 244的CSISA总线接口模块的0000H,Y7Y0开关K1K8。 273的CSISA总线接口模块的0020H,Q7Q0发光二极管L1L8。 该模块的WR、RD分别连到ISA总线接口模块的IOWR、IORD。 该模块的数据(AD0AD7)连到ISA总线接口模块的数据(LD0LD7)。(2)编写实验程序,编译链接,运行程序(3)拨动开关,观察发光二极管的变化。五、实验程序1、笨方法实现(主要代码):START: MOV AX,MY_DATA MOV DS,AX MOV AX,MY_STACK MOV SS,AX LOP: MOV DX,0DF00H IN AL,DX CMP AL,00H JE C0 CMP AL,0FFH JE C3 ;JE EXIT MOV DX,0DF20H OUT DX,AL JMP LOPC0: MOV AL,0FEH JMP C1 C3: MOV AL,07FH JMP C2 C1: ;ROL AL,1 ;MOV DX,0DF20H ;OUT DX,AL ;CALL DELAY ;CALL BREAK ;JE C1 ;CMP AL,0FEH ;JE EXIT ;JMP C1 ;MOV AL,0FCH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FDH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FBH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0F7H MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0EFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0DFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0BFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,07FH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK CALL DELAY CALL BREAK JMP LOP ;CALL DELAY ;CALL BREAK IN AL,DX CMP AL,080H JMP EXIT C2:MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0BFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0DFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0EFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0F7H MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FBH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FDH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FEH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK MOV AL,0FFH MOV DX,0DF20H OUT DX,AL CALL DELAY CALL BREAK CALL DELAY CALL BREAK JMP LOP IN AL,DX CMP AL,080H JMP EXIT EXIT: MOV AH,4CH INT 21H2、 循环左移右移实现:主要代码:(1)右移:LOP: MOV DX,0DF00H IN AL,DX CMP AL,0FFH JE C0 ;JE EXIT MOV DX,0DF20H OUT DX,AL JMP LOPC0: MOV AL,07FH JMP C1 C1: ROR AL,1 MOV DX,0DF20H OUT DX,AL CALL DELAY call break ;CMP AL,0FEH ;JE EXIT JMP C1 IN AL,DX CMP AL,080H JMP EXIT(2)循环左移:LOP: MOV DX,0DF00H IN AL,DX CMP AL,00H JE C0 ;JE EXIT MOV DX,0DF20H OUT DX,AL JMP LOPC0: MOV AL,0FEH JMP C1 C1: ROl AL,1 MOV DX,0DF20H OUT DX,AL CALL DELAY call break ;CMP AL,0FEH ;JE EXIT JMP C1 IN AL,DX CMP AL,080H JMP EXIT实验四 可编程并行接口8255实验一、实验目的了解可编程并行接口芯片8255的内部结构、工作方式、初始化编程及应用。二、实验内容(1) 流水灯实验:利用8255的A口、B口循环点亮发光二极管。(2) 交通灯实验:利用8255的A口模拟交通信号灯。(3) I/O输入输出实验:利用8255的A口读取开关状态,8255的B口把状态送发光二极管显示。(4) 通过开关控制交通红绿灯的亮灭。(5) 通过开关控制流水灯的循环方向和循环方式。 考核方式:完成实验内容(1)(2)(3)其中之一通过,完成实验内容(4)或(5)优秀。三、实验说明1、8255A的内部结构(1)数据总线缓冲器:这是一个双向三态的8位数据缓冲器,它是8255A与微机系统数据总线的接口。输入输出的数据、CPU输出的控制字以及CPU输入的状态信息都是通过这个缓冲器传送的。(2)三个端口A,B和C:A端口包含一个8位数据输出锁存器和缓冲器,一个8位数据输入锁存器。B端口包含一个8位数据输入/输出锁存器和缓冲器,一个8位数据输入缓冲器。C端口包含一个8位数据输出锁存器及缓冲器,一个8位数据输入缓冲器(输入没有锁存器)。(3)A组和B组控制电路:这是两组根据CPU输出的控制字控制8255工作方式的电路,它们对于CPU而言,共用一个端口地址相同的控制字寄存器,接收CPU输出的一字节方式控制字或对C口按位复位字命令。方式控制字的高5位决定A组工作方式,低3位决定B组的工作方式。对C口按位复位命令字可对C口的每一位实现置位或复位。A组控制电路控制A口和C口上半部,B组控制电路控制B口和C口下半部。(4)读写控制逻辑:用来控制把CPU输出的控制字或数据送至相应端口,也由它来控制把状态信息或输入数据通过相应的端口送到CPU。2、8255A的工作方式方式0基本输入输出方式;方式1选通输入输出方式;方式2双向选通输入输出方式图6-3-1 8255方式1的状态字 图6-3-2 8255 方式2的状态字。3、8255A的状态字4、8255A的控制字表6-3-3 8255A方式控制字1D6D5D4D3D2D1D0特征位A组方式00=方式0 01=方式11X=方式2A口0=输出1=输入C口高4位0=输出1=输入B组方式0=方式01=方式1B口0=输出1=输入C口低4位0=输出1=输入表6-3-4 按位置位/复位控制字0D6D5D4D3D2D1D0特征位不用位选择000=C口0位111=C口7位0=复位1=置位四、实验原理图图6-3-5 可编程并行接口8255电路五、实验步骤1、流水灯实验(1) 实验连线 该模块的WR、RD分别连到ISA总线接口模块的IOWR、IORD。 该模块的数据(AD0AD7)、地址线(A0A7)分别连到ISA总线接口模块的数据(LD0LD7)、地址线(LA0LA7)。 8255模块选通线CE连到ISA总线接口模块的0000H。 8255的PA0PA7连到发光二极管的L0L7;8255的PB0PB7连到发光二极管的L8L15。(2) 运行程序,观察发光二极管。图6-3-6 流水灯实验2、交通灯实验(1) 实验连线: 该模块的WR、RD分别连到ISA总线接口模块的IOWR、IORD。 该模块的数据(AD0AD7)、地址线(A0A7)分别连到ISA总线接口模块的数据(LD0LD7)、地址线(LA0LA7)。 8255模块选通线CE连到ISA总线接口模块的0000H。 8255的PA0-L7、PA1-L6、PA2-L5、PA3-L3、PA4-L2、PA5-L1。(2)运行程序,观察发光二极管。图6-3-7 交通灯实验3、I/O输入输出实验(1) 实验连线 该模块的WR、RD分别连到ISA总线接口模块的IOWR、IORD。 该模块的数据(AD0AD7)、地址线(A0A7)分别连到ISA总线接口模块的数据(LD0LD7)、地址线(LA0LA7)。 8255模块选通线CE连到ISA总线接口模块的0000H。 8255的PA0PA7接开关K0K7,8255的PB0PB7接发光二极管L0L7。图6-3-8 I/O输入输出实验(2) 运行程序,拨动开关,观察发光二极管。6、 实验程序主要程序:;*;/*初始状态全为红灯*/;*;ST0PROC NEARMOVAL,1BHOUTDX,ALCALLDELAYRETST0ENDp;*;/*南北为绿灯,东西为红灯子程序*/;*;ST1PROC NEARMOVDX,P8255_AMOVAL,33HOUTDX,ALCALLDELAYCALL BREAKCALLDELAYCALL BREAKCALLDELAYCALL BREAKRETST1ENDp;*;/*南北红灯闪烁,东西为红灯子程序*/;*;ST2PROC NEARMOVCX,5HST20:MOVAL,2BHOUTDX,ALCALLDELAYMOVAL,3BHOUTDX,AlCALLDELAYLOOPST20RETST2ENDp;*;/*南北为红灯,东西为绿灯子程序*/;*;ST3PROC NEARMOVAL,1EHOUTDX,ALCALLDELAYCALL BREAKCALLDELAYCALL BREAKCALLDELAYCALL BREAKRETST3ENDp;*;/*南北为红灯,东西黄灯闪烁子程序*/;*;ST4PROC NEARMOVCX,5HST40:MOVAL,1DHOUTDX,ALCALLDELAYMOVAL,1FHOUTDX,ALCALLDELAYLOOPST40RETST4ENDp实验五 可编程定时器/计数器8254(8253)实验一、实验目的(1)掌握8254定时/计数器的编程方法。(2)学习8254的几种工作方式。(3)了解计数器的硬件连接及时序关系。二、实验内容(1)将32Hz的晶振频率作为8254 的时钟输入,利用定时器 8254 产生 1Hz 的方波,用发光二极管显示输出结果(发光二极管闪烁)。(2)开关控制结束程序执行,发光二极管熄灭。(3)开关控制发光二极管闪烁的速度(输出不同频率的方波)。考核方式:完成实验内容(1)(2)通过,完成实验内容(3)优秀。三、实验原理1. 8254工作原理8254是一种可编程的定时器/计数器芯片,它具有3个独立的16位计数器通道,每个计数器都可以按照二进制或二-十进制计数,每个计数器都有6种工作方式,计数频率可高达10MHz,芯片所有的输入输出都与TTL兼容。计数器都有6种工作方式:方式0计数过程结束时中断;方式1可编程的单拍脉冲;方式2频率发生器;方式3方波发生器;方式4软件触发;方式5硬件触发。6种工作方式主要有5点不同:一是启动计数器的触发方式和时刻不同;二是计数过程中门控信号GATE对计数操作的影响不同;三是OUT输出的波形不同;四是在计数过程中重新写入计数初值对计数过程的影响不同;五是计数过程结束,减法计数器是否恢复计数初值并自动重复计数过程的不同。8254管脚图:图3-3-1 可编程定时器/计数器8254管脚图28254工作方式和编程根据片选信号CS及地址线A1、A0,8254具有四个端口地址。当A1A0=00时,选中的为0通道计数器;A1A0=01时,选中的为1通道计数器;A1A0为10时,选中的为2通道计数器;A1A0=11时,选中控制字寄存器。8253通道及操作地址分配如下表所示:CSRDWRA1A0操作00100读计数器000101读计数器100110读计数器200111无操作(禁止读)01000计数常数写入计数器001001计数常数写入计数器101010计数常数写入计数器201011写入方式控制字1XXXX禁止(三态)011XX不操作通过对控制字符寄存器写入控制字可设定8254的某一个通道的六种工作方式,其格式如下:D7D6D5D4D3D2D1D0SC1SC0RL1RL0M2M1M0BCDSC1、SC0用来选择计数器通道:SC1SC0选择通道00选中0通道计数器01选中1通道计数器10选中2通道计数器11非法RL1、RL0用来选择读计数值及向计数器送入数据的方式:RL1RL0读/输入选择00计数器锁存01只读/输入低字节10只读/输入高字节11先读/输入低字节,后读/输入高字节M2、M1、M0用来选择工作方式:M2M1M0工作方式000方式0001方式1X10方式2X11方式3100方式4101方式5BCD用来选择二进制计数及十进制计数。当此位为0时,为16位二进制计数器;当此位为1时,为4位二-十进制计数器。方式0为计数结束申请中断的方式。当方式控制字写入后,输出为低电平。在写入计数值后,计数器开始计数。计数器减到0后,输出变为高电平,此高电平信号一直维持到写入新的控制字,或写入新的计数值为止。此时可利用计数到0时,输出由低电平变为高电平的信号申请中断。如果在计数过程中写入新的计数值,则在写入第一个字节时中止计数,写入第二个字节时启动新的计数。方式1为单脉冲发生方式。输出的负脉冲宽度由计数值决定。在设定工作方式和写入计数值之后,输出为高电平。门控信号的上升沿使输出变为低电平,并开始计数。当计数结束时,输出为高电平,当门控信号为高电平时,计数器从最初计数值启动。由于计数器写入控制字后输出为高电平,当写入计数值后才开始并输出脉冲,因此也可通过写入计数值来实现软件同步。方式3为方波发生方式。类似于方式2,当计数值为偶数时,前N/2为高电平,后N/2为低电平。当计数值为奇数时,则(N+1)/2为高电平,(N-1)/2为低电平。方式4为软件触发脉冲方式。在写入控制字后,输出为高电平
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 公司防锈处理工职业健康技术规程
- 前厅服务面试准备
- 公路安全员安全生产操作规程
- 宠物行业品牌营销策略
- 宠物健康评估标准详解
- 福利彩票销售员培训重点突破题
- 宠物用药AI面试攻略
- 茶叶加工工安全素养测试考核试卷含答案
- 厨师招聘面试常见问题
- 2025年佛山市招聘工会社会工作者11人笔试题库及答案详解(各地真题)
- 2025至2030赖氨酸行业发展趋势分析与未来投资战略咨询研究报告
- 2025年山东综评专科题目及答案
- 增强营销策略方案
- 【课件】2025年消防月主题培训全民消防生命至上安全用火用电
- 十五五规划12项重大部署专题解读
- 交通标识标牌安装工程施工方案方法
- 江苏省扬州市七校联盟2025-2026学年高三上学期第一次联考英语试题(含答案)
- 狂犬病规范门诊培训要点
- 2025年及未来5年中国量子测量行业市场全景评估及发展战略规划报告
- 资产报废申请书
- 口腔护士长急救知识培训课件
评论
0/150
提交评论