Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Error while doing sbt "runMain naxriscv.Gen" #140

Open
Rishik-Y opened this issue Mar 12, 2025 · 7 comments
Open

Error while doing sbt "runMain naxriscv.Gen" #140

Rishik-Y opened this issue Mar 12, 2025 · 7 comments

Comments

@Rishik-Y
Copy link
Contributor

Hi @Dolu1990,
i tried testing the program after the new merge,
and it seems i am getting error directly here
sbt "runMain naxriscv.Gen"

Where i get this error:

sbt "runMain naxriscv.Gen"
[info] welcome to sbt 1.6.0 (Oracle Corporation Java 11.0.25)
[info] loading settings for project naxriscv-build from plugins.sbt ...
[info] loading project definition from /home/Kihsir/Downloads/Git/Scala/NaxRiscv/project
[info] loading settings for project root from build.sbt ...
[info] loading settings for project spinalhdl-build from plugin.sbt ...
[info] loading project definition from /home/Kihsir/Downloads/Git/Scala/NaxRiscv/ext/SpinalHDL/project
[info] loading settings for project all from build.sbt ...
[info] set current project to NaxRiscv (in build file:/home/Kihsir/Downloads/Git/Scala/NaxRiscv/)
[info] compiling 127 Scala sources and 3 Java sources to /home/Kihsir/Downloads/Git/Scala/NaxRiscv/target/scala-2.12/classes ...
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/Tracer.scala:175:62: too many arguments (2) for method newContext: (workspace: String)Long
[error]   val handle = Frontend.newContext(workspace.getAbsolutePath,spikeLogFileOut)
[error]                                                              ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/Tracer.scala:193:67: value loadU32 is not a member of object rvls.jni.Frontend
[error]   override def loadU32(address: Long, data: Int): Unit = Frontend.loadU32(handle, address, data)
[error]                                                                   ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/Tracer.scala:198:142: too many arguments (5) for method trap: (handle: Long, hartId: Int, interrupt: Boolean, code: Int)Boolean
[error]   override def trap(hartId: Int, interrupt: Boolean, code: Int, fault_addr: Long): Unit = if(!Frontend.trap(handle, hartId, interrupt, code, fault_addr)) throw new Exception()
[error]                                                                                                                                              ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/tilelinkdemo/SocSim.scala:133:6: value wavePath is not a member of spinal.core.sim.SpinalSimConfig
[error]   sc.wavePath(s"waves/${workspaceOutputSubDir}")
[error]      ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/tilelinkdemo/SocSim.scala:201:34: overloaded method value withCb with alternatives:
[error]   [T <: spinal.core.Component](compiled: spinal.core.sim.SimCompiled[T], window: Long, seed: Int)(testbench: (T, (=> Unit) => Unit) => Unit)Unit <and>
[error]   [T <: spinal.core.Component](compiled: spinal.core.sim.SimCompiled[T], window: Long, seed: Int, dualSimEnable: Boolean)(testbench: (T, (=> Unit) => Unit) => Unit)Unit
[error]  cannot be applied to (spinal.core.sim.SimCompiled[naxriscv.platform.tilelinkdemo.SocSim.SocDemoSim], window: Int, seed: Int, String, runBuildroot: Boolean)
[error]       case true => DualSimTracer.withCb(compiled, window = 50000 * 10, seed = 2, file, runBuildroot = false)(testIt)
[error]                                  ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/tilelinkdemo/SocSim.scala:201:110: missing argument list for method testIt in object SocSim
[error] Unapplied methods are only converted to functions when a function type is expected.
[error] You can make this conversion explicit by writing `testIt _` or `testIt(_,_,_,_)` instead of `testIt`.
[error]       case true => DualSimTracer.withCb(compiled, window = 50000 * 10, seed = 2, file, runBuildroot = false)(testIt)
[error]                                                                                                              ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/tilelinkdemo/SocSim.scala:211:34: overloaded method value withCb with alternatives:
[error]   [T <: spinal.core.Component](compiled: spinal.core.sim.SimCompiled[T], window: Long, seed: Int)(testbench: (T, (=> Unit) => Unit) => Unit)Unit <and>
[error]   [T <: spinal.core.Component](compiled: spinal.core.sim.SimCompiled[T], window: Long, seed: Int, dualSimEnable: Boolean)(testbench: (T, (=> Unit) => Unit) => Unit)Unit
[error]  cannot be applied to (spinal.core.sim.SimCompiled[naxriscv.platform.tilelinkdemo.SocSim.SocDemoSim], window: Int, seed: Int, String, runBuildroot: Boolean)
[error]       case true => DualSimTracer.withCb(compiled, window = 50000 * 10, seed = 2, file, runBuildroot = true)(testIt)
[error]                                  ^
[error] /home/Kihsir/Downloads/Git/Scala/NaxRiscv/src/main/scala/naxriscv/platform/tilelinkdemo/SocSim.scala:211:109: missing argument list for method testIt in object SocSim
[error] Unapplied methods are only converted to functions when a function type is expected.
[error] You can make this conversion explicit by writing `testIt _` or `testIt(_,_,_,_)` instead of `testIt`.
[error]       case true => DualSimTracer.withCb(compiled, window = 50000 * 10, seed = 2, file, runBuildroot = true)(testIt)
[error]                                                                                                             ^
[error] 8 errors found
[error] (Compile / compileIncremental) Compilation failed
[error] Total time: 14 s, completed Mar 11, 2025, 12:51:30 PM

