计算机组成原理16——指令系统3(书中重点及习题)

本系列文章是学习了网课《哈尔滨工业大学–计算机组成原理》之后,用以梳理思路而整理的听课笔记及相关思维拓展。本文涉及到的观点均为个人观点,如有不同意见,欢迎在评论区讨论。

目录

1、某机主存容量为4M x 16位,存储字长等于指令字长,若该机指令系统能完成97种操作,操作码位数固定,且具有直接、间接、变址、基址、相对、立即六种寻址方式。
①画出一地址指令格式并指出各字段的作用
OP为操作码字段,共7位, 2 7 2^7 27 = 128 > 97种操作
M寻址方式特征字段,共3位, 2 3 2^3 23 = 8 > 6种寻址方式
A形式地址字段,共16 - 7 - 3 = 6位
在这里插入图片描述
②直接寻址的最大范围
直接寻址的最大范围为 2 6 2^6 26 = 64
③一次间址和多次间址的寻址范围
一次间址的寻址范围为 2 16 2^{16} 216,因为存储长度为16位(形式地址指向的存储空间长度为16位,所以说最多寻址 2 16 2^{16} 216)。
多次寻址需要最高位用作是否继续间接寻址,寻址范围为 2 15 2^{15} 215
④立即数的范围
立即数的范围是 2 6 2^6 26,所以是-32到31(有符号数)或0到63(无符号数)
⑤相对寻址的位移量
相对寻址的位移量为-32到31
⑥上述六种寻址方式哪一种执行时间最短?哪一种最长?哪一种便于用户编制处理数组问题的程序?哪一种便于程序浮动?
立即数由指令直接给出,执行时间最短。
间址寻址要多次访存,执行时间最长。
变址寻址中变址寄存器允许修改,而形式地址不变,便于用户处理数组问题。
相对寻址中有效地址和当前指令地址相差一定的位移量,有利于程序浮动。
⑦如何修改指令格式,使指令的直接寻址范围扩大到4M?
若指令的格式改为双字指令,OP占用7位,M占用3位, A 1 占用 6 位 A_1占用6位 A1占用6 A 2 占用 16 位 A_2占用16位 A2占用16,即指令的地址字段共16+6 = 22位,指令的直接寻址范围可扩大到4M。
在这里插入图片描述

2、假设某机的指令长度可变,而且CPU与存储器的数据传送宽度为32位。试问如何区分一个存储字包含多少条指令?
可在设计该指令时,在指令中安排两位来区分指令的长度,2位共四个状态,直接区分1到4字节指令。

3、说明数据在存储器中可以按“边界对准”或“边界不对准”两种方式存放的特点,并分析利弊。
设存储字长为32位,可按字节、半字、字寻址。
按边界对准方式存放,数据字的地址一定是4的整数倍,这样每访问一个字,即可读出32位。当所存数据不能满足此要求时,会浪费一些存储空间。
若不按边界对准方式存放,则数据字可能跨了两个存储字的位置,此时需要访问两次存储器,影响了取数的时间。
在这里插入图片描述

4、假设指令字长为16位,操作数的地址码为6位,指令有零地址、一地址、二地址三种格式。
①设操作码固定,若零地址指令有M种,一地址指令有N种,则二地址指令最多有几种?
操作数地址码有6位,二地址指令中的操作码位数有16 - 6 -6 = 4,这四位操作码有16种操作。由于操作码固定,除去零地址指令M种,一地址指令N种,剩下的二地址指令有16 - M - N种。
②采用拓展操作码计数,二地址指令最多有多少种?
2 4 2^4 24 = 16种编码,去掉一种编码(1111)用于一地址指令拓展,二地址指令有15种操作。
③采用拓展操作码技术,若二地址指令有P种,零地址指令有Q种,则一地址指令最多有几种?
二地址、一地址和零地址的操作码长度分别由4位、10位和16位。
二地址指令操作码每减少一种,就可以多构成 2 6 2^6 26种一地址指令操作码;一地址指令操作码每减少一种,就可以多构成 2 6 2^6 26种零地址指令操作码
二地址指令有P种,一地址有 ( 2 4 − P ) × 2 6 (2^4 - P)×2^6 (24P)×26种;若一地址有R种,则零地址指令最多有 [ ( 2 4 − P ) × 2 6 − R ] × 2 6 [(2^4-P)×2^6-R]×2^6 [(24P)×26R]×26种。

5、设相对寻址的转移指令占两个字节,第一字节是操作码,第二字节是相对位移量,用补码表示。每当CPU从存储器取出一个字节后,即自动完成(PC)+1 -> PC。
①设当前PC值为3000H,试问转移后的目标地址范围是什么?
由于相对寻址的转移指令为两字节,第一字节是操作码,第二字节为相对位移量,且用补码表示,范围为-128到127,即80H到7FH。当前PC值为3000H,CPU取出指令后,PC修改为3002H,因此最终转移的目标地址范围为3081H到2F82H。
②设当前PC值为2000H,要求转移到201BH,则转移指令第二字节的内容是什么?
若当前为2000H,取出指令后,变成2002H,201BH - 2002H = 19H
③若当前PC值为2000H,指令JMP * - 9的第二字节的内容是什么?
指令要求,转移后的目标地址为2000H - 09H = 1FF7H,但是取出后,PC变为2002H,所以转移指令第二个字节的内容应该为-11,即F5H。

6、画出完成ADD * + 3 指令的信息流程图(表示相对寻址,另一操作数隐含在ACC中)。假设(PC)= 2000H。
①先从内存中取出ADD
+ 3的指令,送入IR中进行处理
②IR处理之后,由控制器控制PC加上相对寻址的偏移3,得到2003H
③将2003H送入内存中找到操作数
④操作数送至ALU和已经隐藏在ACC中的另一个操作数相加
在这里插入图片描述

  • 10
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
计算机组成原理与汇编语言程序设计课后习题及解答 徐洁,俸远祯 电子工业出版社 第1章 习题一 1.什么是程序存储工作方式? 答:计算机的工作方式——存储程序工作方式。即事先编写程序,再由计算机把这些信息 存储起来,然后连续地、快速地执行程序,从而完成各种运算过程。 2.采用数字化方法表示信息有哪些优点? 用数字化方法表示信息的优点: (1)抗干扰能力强, 可靠性高。 (2)依靠多位数字的组合,在表示数值时可获得很宽的表示范围以及很高的精度。 (3)数字化的信息可以存储、信息传送也比较容易实现。 (4)可表示的信息类型与范围及其广泛,几乎没有限制。 (5)能用逻辑代数等数字逻辑技术进行信息处理,这就形成 了计算机硬件设计的基础。 3.如果有7×9点阵显示出字符A的图像,请用9个七位二进制代码表示A的点阵信息。 4.数字计算机的主要特点是什么? 1. (1) 能在程序控制下自动连续地工作; (2")运算速度快; (3) 运算精度高; (4) 具有很强的信息存储能力; (5) 通用性强,应用领域及其广泛。 5.衡量计算机性能的基本指标有哪些? 答:衡量计算机性能的基本指标: (1)基本字长——参加一次运算的数的位数; (2)数据通路宽度——数据总线一次能并行传送的位数; (3)运算速度——可用 CPU的时钟频率与主频, 每秒平均执行指令数, 典型四则运算的 时间来表示。 (4)主存储器容量——可用字节数或单元数(字数)×位数来表示。 (5)外存容量——常用字节数表示。 (6)配备的外围设备及其性能。 (7)系统软件配置。 7.系统软件一般包括哪些部分?列举你所熟悉的三种系统软件。 系统软件一般包括操作系统,编译程序、解释程序、各种软件平台等。例如WINDOWS98操 作系统,C语言编译程序等,数据库管理系统。 8.对源程序的处理有哪两种基本方式? 对源程序的处理通常有两种处理方式:解释方式和编译方式。 第2章 习题二 1.将二进制数(101010.01)2 转换为十进制数及BCD码。 解:(101010.01)2 = (42.25)10 = (01000010.00100101)BCD 2.将八进制数(37.2)8转换为十进制数及BCD码. 解:(37.2)8 = (31.25)10 =(00110001.00100101)BCD 3.将十六进制数(AC.E)转换为十进制数及BCD码. 解: (AC.E)16 =(172.875)10 = (00010111001 4.将十进制数(75.34)10转换为8位二进制数及八进制数、十六进制数。 解: (75.34)10 = (01001011.01010111)2 =(213.256)8 =(4B.57)16 5.将十进制数13/128转换为二进制数. 解: (13/128)10 =(1101/10000000)2 =(0.0001101)2 6.分别写出下列各二进制数的原码、补码,字长(含一位数符)为8位。 (1)0 (2)- 0 (3)0.1010 (4)- 0.1010 (5)1010 (6)-1010 解: 原码 补码 0 00000000 00000000 -0 10000000 00000000 0.1010 0.1010000 0.1010000 - 0.1010 1.1010000 1.0110000 1010 00001010 00001010 -1010 10001010 11110110 7.若X补=0.1010,则X原、真值等于什么? 解:X补=0.1010,则X原=0.1010,真值 X = 0.1010 8.若X补=1.1010,则X原、真值等于什么? 解:X补=1.1010,则X原=1.0110,真值 X = - 0.0110 9.某定点小数字长16位,含1位符号,原码表示,分别写出下列典型值的二进制代码与十 进制真值。 (1)非0最小正数 (2)最大正数 (3)绝对值最小负数 (4)绝对值最大负数 解: 二进制代码 十进制真值 (1)非0最小正数 0.000000000000001 2-15 1-2-15 (3)绝对值最小负数 1.000000000000001 -2-15 (4)绝对值最大负数 10.某定点小数字长16位,含1位符号,补码表示,分别写出下列典型值的二进制代码与 十进制真值。 (1)非0最小正数 (2)最大正数 (3)绝对值最小负数 (4)绝对值最大负数 解: 二进制代码 十进制真值 (1)非0最小正数 0.000000000000001 2-15 (4)绝对值最大负数 1.000000000000000 -1 11.某浮点数字长16位,其中阶码6位,含1位符号位,补码表示,以2为底;尾数10位(含1位数 符),补码表示,规格化。分别写出下
【目  录】: 第1篇系统篇 第1章嵌入式系统概述3 1.1嵌入式系统的定义和特点3 1.1.1嵌入式系统的定义3 1.1.2嵌入式系统和通用计算机比较4 1.1.3嵌入式系统的特点5 1.2嵌入式系统的硬件6 1.2.1嵌入式处理器7 1.2.2嵌入式存储器15 1.2.3嵌入式I/O设备18 1.2.4嵌入式I/O接口18 1.3嵌入式系统的软件21 1.3.1无操作系统的嵌入式软件22 1.3.2带操作系统的嵌入式软件24 1.4嵌入式系统的分类27 1.4.1按硬件(嵌入式处理器)划分27 1.4.2按软件复杂度划分27 1.4.3按实时性划分28 1.4.4按使用对象划分28 1.5嵌入式系统的应用28 1.5.1国防军事28 1.5.2工业控制29 1.5.3消费电子30 1.5.4办公自动化产品30 1.5.5网络和通信设备30 1.5.6汽车电子31◆嵌入式系统原理及应用目录1.5.7金融商业31 1.5.8生物医学32 1.5.9信息家电32 1.6本章小结34 习题134 第2章嵌入式系统开发35 2.1嵌入式系统的开发环境、开发工具和调试方式35 2.1.1嵌入式系统的开发环境35 2.1.2嵌入式系统的开发工具37 2.1.3嵌入式系统的调试方式43 2.2嵌入式系统的开发语言50 2.2.1嵌入式硬件开发语言50 2.2.2嵌入式软件开发语言51 2.3嵌入式系统的开发过程53 2.3.1需分析54 2.3.2系统设计55 2.3.3系统实现61 2.3.4系统测试70 2.3.5系统发布73 2.4嵌入式开发工程师之路74 2.4.1嵌入式行业和人才的现状分析74 2.4.2嵌入式开发工程师的能力要74 2.4.3嵌入式开发工程师的进阶之路75 2.5本章小结77 习题278 第2篇内核篇 第3章ARM CortexM3处理器81 3.1ARM CortexM3组成结构81 3.1.1CortexM3内核82 3.1.2调试系统84 3.2ARM CortexM3总线接口86 3.2.1CortexM3总线接口类型87 3.2.2CortexM3总线连接方案88 3.3ARM CortexM3编程模型89 3.3.1工作状态89 3.3.2数据类型89 3.3.3寄存器89 3.3.4指令系统93 3.3.5操作模式和特权分级96 3.3.6异常和中断98 3.3.7双堆栈机制105 3.4ARM CortexM3存储器系统107 3.4.1存储器映射107 3.4.2位带操作110 3.4.3存储格式112 3.5ARM CortexM3的低功耗模式113 3.6本章小结114 习题3115 第4章基于ARM CortexM3的STM32微控制器117 4.1从CortexM3到基于CortexM3的MCU117 4.2基于CortexM3的STM32系列微控制器概述118 4.2.1产品线118 4.2.2命名规则124 4.2.3生态系统125 4.2.4开发方法131 4.2.5学习之路134 4.3STM32F103微控制器基础136 4.3.1概述136 4.3.2主系统结构137 4.3.3功能模块139 4.3.4引脚定义140 4.3.5存储器组织141 4.4STM32F103微控制器的最小系统145 4.4.1电源电路145 4.4.2时钟电路148 4.4.3复位电路149 4.4.4调试和下载电路150 4.4.5其他151 4.5STM32F103微控制器的时钟系统153 4.5.1输入时钟153 4.5.2系统时钟155 4.5.3由系统时钟分频得到的其他时钟155 4.5.4STM32F10x时钟系统相关库函数157 4.6STM32F103微控制器的低功耗模式162

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值