上一页 1 2 3 4 5 6 ··· 9 下一页
摘要: difftest在测试集中可以起到十分重要的作用,可以快速找到发生问题的指令和pc寄存器地址。在nemu作为dut,参考其他模拟器(比如spike)的功能中,大部分代码已经完成,我们只需要完成寄存器的比对即可。但在RTL中重新实现这一功能或者类似功能时,我们需要完成更多函数,但大体的框架已经完成,我 阅读全文
posted @ 2024-12-05 18:35 namezhyp 阅读(413) 评论(0) 推荐(0)
摘要: nemu本身自带了将自己编译为动态库的功能,在menuconfig->build target里选择shared object即可。 在编译完成后,build文件夹里就会出现riscv32-nemu-interpreter-so这个库。首先可以用file命令检查文件,只要返回信息是lsb,share 阅读全文
posted @ 2024-12-03 18:19 namezhyp 阅读(292) 评论(0) 推荐(0)
摘要: 首先看一下讲义里提到的yield os,这个os里面只有两道程序切换的模拟内容,只要做过pa3就很容易理解: #define STACK_SIZE (4096 * 8) typedef union { uint8_t stack[STACK_SIZE]; struct { Context *cp; 阅读全文
posted @ 2024-11-16 23:18 namezhyp 阅读(506) 评论(0) 推荐(0)
摘要: 用户程序从main开始,而调用用户程序的就是navyapps里crt0的start.S,这个汇编代码会调用crt0.c里面的call_main()函数,然后调用用户程序的main(),用户程序执行完了以后,返回crt0.c,继续执行exit()。然后结束。 如何解决“不知道程序要被放到哪里”这个问题 阅读全文
posted @ 2024-11-03 16:21 namezhyp 阅读(44) 评论(0) 推荐(0)
摘要: 一般情况下,我们在vscode里编辑C/C++代码时用的都是微软的c++ package,但是这个插件包很多时候无法正确分析出语法,导致大量虚假错误报告,为了解决这个问题,我们首先禁用掉C++插件包,然后准备更换clangd。 clangd是一个基于Clangd的分析服务器,方便我们分析代码语法。为 阅读全文
posted @ 2024-08-05 18:40 namezhyp 阅读(1557) 评论(0) 推荐(0)
摘要: nemu把库函数分为了与架构有关的isa部分和与架构无关的klib部分。这部分的任务,就是完善stdio.c stdlib.c 和string.c,让各种测试集、跑分和demo可以正常运行。值得一提的是,我也是看到这一部分,回看测试集时,才注意到测试集用的其实都是C语言自带的关键字和基本功能,没有使 阅读全文
posted @ 2024-08-01 15:54 namezhyp 阅读(254) 评论(0) 推荐(0)
摘要: 尽管指令匹配的部分早就已经完成,但这并不代表代码方面就不会再检测出漏洞。cpu-test这个测试集文件夹里面的测试代码只是覆盖了一部分内容,即使是全部通过,你的代码也仍有可能是错误的。 当我在处理其他内容时,突然间nemu就卡在了代码某处提示地址错误。重新打开difftest,定位到某处jal跳转发 阅读全文
posted @ 2024-07-30 23:45 namezhyp 阅读(116) 评论(0) 推荐(0)
摘要: dummy的反汇编表: 80000000 <_start>: 80000000: 00000413 li s0,0 80000004: 00009117 auipc sp,0x9 80000008: ffc10113 addi sp,sp,-4 # 80009000 <_end> 8000000c: 阅读全文
posted @ 2024-07-11 12:18 namezhyp 阅读(271) 评论(0) 推荐(0)
摘要: ysyx的nvboard项目里自带了一个example,用来演示功能,同时也给出了简单的使用说明。 要将自己的verilog代码接入nvboard,首先需要生成一份nvboard.a库文件。在nvboard目录下make nvboardarchive,然后将库文件放到npc文件夹下的目录文件。库文件 阅读全文
posted @ 2024-06-13 14:58 namezhyp 阅读(1479) 评论(5) 推荐(0)
摘要: 要解析一个带有括号的长表达式并没有想象中那么容易。 首先,数学表达式的递归分解顺序和日常的顺序是完全相反的。在标准的数学四则表达式里,我们的计算顺序是从左往右,从高到低,优先计算括号内容。 由于我们使用的是递归的思路,代码拆分表达式的过程和计算顺序是完全相反的: 一方面,原本的高优先级级运算符要后进 阅读全文
posted @ 2024-06-03 17:39 namezhyp 阅读(287) 评论(0) 推荐(0)
上一页 1 2 3 4 5 6 ··· 9 下一页