首页 > 试题广场 >

(12分)某程序中有如下循环代码段”for(inti=0;i

[问答题]
(12 分)某程序中有如下循环代码段”for(int i = 0; i < N; i++) sum+=A[i];”。假设编译时变量sum 和i 分别分配在寄存器R1 和R2 中。常量N 在寄存器R6 中,数组A 的首地址在寄存器R3 中。程序段P 起始地址为0804 8100H,对应的汇编代码和机器代码如下表所示。

        执行上述代码的计算机M采用32位定长指令字,其中分支指令bne 采用如下格式:
                               

        OP 为操作码Rs和Rd 为寄存器编号;OFFSET 为偏移量,用补码表示。请回答下列问题,并说明理由。

1)M 的存储器编址单位是什么?

2) 已知sll 指令实现左移功能,数组A 中每个元素占多少位?

3) 题44 表中bne 指令的OFFSET 字段的值是多少?已知bne 指令采用相对寻址方式,当前PC 内容为bne 指令地址,通过分析题44 表中指令地址和bne 指令内容,推断出bne 指令的转移目标地址计算公式。

4) 若M 采用如下“按序发射、按序完成”的 5 级指令流水线:IF(取值)、ID(译码及取数)、EXE(执行)、MEM(访存)、WB(写回寄存器),且硬件不采取任何转发措施,分支指令的执行均引起3 个时钟周期的阻塞,则P 中哪些指令的执行会由于数据相关而发生流水线阻塞?哪条指令的执行会发生控制冒险?为什么指令1 的执行不会因为与指令5 的数据相关而发生阻塞?

这道题你会答吗?花几分钟告诉大家答案吧!