当前位置: 首页 > article >正文

实验-使用递归计算阶乘-RISC-V(计算机组成原理)

目录

一、实验内容

二、实验步骤

三、实验效果

四、实验环境

五、实验小结和思考


一、实验内容

一个典型的计算阶乘的递归过程如下图所示:

在这个任务中,一份汇编代码的框架“task4-阶乘”你需要使用RISC-V或MIPS汇编程序以递归的形式解决这个问题。你可能会遇到的挑战包括:(1)如何使用栈保护某些重要的寄存器;(2)如何结合RISC-V的MIPS的jal分支跳转指令实现递归。当你进入测试阶段时,你可以在第4行代码修改n的值:

二、实验步骤

(1)我们利用a2这个寄存器来暂存阶乘的结果,所以在main函数中,我们在跳转前,先加入一条初始化a2为1的指令。

(2)在这里我们首先需要判断n是否为0,如果为0,直接跳到loop函数处,将a2的值赋给a0,再跳回A处(不用调用factorial函数),打印出结果。

(3)如果n不为0,则调用factorial函数,计算阶乘。

(4)首先先保护ra的值,先将sp指针的值减4,然后把ra的值写入当前sp指向的地址处。

(5)将a2和a0寄存器中的值相乘保存到a2寄存器中,然后a0寄存器中的值减一(加-1)。

(6)接着比较a0的值是否为0,不为0则继续递归,如果为0就出栈(把当前sp指向地址的值赋给ra,sp加4)。再把a2的值赋给ra,返回main函数。

(7)最后将a0的值打印出来。

三、实验效果

(1)输入0时的答案:

(2)输入6时的答案

(3)程序运行中栈的变化:

还未调用factorial函数时sp的值:

调用一次factorial函数时sp的值:

可以看到,调用一次factorial函数,sp的值减4。

四、实验环境

 Venus仿真器(https://venus.cs61c.org/)

五、实验小结和思考

  • 问题1:未正确处理递归终止条件(n=0),导致程序陷入无限循环。
    解决:在factorial函数开始时增加beq a0, zero, exit判断,若n=0则直接跳转至返回阶段。

  • 问题2:首次尝试时,未正确保存ra(返回地址),导致递归返回时跳转到错误位置。
    解决:在每次递归调用前,先调整栈指针(addi sp, sp, -4),并存储ra到栈中(sw ra, 0(sp)),返回时再恢复。

  • 问题3:未保护a0(当前n值)和a2(累积结果),导致递归过程中数据丢失。
    解决:在递归调用前将a0a2压栈,返回后恢复,确保数据一致性。

http://www.lryc.cn/news/2384374.html

相关文章:

  • ISO 26262-5 评估硬件架构度量值
  • JMeter 教程:响应断言
  • 【Qt开发】显示类控件——QLCDNumber
  • 深入剖析 5G 核心网中的 PLMN
  • 音频AAC编码与RV1126的AENC模块的讲解
  • vue页面目录菜单有些属性是根据缓存读取的。如果缓存更新了。希望这个菜单也跟着更新。
  • Android开发-Application
  • 在TIA 博途中下载程序时找不到对应的网卡怎么办?
  • 《量子计算实战》PDF下载
  • Linux入门(部分基础相关知识+常用命令+权限)
  • 海拔案例分享-实践活动报名测评小程序
  • JavaWeb面试题 (一)
  • 解决Vue项目依赖错误:使用electron-vite重建
  • vue3样式穿透用法
  • Puppeteer 浏览器自动化操作工具
  • 5G 网络寻呼的信令及 IE 信息分析
  • 信奥赛CSP动态规划入门-最小硬币问题
  • cmd里可以使用npm,vscode里使用npm 报错
  • JAVA开发工具延长方案
  • CSS 浮动(Float)及其应用
  • CC53.【C++ Cont】一维前缀和
  • Python爬虫实战:研究Grab 框架相关技术
  • 每日leetcode
  • YouTube视频字幕转成文章算重复内容吗?
  • 网络学习-利用reactor实现http请求(六)
  • 云原生安全:IaaS安全全解析(从基础到实践)
  • 【IC_Design】跨时钟域的寄存器更新后锁存
  • Spring AI 之提示词
  • 亚远景-汽车软件开发的“升级之路”:ASPICE各等级说明
  • Java微服务架构:Spring Cloud全栈指南,附最新Demo源码,可独立运行!