Comments (8)
B extension does not require special handling in DiffTest, since B extension uses the same general-purpose registers as the RV64GC.
Difftest requires extra bundles defined for F/D, Vector (DiffArchVecRegState
, DiffVecCSRState
) and Hypervisor (DiffHCSRState
) extensions.
Therefore, not supporting B extension should not be related to difftest.
If you find rocket not support B ext, please refer to rocket readme/help for how to enable this extension.
If you find the simulation framework unable to test B extensions, it's most likely you are not using a reference model (NEMU/Spike) with B extension enabled. You may refer to their readme to see how to enable B extension.
from difftest.
Thank you for your prompt response.
I followed your suggestions and made modifications to both Rocket and Spike, and it worked for the B ext ! 😊
However, could you provide more information or approaches on how to support the V extension?
Thanks!
from difftest.
Never mind, it seems that Xiangshan is a good example to learn how to support other extensions. You can close this issue whenever you like.
Thank you.
from difftest.
After the changes, the log output at the top shows:
The first instruction of core 0 has commited. Difftest enabled.
No instruction of core 0 commits for 500 cycles, maybe get stuck
(please also check whether a fence.i instruction requires more than 500 cycles to flush the icache)
Let REF run one more instruction.
...
> The normal instruction flow is displayed below.
May I ask if this prompt can be ignored?
from difftest.
However, could you provide more information or approaches on how to support the V extension?
Besides XiangShan, which is a good start point, I would recommend just reading the Difftest.scala
. You can infer from the Bundle definitions that only DiffArchVecRegState
, DiffVecCSRState
are for vector (also can be seen from the commit 4ec40ea). Thus, the only thing to do is instantiting the corresponding DifftestModule in the design-under-test the same way as other bundles. I believe it would be easy for you to add these bundles in your own design.
from difftest.
After the changes, the log output at the top shows:
The first instruction of core 0 has commited. Difftest enabled. No instruction of core 0 commits for 500 cycles, maybe get stuck (please also check whether a fence.i instruction requires more than 500 cycles to flush the icache) Let REF run one more instruction. ... > The normal instruction flow is displayed below.
May I ask if this prompt can be ignored?
It means the design-under-test may be stucked (no commits for 500 cycles) at executing some instruction.
While this cannot be ignored, this suggests something wrong with the design-under-test or how you connect them. DiffInstrCommit does not receive any commit in the last 500 cycles.
If the design does take more than 500 cycles to execute, you may need to enlarge this limit in difftest.h.
However, the more likely reason is, just as it says, the design-under-test may be stucked at some instruction. You can see from the logs displayed for the last instruction executed (marked as <-
). You can check the design-under-test why this instruction does not commit in the last 500 cycles.
from difftest.
Never mind, it seems that Xiangshan is a good example to learn how to support other extensions. You can close this issue whenever you like.
I'm closing this issue to indicate the completion. However, you can still reply to this issue to track future problems.
If you encounter another problem, please feel free to raise a new issue with the corresponding title for the new problem.
from difftest.
Thank you for your detailed explanation and kind reminder!
from difftest.
Related Issues (20)
- RefProxy void (*memcpy)的调用传参错误 HOT 1
- Difftest::step()中实际上没有完成比较,proxy->regcpy(ref_regs_ptr, REF_TO_DUT)将NEMU的reg val全部copy到DUT,二者永远相等 HOT 1
- Snapshot timestamp t not updated in while loop for simulation HOT 2
- 请问XiangShan上怎么enable smp-difftest? HOT 2
- Difftest is not compatible with Chisel Definition/Instance
- 请问difftest中的DiffTestState 的定义在哪 我没有找到它 HOT 3
- When using Spike as REF, it fails to correctly synchronize the DUT's state during exceptions HOT 2
- AbstractRefProxy 声明了与reference model 不相同的函数原型 HOT 3
- 覆盖率导向模糊测试相关流程使用 HOT 7
- 请问怎么把difftest的打印信息输出到log?有相关功能吗,应该怎么修改代码?
- Difftest环境移植问题 HOT 2
- move指令消除问题 HOT 4
- Rocket-chip difftest框架使用 HOT 1
- Links for Difftest docs HOT 1
- clock/timescale and reset in the generated waveform HOT 2
- Proposal to remove ssh remote on verilator.mk HOT 2
- Integrating VIP into DiffTest HOT 4
- sync/async read of ram HOT 1
- 仿真加速 HOT 6
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from difftest.