- 1、本文档共30页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理-第二章-3要点
微机原理与接口技术--基于IA-32处理器和32位汇编语言·第4版 第2章 处理器结构 2.3 存储器组织 物理存储器以字节为基本存储单位 每个存储单元被分配一个唯一的地址:物理地址 物理地址空间从0开始顺序编排,直到处理器支持的最大存储单元 8086处理器支持1MB存储器:00000H~FFFFFH IA-32处理器支持4GB存储器~FFFFFFFFH 操作系统利用存储管理单元进行存储管理,程序并不直接寻址物理存储器 IA-32处理器提供3种存储模型,用于程序访问存储器 2.3.1 存储模型 1. 平展存储模型(Flat memory model) 存储器是一个连续的地址空间--线性地址空间 IA-32处理器支持4GB容量线性地址空间 2. 段式存储模型 存储器由一组独立的地址空间-段(Segment)组成 每个段都可以达到4GB容量 在处理器内部,所有的段都被映射到线性地址空间 3. 实地址存储模型 8086处理器的存储模型 段式存储模型 地址空间最大为1MB容量,段最大为64KB 2.3.2 工作方式 1. 保护方式(Protected mode) IA-32处理器固有的工作状态 具有强大的段页式存储管理和特权与保护能力 使用全部32条地址总线,可寻址4GB物理存储器 使用平展或段式存储模型 利用虚拟8086方式支持实地址8086软件 2. 实地址方式(Real-address mode) 可以进行32位处理的快速8086 只能寻址1MB物理存储器空间,每个段不超过64KB 可以使用32位寄存器、32位操作数和32位寻址方式 只能支持实地址存储模型 3. 系统管理方式 实现节能和系统安全管理 2.3.3 逻辑地址(Logical Address) 程序员编程时采用的地址 逻辑地址=段基地址∶偏移地址 段基地址=在主存中的起始地址 偏移地址=距离段基地址的位移量 一个存储单元可以有多个逻辑地址,但只有一个唯一的物理地址 逻辑地址与物理地址 1. 基本段 代码段(Code Segment):存放指令代码 程序的指令代码必须安排在代码段 数据段(Data Segment):存放数据 程序的数据默认存放在数据段 数据也可放在其他段 堆栈段(Stack Segment):堆栈区域 程序使用的堆栈一定在堆栈段 基本段的逻辑地址构成 代码段(Code Segment) 段基地址:代码段寄存器CS指示 偏移地址:指令指针寄存器EIP保存 数据段(Data Segment) 段基地址:数据段寄存器DS指示 有时也用附加段寄存器ES,段寄存器FS和GS表示数据 偏移地址:多种存储器寻址方式 堆栈段(Stack Segment) 段基地址:堆栈段寄存器SS指示 偏移地址:堆栈指针寄存器ESP保存 2. 段选择器 16位段寄存器保存16位段选择器 段选择器指向64位段描述符(Descriptor) 段描述符包括段基地址 平展存储模型:指向地址0位置 段式存储模型:指向线性地址空间不同的段 实地址存储模型:保存段基地址的高16位 3. 保护方式的地址转换 平展存储模型 段基地址为0,偏移地址等于线性地址 段式存储管理 段基地址和偏移地址都是32位 段基地址加上偏移地址形成线性地址 线性地址映射到物理地址 不使用分页机制:线性地址与物理地址对应 使用分页机制:硬件支持下由操作系统或核心程序管理,构成虚拟存储器,转换成物理地址 4. 实地址方式的地址转换 主存空间1MB(=220 B):00000H~FFFFFH 程序设计时分段管理,但有两个限制: 每个段最大为64KB 段只能开始于低4位地址全为0的物理地址处 逻辑地址=段地址∶偏移地址 16位段寄存器保存20位段起始地址的高16位 偏移地址也用16位数据表示 物理地址=段地址×16+偏移地址 实地址存储模型的逻辑地址和物理地址 2.4 汇编语言基础 以助记符形式表示计算机指令 便于记忆、并能描述指令功能 是指令功能的英语单词或其缩写 汇编指令及其使用规则称作汇编语言(Assembly Language) 汇编语言源程序:用汇编语言书写的程序 汇编程序:将汇编语言源程序“汇编”成机器代码目标模块的程序 2.4.1 指令代码格式(Instruction format) IA-32处理器指令采用可变长度格式 1)操作码 1~3字节的主要操作码 可选的指令前缀(用于扩展指令功能) 2)操作数 可选的寻址方式域 可选的位移量 可选的立即数 指令代码示例 数据传送指令MOV(取自Move) 将数据从一个位置传送到另一个位置 类似高级语言的赋值语句 mov dest,src ;源操作数src:被传送的数据或数据所在的位置 ;目的操作数dest:数据将要传送到的位置 传送指令MOV AX,3
文档评论(0)