计算机组成原理第8章习题指导.pdf_第1页
计算机组成原理第8章习题指导.pdf_第2页
计算机组成原理第8章习题指导.pdf_第3页
计算机组成原理第8章习题指导.pdf_第4页
计算机组成原理第8章习题指导.pdf_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

计算机组成原理第 8 章习题 1 第 8 章 CPU 的结构和功能 例例 8 1 假设指令流水线分取指 IF 译码 ID 执行 EX 回写 WR 四个过程段 共有 10 条指令连续输入此流水线 1 画出指令周期流程 2 画出非流水线时空图 3 画出流水线时空图 4 假设时钟周期为 100ns 求流水线的实际吞吐率 5 求该流水处理器的加速比 解 1 根据指令周期包括 IF ID EX WR 四个子过程 图 8 1 a 为指令周期流程图 2 非流水线时空图如图 8 1 b 所示 假设一个时间单位为一个时钟周期 则每隔 4 个时钟周 期才有一个输出结果 3 流水线时空图如图 8 1 c 所示 由图可见 第一条指令出结果需要 4 个时钟周期 当流 水线满载时 以后每一个时钟周期可以出一个结果 即执行完一条指令 a 指令周期流程 b 非流水线时空图 c 标准流水线时空图 图 8 1 例 8 1 答图 4 由图 8 1 c 所示的 10 条指令进入流水线的时空图可见 在 13 个时钟周期结束时 CPU 入 IF ID EXWR I6 I7 I8 I9 I10I3 I2 910 11 12 13 I5I1 空间 S 时间 T 876 5 4 3 21 IF ID EX WR I4 I2 I1 空间 S 时间 T 876543 2 1 IF ID EX WR 计算机组成原理第 8 章习题 2 执行完 10 条指令 故实际吞吐率为 10 100ns 13 0 77 107条指令 秒 5 在流水处理器中 当任务饱满时 指令不断输入流水线 不论是几级流水线 每隔一个时钟 周期都输出一个结果 对于本题四级流水线而言 处理 10 条指令所需的时钟周期数为 T4 4 10 1 13 而非流水线处理 10 条指令需 4 10 40 个时钟周期 故该流水处理器的加速比为 40 13 3 08 例例 8 2 设某机有四个中断源 1 2 3 4 其硬件排队优先次序按 1 2 3 4 降序排列 各中断 源的服务程序中所对应的屏蔽字如表 8 1 所示 表 8 1 例 8 2 各中断源对应的屏蔽字 中断源 屏蔽字 1 2 3 4 1 1 1 0 1 2 0 1 0 0 3 1 1 1 1 4 0 1 0 1 1 给出上述四个中断源的中断处理次序 2 若四个中断源同时有中断请求 画出 CPU 执行程序的轨迹 解 1 根据表 8 1 四个中断源的处理次序是 3 1 4 2 2 当四个中断源同时有中断请求时 由于硬件排队的优先次序是 1 2 3 4 故 CPU 先 响应 1 的请求 执行 1 的服务程序 由于在该服务程序中设置了屏蔽字 1101 故开中断指令后转去执 行 3 服务程序 且 3 服务程序执行结束后又回到 1 服务程序 1 服务程序结束后 CPU 还有 2 4 两个 中断源请求未响应 由于 2 的响应优先级高于 4 故 CPU 先响应 2 的请求 执行 2 服务程序 在 2 服 务程序中由于设置了屏蔽字 0100 意味着 1 3 4 可中断 2 服务程序 而 1 3 的请求已处理结束 因此在开中断指令之后转去执行 4 服务程序 4 服务程序执行结束后又回到 2 服务程序的断点处 继 续执行 2 服务程序 直至该程序执行结束 图 8 2 示意了 CPU 执行程序的轨迹 图 8 2 例 8 2CPU 执行程序的轨迹 例例 8 3 假设主机框图如图 8 3 所示 各部分之间的连线表示数据通路 箭头表示信息传送方向 1 标明图中 X Y Z W 四个寄存器的名称 2 简述取指令的数据通路 3 简述取数指令和存数指令执行阶段的数据通路 程序 4 程序 3 程序 2 程序 1 t 1 2 3 4 同时请求中断 服务程序 计算机组成原理第 8 章习题 3 图 8 3 例 8 3 主机框图 解 1 图中 X 为存储器数据寄存器 MDR Y 为存储器地址寄存器 MAR Z 为指令寄存器 IR W 为程序计数器 PC 2 取指令的数据通路是 W Y M X Z 3 取数指令是将指令地址码字段指出的存储单元的内容读到 AC 中 由于图中 X MDR 与 AC 无直接通路 要经过 ALU 实现数据传送 故执行阶段的数据通路是 X 或 Z Y M X ALU AC 存数指令是将 AC 的内容存入指令地址码字段指出的存储单元中 其执行阶段的数据通路是 先置地址 X 或 Z Y M 然后 AC X M 例例 8 4 设 CPU 内有下列部件 PC IR SP AC MAR MDR 和 CU 要求 1 写出完成间接寻址的取数指令 LDA X 将主存某单元的内容取至 AC 中 的信息流 2 画出中断周期的信息流 并简要说明 解 1 完成间接寻址的取数指令包括取指 间址和执行三个阶段 取指阶段的信息流 PC MAR 地址线 CU 发出读存储器命令 M 数据线 MDR IR 至此指令读至 IR OP IR CU 指令操作码送 CU 分析 PC 1 PC 形成下一条指令地址 间址阶段的信息流 MDR 或 IR 的地址码字段 MAR 地址线 CU 发出读存储器命令 CPU 1 主存储器 M X Y Z W 状态寄存器 ALU AC CU 1 计算机组成原理第 8 章习题 4 M 数据线 MDR 至此有效地址读至 MDR 执行阶段的信息流 MDR MAR 地址线 CU 发出读存储器命令 M 数据线 MDR AC 至此数据读至 AC 中 2 中断周期的信息流 在中断周期内需将程序断点 在 PC 中 保存起来 通常把断点存入堆栈 假设进栈操作是先修 改堆栈指针 后存入数据 则中断周期的信息流如图 8 4 所示 具体可描述为 CU 控制 SP 1 SP MAR 地址线 CU 发出写存储器命令 PC MDR 数据线 存储器 CU 将向量地址 硬件向量法 或中断识别程序入口地址 软件查询法 PC MDR CU MAR CPU PC 存储器 数 据 总 线 控 制 总 线 地 址 总 线 图8 4 例8 4中断周期信息流 例例 8 5 流水线中有三类数据相关冲突 写后读相关 Read After Write RAW 读后写相关 Write After Read WAR 写后写相关 Write After Write WAW 判断下面三组指令各存在哪种类型的 数据相关 1 I1 SUB R1 R2 R3 R2 R3 R1 I2 ADD R4 R5 R1 R5 R1 R4 2 I3 STA M R2 R2 M M 为存储单元 I4 ADD R2 R4 R5 R4 R5 R2 3 I5 MUL R3 R2 R1 R2 R1 R3 I6 SUB R3 R4 R5 R4 R5 R3 解 在第 1 组指令中 I1指令运算结果应先写入 R1 然后在 I2指令中读出 R1内容 由于 I2 指令进入流水线 使得 I2指令在 I1指令写入 R1前就读出 R1的内容 发生 RAW 相关 在第 2 组指令中 I3指令应先读出 R2内容并存入存储器单元 M 中 然后 I4指令中将运算结果 计算机组成原理第 8 章习题 5 写入 R2中 但由于 I4指令进入流水线 使得 I4指令在 I3指令读出 R2之前就写入 R2 发生 WAR 相关 在第 3 组指令中 如果 I6指令减法运算完成时间早于 I5指令的乘法运算时间 使得 I6指令在 I5指令写入 R3之前就写入 R3 导致 R3内容错误 发生 WAW 相关 例例 8 6 假设指令流水线分取指令 IF 指令译码 读寄存器 ID 执行 有效地址计算 EX 存 储器访问 MEM 结果寄存器写回 WB 五个过程段 现有下列指令序列进入该流水线 ADD R1 R2 R3 R2 R3 R1 SUB R4 R1 R5 R1 R5 R4 AND R6 R1 R7 R1 AND R7 R6 OR R8 R1 R9 R1 OR R9 R8 XOR R10 R1 R11 R1 XOR R11 R10 试问 1 如果处理器不对指令之间的数据相关进行特殊处理 而允许这些指令进入流水线 试问上述 指令中哪些指令将从未准备好数据的 R1寄存器中取到错误的操作数 2 假如采用将相关指令延迟到所需操作数被写回到寄存器后再执行的方式 以解决数据相关的 问题 那么处理器执行该指令序列需占多少个时钟周期 解 1 由上述指令序列可见 ADD 指令后的所有指令都用到 ADD 指令的计算结果 表 8 2 a 列出了未采用特殊处理的流水线示意 表中ADD指令在WB段才将计算结果写入寄存器R1中 但SUB 指令在其 ID 段就要从寄存器 R1中读取该计算结果 同样 AND 指令 OR 指令也将受到这种相关关系 的影响 ADD 指令只有到第五个时钟周期末尾才能结束对寄存器 R1的写操作 使 XOR 指令可以正常 操作 因为它在第六个时钟周期才读寄存器 R1的内容 表8 2 a 未对数据相关进行特殊处理的流水线 时钟周期 1 2 3 4 5 6 7 8 9 ADD IF ID EX MEMWB SUB IF ID EX MEMWB AND IF ID EX MEMWB OR IF ID EX MEMWB XOR IF ID EX MEM WB 2 表 8 2 b 列出了对这些指令之间数据相关进行特殊处理的流水示意 由此表可见 从第一 条指令进入流水线到最后一条指令出结果 共需 12 个时钟周期 计算机组成原理第 8 章习题 6 表8 2 b 对数据相关进行特殊处理的流水线 时钟 周期 1 2 3 4 5 67 8 9 10 11 12 ADD IF ID EX MEM WB SUB IF IDEXMEMWB AND IF IDEX MEMWB OR IF ID EX MEMWB XOR IF ID EX MEM WB 例例 8 7 回答下列问题 1 一个完整的指令周期包括哪些 CPU 工作周期 2 中断周期前和中断周期后各是 CPU 的什么工作周期 3 DMA 周期前和 DMA 周期后各是 CPU 的什么工作周期 解 1 一个完整的指令周期包括取指周期 间址周期 执行周期和中断周期 其中取指和执行周期 是每条指令都有的 间址周期只有间接寻址 存储器间接寻址 的指令才有 中断周期只有在条件满 足时才有 2 中断周期前是执行周期 中断周期后是取指周期 3 DMA 周期前可以是取指周期 执行 取数和存数 周期或中断周期 DMA 周期后也可以 是取指周期 执行 取数或存数 周期或中断周期 总之 DMA 周期前后都是存取周期 例例 8 8 判断下列叙述是否正确 并对有错的句子加以修改 1 一个更高级的中断请求一定可以中断另一个正在执行的中断处理程序 2 所谓关中断就是屏蔽所有的中断源 3 一旦有中断请求出现 CPU 立即停止当前指令的执行 转去执行中断服务程序 4 为了保证中断服务程序执行后能正确返回到被中断的程序断点处继续执行程序 必须进行现 场保护 5 中断级别最高的是不可屏蔽中断 6 CPU 响应中断后 由用户通过关中断指令置 0 允许中断触发器 7 在多重中断系统中 CPU 响应中断后可以立即响应更高优先级的中断请求 8 CPU 响应中断时暂停当前程序的运行 自动转去执行中断服务程序 解 上述句子中 4 8 正确 其余有错 修改如下 1 如果 CPU 处于关中断状态 允许中断触发器 EINT 0 或者更高级的中断源被屏蔽 则 优先级高的中断源就不能中断另一个正在执行的中断处理程序 2 关中断是指允许中断触发器 EINT 0 CPU 不允许响应任何中断 这和屏蔽中断源是两个 概念 3 一旦有中断请求出现 CPU 必须执行完当前指令后才能转去受理中断请求 如果允许中断 触发器为 1 5 级别最高的中断不一定是不可屏蔽中断 这与机器的设计有关 例如 8086 8088 中 内部中 计算机组成原理第 8 章习题 7 断的优先级比不可屏蔽中断的级别更高 6 CPU 响应中断后 不是由用户通过关中断指令置 0 允许中断触发器的 而是由硬件 中 断隐指令 自动完成的 7 在多重中断系统中 CPU 响应中断后 在保护断点和现场以及开中断之前 CPU 不能立即 响应更高优先级的中断请求 例例 8 9 设某机有四个中断源 A B C D 其硬件排队优先次序为 A B C D 现要求将中断 处理次序改为 D A C B 1 写出每个中断源对应的屏蔽字 2 按图 8 5 时间轴给出的四个中断源的请求时刻 画出 CPU 执行程序的轨迹 设每个中断源 的中断服务程序时间均为 20 s 图8 5 例8 9设置中断请求的时刻 解 1 在中断处理次序改为 D A C B 后 每个中断源新的屏蔽字如表 8 3 所示 表8 3 例8 9各中断源对应的屏蔽字 中断源 屏蔽字 A B C D A 1 1 1 0 B 0 1 0 0 C 0 1 1 0 D 1 1 1 1 2 根据新的处理次序 CPU 执行程序的轨迹如图 8 6 所示 图8 6 例8 9 2 答图 例例 8 10 设某机有六个中断源 优先顺序按 0 1 2 3 4 5 降序排列 1 若在某用户程序的运行过程中 依次

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论