

# 四川大学期末考试试题（闭卷）

## (2019——2020 学年 秋 学期) A 卷

课程号: 304036030 课序号: 课程名称: 计算机组装原理 任课教师: 成绩:  
适用专业年级: 学生人数: 印题份数: 学号: 姓名:

### 考生承诺

我已认真阅读并知晓《四川大学考场规则》和《四川大学本科学生考试违纪作弊处分规定（修订）》，郑重承诺：

- 1、已按要求将考试禁止携带的文具用品或与考试有关的物品放置在指定地点；
- 2、不带手机进入考场；
- 3、考试期间遵守以上两项规定，若有违规行为，同意按照有关条款接受处理。

考生签名:

### 一、选择题 （本大题共 15 空，每空 2 分，共 30 分）

1. mips 指令 sw \$t0,-1(\$t1) 立即数字段符号扩展后是（ ）  
A. 0x1111  
B. 0x11111111  
C. 0xffff  
D. 0xffffffff
2. 8 位五选一多路选择器控制线位数是（ ）  
A. 1      B. 2      C. 3      D. 8
3. mips 指令中，下面那条指令不能实现数据从一个寄存器传输到另一个寄存器（ ）  
A. add      B. lw      C. sub      D. addi
4. 在程序的执行过程中，Cache 与主存的地址映射是由（ ）  
A. 由硬件自动完成的  
B. 程序员调度的  
C. 操作系统来管理的  
D. 用户软件完成
5. 同一个程序，在同一台计算机的 CPU 超频前和超频后运行，假设内存的访问速度不变，超频前和超频后 CPI 对比应该是（ ）  
注：CPU 超频是指增大 CPU 的时钟频率  
A. 超频前的 CPI 大  
B. 超频后的 CPI 大

- C. 一样大  
D. 无法判断
6. 在下列因素中，与 Cache 的命中率无关的是（ ）  
A. Cache 块的大小  
B. Cache 的容量  
C. 主存的存取时间  
D. Cache 的映射方式
7. 关于虚拟内存，下列描述错误的是（ ）  
A. 每个进程的虚拟内存空间是独立的  
B. 虚拟内存页有可能映射到磁盘上  
C. 虚拟内存采用全关联映射  
D. 虚拟内存采用硬件的方法来处理页缺失
8. 32 位二进制补码 1111 1111 1111 1111 1111 1111 1111 0011<sub>(2)</sub> 对应的十进制真值是（ ）  
A. -3              B. -13              C. -14              D. -15
9. mips 指令 jal 隐含使用了哪个寄存器（ ）  
A. \$at              B. \$sp              C. \$ra              D. \$fp
10. 对于浮点数乘法运算，下面描述的那个过程是错误的或是不需要的（ ）  
A. 相乘前对阶，对阶的规则是小阶向大阶对齐  
B. 尾数相乘，指数相加  
C. 指数运算结果需要减去偏阶进行修正  
D. 对运算结果进行规格化，一般是右规
11. 下面关于活动记录（过程帧）的描述，错误的是（ ）  
A. mips 的活动记录是指起始地址为[\$sp]和[\$fp]的内存空间  
B. 活动记录在进入过程时创建，在退出过程时销毁  
C. 全局变量保存在活动记录中  
D. 活动记录的创建和销毁是编译器产生的代码自动完成的
12. mips 指令 slti \$t1,\$t0,32 的代码是（ ）  
注：slti 的操作码为 10, \$t0 编号为 8, \$t1 编号为 9  
A. 0x29090032  
B. 0x29280032

- C. 0x29280020  
D. 0x29090020
13. 下面关于 DRAM 和 SRAM 的描述，错误的是（ ）  
A. SRAM 速度比 DRAM 快，耗电量也比 DRAM 低  
B. DRAM 存储原理是电容保存电荷，需要定时刷新  
C. DRAM 和 SRAM 都是随机存储器，掉电后数据都不能保存  
D. SRAM 存储单元和寄存器的存储原理相同
14. 下面关于硬盘的描述，错误的是（ ）  
A. 扇区是硬盘存储数据的最小寻址单位  
B. 硬盘的存取时间和数据的存储位置无关  
C. 硬盘是磁表面存储器，存储的数据需要加上校验位  
D. 相同长度内，外环的磁道存储数据量小于内环的磁道
15. 关于常用编程语言，下列说法错误的是（ ）  
A. 汇编语言就是机器语言，CPU 可以直接执行汇编代码  
B. C 语言是编译型语言，编写的代码需要经过编译、汇编、链接才可以形成可执行程序  
C. java 编写的程序可以在不同平台下运行  
D. java 程序运行需要 java 虚拟机对 java 程序进行解释