It could very well be a me issue but looking at the error seems possibly some code issue?

@Dolu1990
Copy link
Member

@Bill94l Hi,

I don't know how, but apparently, the automated regressions didn't cached issues ?
Seems like the RVLS being used when cloning the master branch isn't in sync ?

I have the same issue when cloning a fresh NaxRiscv main branch.

@Bill94l
Copy link
Contributor

Bill94l commented Mar 14, 2025

Hi @Dolu1990, @Rishik-Y,

The error you are encountering is due to the fact that you haven’t run the make install command. Without this step, some essential patches are not applied:

  • RVLS patch (files rvls.diff and rvls.patch)

  • Patch for the SpinalHDL library (file adding_wavePath_simConfig.patch)

Follow the instructions available in the src/test/README file, to properly install and avoid this error :

# Clone repository
git clone https://github.com/SpinalHDL/NaxRiscv.git
cd NaxRiscv
export NAXRISCV=$(pwd)  # Set environment variable

# Full installation (toolchain + core + simulators)
make install
sbt "runMain naxriscv.Gen"

@Dolu1990 If you confirm that the RVLS and SpinalHDL patches are validated on your side, I can then submit a pull-request to integrate these changes and remove patches. I will also update the README and the RVLS hash, although that is not directly related to the error you are experiencing.

Have a nice weekend ^^

@Dolu1990
Copy link
Member

Dolu1990 commented Mar 14, 2025

Ahhhhh, hmmm, we could merge those rvls patch into a proper rvls branch ?

Have a nice week-end too :D

@Bill94l
Copy link
Contributor

Bill94l commented Mar 14, 2025

Hello,

The patches are already available in your current main branch, so there is no need to merge them.

Image

If you prefer that we remove the patches, I can directly integrate the patch code into RVLS and SpinalHDL, if that works for you.

@Rishik-Y
Copy link
Contributor Author

Rishik-Y commented Mar 14, 2025

Hi @Dolu1990 @Bill94l
FIrst of Thanks very much for your answers!

I am bit confused? 😓
Sorry about it
But why is there two different readme over here?

Follow the instructions available in the src/test/README file, to properly install and avoid this error :

I understand i probably would have to follow this code

But what is this readme exactly for?

As in the documentation redirects to this

Also as @Bill94l, it is indeed most likely to be make install issue..
I am still trying to figure out how exactly i could run it in NixOS

@Dolu1990
Copy link
Member

@Bill94l I mean to merge those files into the real repository ^^
having patch files may increase maintenance overhead in the future, as it is very lose.

@Bill94l
Copy link
Contributor

Bill94l commented Mar 14, 2025

I am bit confused? 😓

Existing Documentation

  • The README located in src/test/cpp/naxriscv provides a step-by-step guide on how to install the tools to run regression tests with the simulator available in that folder. (Note: I forgot to update this README to indicate that the adding_wavePath_simConfig.patch needs to be applied.)

  • The README in src/test/, on the other hand, explains how to install the toolchain using the Makefile (which utilizes the scripts available in the ci/ folder) and how to run regression tests via RVLS for a lockstep simulation.

But why is there two different readme over here?

You are correct in noticing the redundancy. To avoid confusion, we plan to merge these two README files into one, placing it in src/test/ to provide both a step-by-step installation guide and the Makefile solution.

As in the documentation redirects to this

We also need to update this link to reflect the changes.

having patch files may increase maintenance overhead in the future, as it is very lose.

I'm agree to integrate the patch code directly into RVLS and SpinalHDL

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants