From 26d6f61d49f6e02cb3fe7093accae3ed94f54d3e Mon Sep 17 00:00:00 2001 From: Gongqi Huang Date: Sat, 9 Mar 2024 20:49:37 -0500 Subject: [PATCH] Fix SMP compile-time error when disabling supervisor When generating SMP configuration with supervisor disable, the compiler stucks at waiting for the signal from `externalSupervisorInterrupt`, which is generated conditionally based on `withSupervisor` option. --- src/main/scala/vexriscv/VexRiscv.scala | 5 +++++ src/main/scala/vexriscv/demo/smp/VexRiscvSmpCluster.scala | 4 +++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/main/scala/vexriscv/VexRiscv.scala b/src/main/scala/vexriscv/VexRiscv.scala index 2f4917f5..fcad68a7 100644 --- a/src/main/scala/vexriscv/VexRiscv.scala +++ b/src/main/scala/vexriscv/VexRiscv.scala @@ -53,6 +53,11 @@ case class VexRiscvConfig(){ case None => false } + def withSupervisor = find(classOf[CsrPlugin]) match { + case Some(x) => x.config.supervisorGen + case None => false + } + def FLEN = if(withRvd) 64 else if(withRvf) 32 else 0 //Default Stageables diff --git a/src/main/scala/vexriscv/demo/smp/VexRiscvSmpCluster.scala b/src/main/scala/vexriscv/demo/smp/VexRiscvSmpCluster.scala index 854828f3..8be22041 100644 --- a/src/main/scala/vexriscv/demo/smp/VexRiscvSmpCluster.scala +++ b/src/main/scala/vexriscv/demo/smp/VexRiscvSmpCluster.scala @@ -206,7 +206,9 @@ class VexRiscvSmpClusterWithPeripherals(p : VexRiscvSmpClusterParameter) extends plic.priorityWidth.load(2) plic.mapping.load(PlicMapping.sifive) plic.addTarget(core.cpu.externalInterrupt) - plic.addTarget(core.cpu.externalSupervisorInterrupt) + if(core.cpu.config.withSupervisor) { + plic.addTarget(core.cpu.externalSupervisorInterrupt) + } List(clint.logic, core.cpu.logic).produce { for (plugin <- core.cpu.config.plugins) plugin match { case plugin: CsrPlugin if plugin.utime != null => plugin.utime := clint.logic.io.time