## 二、分析计算题（本大题共 4 小题，每小题 5 分，共 20 分）

- 1、求 10 进制数 9（共 4 位二进制位）的海明校验码（每组采用奇校验，要求写出分组和计算过程）。(5 分)
- 2、IEEE754-2008 包含一种“半精度”格式，只有 16 位宽，最高位是数符，指数是 5 位宽且偏阶为 15 的移码表达，尾数有 10 位宽，具有隐含 1。写出 10 进制 -9.625 的半精度二进制位表达式 (5 分)
- 3、使用补码一位乘法计算  $-13_{(10)} \times 9_{(10)}$ 。（乘数和被乘数的补码位宽都是 5 位，含 1 位符号位，要求写出计算过程及每一步中各个寄存器的值）。(5 分)
- 4、假设当前指令 `beq $zero, $t1, 4` 的内存地址为 0x4A0020，如果 \$t1 中的数据为 0，指令执行完成后程序计数器 PC 的值是多少？(要求结果表达为

16 进制)。(5 分)

### 三、应用题 (本大题共 2 小题, 每小题 10 分, 共 20 分)

1、请将下面的 C 语言程序翻译为 MIPS 汇编语言程序。(10 分)

```
int Sum(int pArray[], int nCount)
{
    int i, sum = 0;
    for (i = 0; i < nCount; i++)
        sum += pArray[i];
    return sum;
}
```

(数组 pArray 的首地址保存在\$a0 中, 数组元数数目 nCount 保存在\$a1 中, 返回结果保存在\$v0 中)

2、设主存的容量是 256KB, Cache 的容量是 1KB, 每个块的大小为 32B, 采用直接关联映像。

问 1). 主存和 Cache 各有多少个块? (2 分)

2). 请问索引 Index 位是多少位? 标记 Tag 位是多少位? (2)

3). 假设开始时 Cache 为空, 按下列内存字节地址进行访问, 每次读取 1 个字: (内存字节地址访问顺序: 0x24, 0x52A, 0x30)

请列出每一次访问内存时的<标记、索引、块内偏移量>, 并判断每次访问内存时 Cache 是否命中。(6 分)

#### 四、数据通路分析与设计（本大题共 2 小题，每小题 15 分，共 30 分）

1、下图是单周期处理器的数据通路图：



1) 处理器执行 `sw $t1, 32($t2)` 指令（指令地址为  $1000_{(10)}$ ）， $t2$  中保存的数值为  $2000_{(10)}$ ，写出 ALU 输出结果，写出右上角加法器的输出结果（10 进制）

(5 分)

2) 请写出处理器执行上述指令时，控制器产生的控制信号值（10 分）

| RegDst | ALUSrc | MemRead | MemWrite | Branch | ALUOp1 | Jump |
|--------|--------|---------|----------|--------|--------|------|
|        |        |         |          |        |        |      |

2、下图是多周期处理器的数据通路（能够实现 lw、sw、R-type、beq 以及 j 指令）：



- 1) 请用 RTL 描述指令在取指周期的执行过程，并给出在取指周期主要控制信号和信号值（5 分）
- 3) 上述电路能否不添加硬件和控制信号的情况下执行 jr \$ra 指令（jr 指令是从过程中返回的跳转指令，\$ra 的编号是 31，在指令中的 rs 字段）？如果能，请给出指令设计方案，用 RTL 描述该指令在执行周期的执行过程，并给出主要相关的控制信号；如果不能，请给出电路修改方案，用 RTL 描述修改过后的指令执行周期的执行过程，并给出主要相关的控制信号（注：原则上能不修改电路就不修改）（10 分）