(07)80486的三种工作方式及转换2.2.3
- 格式:ppt
- 大小:73.50 KB
- 文档页数:6
教学目标介绍80486的寻址方式及指令系统。
第三章80486微处理器指令系统目标和基本要求学习要求通过本章的学习,要求熟悉各种寻址方式的使用场合以及常用指令的使用方法。
第三章80486微处理器指令系统第一节80486微处理器寻址方式讲授内容第二节80486微处理器指令系统前言1.通知CPU执行某种操作的“命令”,CPU全部指令的集合,称为指令系统第一节80486微处理器的寻址方式1. 指令3+目标指令(机器指令):用一串0,1代码书写注意:硬件只能识别,存储,运行目标指令+符号指令:用规定的助记符,规定的书写格式书写的指令2. 指令的书写格式80486符号指令与机器指令对照表操作80486符号指令80486机器指令1234H→AX MOV AX, 1234H B8 34 12 AX+BX→AX ADD AX,BX 03C34AX+BX→AXADD AX, BX 03 C3 CX-DX→CX SUB CX, DX 2B CA 返回调用程序RET C3MOV: MOVE传送ADD:加SUB:减RET:RETURN 返回指令的组成:操作码+ 操作数操作码——告诉计算机要执行的操作是什么,3.指令的组成第一节80486微处理器的寻址方式5如:加、减、逻辑与等。
操作数——执行操作过程所要操作的数,如加运算的两个加数。
4.目标程序的生成汇编可执行的机器指令CPU只能识别,存储,运行目标指令,而用机器指令编程非常困难。
于是早期的专家们发明了符号指令,再经过软件把符号指令→机器指令。
图示如下:第一节80486微处理器的寻址方式6源程序编辑、编译、链接程序(目标程序)486指令长度(机器指令长度)为1~16字节规定:多字节指令占用连续的内存单元,存放指令第一字节的内存地址,称为“指令地址”。
5.指令长度先写操作码,再写操作数。
多字节操作数连续存放。
存放规律: 低位字节存放在低地址单元,高位字节存放在相邻的高地址单元7如:12345H单元中有一条指令MOV AX,6789H67H89H B8H 12345H:操作码操作数6789HMOV AX,6789H如:NEXT: ADD AX , BX ;AX+BX → AXINC SI ;SI+1 → SI 8INC SI;SI+1→SI标号:以字母开头,后跟字母,数字,下划线,长度≤31字符标号又称符号地址,代表该指令的逻辑地址。
Intel 80386 微处理器的存储器管理一、存储器的管理存储器的管理是一种硬件机制,微处理器在总线地址上对物理存储器进行寻址。
但是,为了给程序提供比物理存储器容量更大的空间,就引入了虚拟存储器的概念,它在外存(比如磁盘)的支持来下实现,通常所说的虚拟地址称为逻辑地址。
对80386来说,既有段的管理又有页的管理。
对段和页的管理属于操作系统的职责,80386从硬件上提供管理机制。
二、Intel 80386 微处理器的三种工作方式三种工作方式:实地址方式,虚地址保护方式,虚拟8086方式。
1. 实地址方式80386在硬件复位后处于该模式下,只能使用32位地址总线的低20位地址,寻址空间为1MB。
此时他就是一个8086/8088微处理器,不同的是它不仅可以运行8086/8088的全部指令,还可以运行32位的运算类指令。
系统初始化区在FFFFFFF0H-FFFFFFFFH存储区内。
设置此方式是为了与8086兼容,也可从实地址方式转变到保护虚地址方式。
物理地址由8386芯片地址引线送出的低的20位地址码,经过存储器译码后选择一个存储单元进行读写,物理地址可用5位的十六进制来表示20位的地址。
储器地址分段是把1MB 的存储器空间分成若干段,每段的容量最大为64KB,每个段首地址的高16位二进制代码就是该段的段号(称段基地址)。
存储器采用分段管理后,段地址存放在段寄存器CS、DS、SS、ES中,对段寄存器设置不同的值来使微处理器的段寄存器指向存储器中不同的段。
偏移地址是相对于某段首地址的段内偏移量。
物理地址的形成,把段地址左移4 位得到段基地址,再加上偏移地址值就形成了20 位的物理地址。
计算表示方式如下:段地址×10H+偏移地址=物理地址80386在实地址方式下的地址转换如图一:2.虚地址保护方式当Intel 80386/486 的控制寄存器CR0 的最低位为PE(Protection Enable)保护模式允许位,用来启动CPU进入虚地址保护方式。
80486基本集指令1.传送类指令2.算术运算指令3.转移和调用指令4.逻辑运算和移位指令5.串操作指令6.处理机控制指令1.1通用传送指令(1)数据传送指令格式:MOV 目标操作数,源操作数作用:把源操作数传送到目标寄存器或目标单元,源操作数不变,不影响状态标志。
(2)符号扩展传送指令格式:MOVSX 目标寄存器,源操作数作用:将源操作数的符号位向高位扩展使其与目标字长相同,然后再传送到目标寄存器,而源操作数不变。
(3)零扩展传送指令格式:MOVZX 目标寄存器,源操作数作用:将源操作数高位用零补足16位或32位,再传送到目标寄存器。
(4)偏移地址传送指令格式:LEA 目标寄存器,源操作数作用:将内存单元的偏移地址(不是指该单元的内容)传送到目标寄存器中。
目标为16或32位寄存器,源操作数为内存操作数(5)指针传送指令格式:操作码助记符目标寄存器,源操作数作用:操作码助记符有LDS、LES、LFS、LGS、LSS,其后两位字母代表段寄存器(6)标志寄存器传送指令格式:LAHFSAHF作用:LAHF将标志寄存器低8位传送到AH寄存器中,SAHF将AH寄存器的内容传送到标志寄存器低8位。
(7)交换指令格式:XCHG 目标操作数,源操作数作用:完成源、目标操作数互换。
源、目标操作数是等长的寄存器操作数、内存操作数。
不能同为内存操作数。
(8)字节交换指令格式:BSWAP 32寄存器作用:将32位通用寄存器的31位~24位与7~0位交换,23位~16位与15~8位交换(9)查表指令格式:XLAT 表头变量名作用:取出DS:[BX+AL]中的一个字节给AL,或者取出DS:[EBX+AL]中的一个字节给AL1.2堆栈操作指令(1)进栈指令格式:PUSH 源操作数作用:执行时,首先调整堆栈指针,然后把源操作数压栈(2)出栈指令格式:POP 目标操作数作用:先从栈顶弹出2个或4个字节送目标操作数,然后调整堆栈指针(3)16位标志寄存器进栈/出栈指令格式:PUSHFPOPF作用:执行PUSHF时,首先SP-2→SP,然后标志寄存器低16位→SS:[SP]的两个单元。
汇编语言程序设计教程(第二版)习题参考答案第1章计算机基础知识1.计算机的应用分哪几个方面,请举例说明书中未提到的领域的计算机应用。
科学计算、数据处理、计算机控制、计算机辅助设计、人工智能、企业管理、家用电器、网络应用。
书中未提及的如:远程教育、住宅小区控制、飞行系统控制与管理等。
2.简述计算机的发展过程,请查阅相关资料,列出微机的发展过程。
电子管、晶体管、集成电路、大规模集成电路以IBM为例,微机的发展:4004、8008、8080、8086/8088、80286、80386、80486、Pentium 系列3.计算机的字长是怎么定义的,试举例说明。
计算机能同时处理二进制信息的位宽定义为计算机的字长。
如8086能同时进行16位二进制数据的运算、存储和传输等操作,该机器的字长为16位。
4.汇编语言中的基本数据类型有哪些?数值型数据和非数值型数据。
非数值数据如字符、字符串、逻辑值等。
(1)7BCH=011110111100B=1980D(2)562Q=101110010B=370D(3)90D=01011010B=5AH(4)1110100.111B=164.7Q=74.EH30H~39H 41H~5AH 61H~7AH9.在汇编语言中,如何表示二进制、八进制、十进制和十六进制的数值?用相应进制的数值加上进制标记即可。
二进制用B,如10101010B八进制用Q,如437Q。
十进制用D或不用,如54D,或54。
十六进制用H,如27A8H10.完成下列二进制数的加减运算。
(1)10101010 + 11110000 (2)11001100 + 01010100=110011010 =100100000(3)11011010 - 01010010 (4)11101110 - 01001101=10001000 =1010000111.完成下列十六进制数的加减运算。
(1)0FEA9 - 8888=7621H (2)0FFFF - 1234=EDCBH(3)0EAC0 + 0028=EAE8H (4)3ABC + 1678=5134H12.完成下列BCD码的运算。
80x86保护模式系列教程(1)保护方式简介一. 保护方式简介80386 有三种工作方式: 实模式, 保护模式和虚拟8086 模式。
本文介绍保护方式下的80386 及相关的程序设计内容。
实模式下的80386 寄存器,寻址方式和指令等基本概念,除特别说明外在保护方式下仍然保持。
尽管实方式下80386 的功能要大大超过其先前的处理器(8086/8088,80186,80286) ,但只有在保护方式下,8038 6 才能真正发挥更大的作用。
在保护方式下,全部32 条地址线有效,可寻址高达4G字节的物理地址空间; 扩充的存储器分段管理机制和可选的存储器分页管理机制,不仅为存储器共享和保护提供了硬件支持,而且为实现虚拟存储器提供了硬件支持; 支持多任务,能够快速地进行任务切换和保护任务环境;4 个特权级和完善的特权检查机制,既能实现资源共享又能保证代码和数据的安全和保密及任务的隔离; 支持虚拟8086 方式,便于执行8086 程序。
<一>存储管理机制为了对存储器中的程序及数据实现保护和共享提供硬件支持,为了对实现虚拟存储器提供硬件支持,在保护方式下,80386 不仅采用扩充的存储器分段管理机制,而且提供可选的存储器分页管理机制。
这些存储管理机制由803 86 存储管理部件MMU实现。
1. 目标80386 有32 根地址线,在保护方式下,它们都能发挥作用,所以可寻址的物理地址空间高达4G字节。
在以8038 6 及其以上处理器为CPU的PC 兼容机系统中,把地址在1M以下的内存称为常规内存,把地址在1M 以上的内存称为扩展内存。
80386 还要对实现虚拟存储器提供支持。
虽然与8086 可寻址的1M字节物理地址空间相比,80386 可寻址的物理地址空间可谓很大,但实际的微机系统不可能安装如此达的物理内存。
所以,为了运行大型程序和真正实现多任务,必须采用虚拟存储器。
虚拟存储器是一种软硬件结合的技术,用于提供比在计算机系统中实际可以使用的物理主存储器大得多的存储空间。
《微机原理与汇编语言》作业一答案一、填空题1、计算机中的CPU由运算器和控制器组成。
2、根据传送的内容不同,微型计算机系统总线可以分为数据总线、地址总线和控制总线。
3、(513.85)10 = ( 201.D999 )16 (105.3)8 = ( 69.375 )10(9E.A)16 = ( 236.5 )8(1001.11001 )2 = ( 9.78125 )104、“9”的ASCII码是39H ,“DEL”的ASCII码是7FH ,“K”的ASCII码是4BH 。
5、假定机器的字长为8位,且最高位为符号位,则(-127)10的原码用8位二进数表示为11111111 ,其补码用8位二进数可表示为10000001 。
6、[4C10H]补= [ 4C10H ]原[9DH]补= [ -63H ]原7、I/O端口有两种编址方式,分别是统一编址和独立编址。
8、有一个由20个字组成的数据区,其起始地址为610AH:1CE7H,则数据区首地址为62D87H ,数据区末地址为62DAEH 。
9、8086寻址I/O端口时,使用16 条地址总线,可以寻址32K 个字端口或64K 个字节端口。
二、名词解释1、字节、字、字长字节:是计算机中通用的的基本单元,它由8个二进制位组成,即8位二进制数组成一个字节。
字:是计算机内部进行数据处理的基本单位。
对于16位微型计算机而言,字由两个字节组成,每个字节长度为8位,分别称为高位字节和低位字节。
对于32位的微型计算机,它由4个字节组成,组合后为双字。
字长:是计算机在交换、加工和存放信息时,其信息位的最基本长度,决定了系统一次传送的二进制数的位数。
各种类型的微型计算机字长是不相同的,字长越长的计算机,处理数据的精度和速度就越高。
因此,字长是微型计算机中最重要的指标之一。
2、主频、基本指令执行时间主频:也称为时钟频率,通常是指计算中时钟脉冲发生器所产生的时钟信号的频率,单位为MHz(兆赫),它决定了微型计算机的处理速度。