From ba42f718135a915d88c30fc817575de6cdf8514d Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Mon, 30 Oct 2017 14:29:25 +0100 Subject: [PATCH 1/5] pass VexRiscv regressions --- build.sbt | 6 +++--- src/main/scala/vexriscv/Stage.scala | 11 +++++------ src/main/scala/vexriscv/TestsWorkspace.scala | 2 +- src/main/scala/vexriscv/demo/GenSmallestNoCsr.scala | 2 +- .../scala/vexriscv/plugin/DecoderSimplePlugin.scala | 10 +++++----- 5 files changed, 15 insertions(+), 16 deletions(-) diff --git a/build.sbt b/build.sbt index 038d4ca..2786cc0 100644 --- a/build.sbt +++ b/build.sbt @@ -9,7 +9,7 @@ scalaVersion := "2.11.8" EclipseKeys.withSource := true libraryDependencies ++= Seq( - "com.github.spinalhdl" % "spinalhdl-core_2.11" % "0.10.15", - "com.github.spinalhdl" % "spinalhdl-lib_2.11" % "0.10.15", + "com.github.spinalhdl" % "spinalhdl-core_2.11" % "0.11.0", + "com.github.spinalhdl" % "spinalhdl-lib_2.11" % "0.11.0", "org.yaml" % "snakeyaml" % "1.8" -) \ No newline at end of file +) diff --git a/src/main/scala/vexriscv/Stage.scala b/src/main/scala/vexriscv/Stage.scala index eb121e2..57d2a8d 100644 --- a/src/main/scala/vexriscv/Stage.scala +++ b/src/main/scala/vexriscv/Stage.scala @@ -12,13 +12,12 @@ class Stageable[T <: Data](val dataType : T) extends HardType[T](dataType) with class Stage() extends Area{ def outsideCondScope[T](that : => T) : T = { - val condStack = GlobalData.get.conditionalAssignStack.stack.toList - val switchStack = GlobalData.get.switchStack.stack.toList - GlobalData.get.conditionalAssignStack.stack.clear() - GlobalData.get.switchStack.stack.clear() + val body = Component.current.dslBody + body.push() + val swapContext = body.swap() val ret = that - GlobalData.get.conditionalAssignStack.stack.pushAll(condStack.reverseIterator) - GlobalData.get.switchStack.stack.pushAll(switchStack.reverseIterator) + body.pop() + swapContext.appendBack() ret } diff --git a/src/main/scala/vexriscv/TestsWorkspace.scala b/src/main/scala/vexriscv/TestsWorkspace.scala index 44a5150..95d1314 100644 --- a/src/main/scala/vexriscv/TestsWorkspace.scala +++ b/src/main/scala/vexriscv/TestsWorkspace.scala @@ -28,7 +28,7 @@ import spinal.lib.eda.altera.{InterruptReceiverTag, ResetEmitterTag} object TestsWorkspace { def main(args: Array[String]) { - SpinalVerilog { + SpinalConfig(mergeAsyncProcess = false).generateVerilog { val configFull = VexRiscvConfig( plugins = List( new PcManagerSimplePlugin( diff --git a/src/main/scala/vexriscv/demo/GenSmallestNoCsr.scala b/src/main/scala/vexriscv/demo/GenSmallestNoCsr.scala index bbc8d27..096394a 100644 --- a/src/main/scala/vexriscv/demo/GenSmallestNoCsr.scala +++ b/src/main/scala/vexriscv/demo/GenSmallestNoCsr.scala @@ -54,5 +54,5 @@ object GenSmallestNoCsr extends App{ ) ) ) - SpinalVerilog(cpu()) + SpinalConfig(mergeAsyncProcess = false).generateVerilog(cpu()) } diff --git a/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala b/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala index cbcb5d5..299d084 100644 --- a/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala +++ b/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala @@ -83,11 +83,11 @@ class DecoderSimplePlugin(catchIllegalInstruction : Boolean) extends Plugin[VexR stageables.foreach(e => { defaults.get(e) match { case Some(value) => { - value.input match { + value.head.source match { case literal: EnumLiteral[_] => literal.fixEncoding(e.dataType.asInstanceOf[SpinalEnumCraft[_]].getEncoding) case _ => } - defaultValue += value.input.asInstanceOf[Literal].getValue << offset + defaultValue += value.head.source .asInstanceOf[Literal].getValue << offset defaultCare += ((BigInt(1) << e.dataType.getBitsWidth) - 1) << offset } @@ -102,12 +102,12 @@ class DecoderSimplePlugin(catchIllegalInstruction : Boolean) extends Plugin[VexR var decodedValue = defaultValue var decodedCare = defaultCare for((e, literal) <- values){ - literal.input match{ + literal.head.source match{ case literal : EnumLiteral[_] => literal.fixEncoding(e.dataType.asInstanceOf[SpinalEnumCraft[_]].getEncoding) case _ => } val offset = offsetOf(e) - decodedValue |= literal.input.asInstanceOf[Literal].getValue << offset + decodedValue |= literal.head.source.asInstanceOf[Literal].getValue << offset decodedCare |= ((BigInt(1) << e.dataType.getBitsWidth)-1) << offset } (Masked(key.value,key.careAbout),Masked(decodedValue,decodedCare)) @@ -145,7 +145,7 @@ class DecoderSimplePlugin(catchIllegalInstruction : Boolean) extends Plugin[VexR val stageables = encodings.flatMap(_._2.map(_._1)).toSet stageables.foreach(e => out(RegNext(RegNext(toplevel.decode.insert(e)).setName(e.getName())))) if(catchIllegalInstruction) out(RegNext(RegNext(toplevel.decode.insert(LEGAL_INSTRUCTION)).setName(LEGAL_INSTRUCTION.getName()))) - toplevel.getAdditionalNodesRoot.clear() + // toplevel.getAdditionalNodesRoot.clear() } } } From d6777ae8ec7ac212c070f73324b58d1a706d12c8 Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Thu, 9 Nov 2017 20:10:56 +0100 Subject: [PATCH 2/5] usetRegIfNoAssign upgrade --- src/main/scala/vexriscv/plugin/CsrPlugin.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/scala/vexriscv/plugin/CsrPlugin.scala b/src/main/scala/vexriscv/plugin/CsrPlugin.scala index 4c3c310..47996aa 100644 --- a/src/main/scala/vexriscv/plugin/CsrPlugin.scala +++ b/src/main/scala/vexriscv/plugin/CsrPlugin.scala @@ -337,7 +337,7 @@ class CsrPlugin(config : CsrPluginConfig) extends Plugin[VexRiscv] with Exceptio val exceptionPortCtrl = if(exceptionPortsInfos.nonEmpty) new Area{ val firstStageIndexWithExceptionPort = exceptionPortsInfos.map(i => indexOf(i.stage)).min val exceptionValids = Vec(Bool,stages.length) - val exceptionValidsRegs = Vec(Reg(Bool) init(False), stages.length) + val exceptionValidsRegs = Vec(Reg(Bool) init(False), stages.length).unsetRegIfNoAssignement val exceptionContext = Reg(ExceptionCause()) val pipelineHasException = exceptionValids.orR //TODO FMAX maybe could be partialy pipelined From c3a7f4e58c9ec6061264dc9a2449d601ae2c4f0b Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Fri, 10 Nov 2017 00:59:31 +0100 Subject: [PATCH 3/5] CSR unsetRegIfNoAssignement fix BranchPlugin doesn't emit the prediction cache when the STATIC setup is used --- src/main/scala/vexriscv/plugin/BranchPlugin.scala | 4 ++-- src/main/scala/vexriscv/plugin/CsrPlugin.scala | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/main/scala/vexriscv/plugin/BranchPlugin.scala b/src/main/scala/vexriscv/plugin/BranchPlugin.scala index f6c0e39..4276b91 100644 --- a/src/main/scala/vexriscv/plugin/BranchPlugin.scala +++ b/src/main/scala/vexriscv/plugin/BranchPlugin.scala @@ -147,8 +147,8 @@ class BranchPlugin(earlyBranch : Boolean, import pipeline._ import pipeline.config._ - val historyCache = Mem(BranchPredictorLine(), 1 << historyRamSizeLog2) setName("branchCache") - val historyCacheWrite = historyCache.writePort + val historyCache = if(prediction == DYNAMIC) Mem(BranchPredictorLine(), 1 << historyRamSizeLog2) setName("branchCache") else null + val historyCacheWrite = if(prediction == DYNAMIC) historyCache.writePort else null //Read historyCache if(prediction == DYNAMIC) fetch plug new Area{ diff --git a/src/main/scala/vexriscv/plugin/CsrPlugin.scala b/src/main/scala/vexriscv/plugin/CsrPlugin.scala index 47996aa..57c4470 100644 --- a/src/main/scala/vexriscv/plugin/CsrPlugin.scala +++ b/src/main/scala/vexriscv/plugin/CsrPlugin.scala @@ -260,10 +260,10 @@ class CsrPlugin(config : CsrPluginConfig) extends Plugin[VexRiscv] with Exceptio //Define CSR registers val misa = new Area{ - val base = Reg(UInt(2 bits)) init(U"01") - val extensions = Reg(Bits(26 bits)) init(misaExtensionsInit) + val base = Reg(UInt(2 bits)) init(U"01") unsetRegIfNoAssignement + val extensions = Reg(Bits(26 bits)) init(misaExtensionsInit) unsetRegIfNoAssignement } - val mtvec = RegInit(U(mtvecInit,xlen bits)) + val mtvec = RegInit(U(mtvecInit,xlen bits)) unsetRegIfNoAssignement val mepc = Reg(UInt(xlen bits)) val mstatus = new Area{ val MIE, MPIE = RegInit(False) From 3060296b94f9ed60d4252fc712dcdb92eb054fc5 Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Fri, 10 Nov 2017 11:33:04 +0100 Subject: [PATCH 4/5] unsetRegIfNoAssignement -> allowUnsetRegToAvoidLatch --- src/main/scala/vexriscv/plugin/CsrPlugin.scala | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/main/scala/vexriscv/plugin/CsrPlugin.scala b/src/main/scala/vexriscv/plugin/CsrPlugin.scala index 57c4470..b9745ea 100644 --- a/src/main/scala/vexriscv/plugin/CsrPlugin.scala +++ b/src/main/scala/vexriscv/plugin/CsrPlugin.scala @@ -260,10 +260,10 @@ class CsrPlugin(config : CsrPluginConfig) extends Plugin[VexRiscv] with Exceptio //Define CSR registers val misa = new Area{ - val base = Reg(UInt(2 bits)) init(U"01") unsetRegIfNoAssignement - val extensions = Reg(Bits(26 bits)) init(misaExtensionsInit) unsetRegIfNoAssignement + val base = Reg(UInt(2 bits)) init(U"01") allowUnsetRegToAvoidLatch + val extensions = Reg(Bits(26 bits)) init(misaExtensionsInit) allowUnsetRegToAvoidLatch } - val mtvec = RegInit(U(mtvecInit,xlen bits)) unsetRegIfNoAssignement + val mtvec = RegInit(U(mtvecInit,xlen bits)) allowUnsetRegToAvoidLatch val mepc = Reg(UInt(xlen bits)) val mstatus = new Area{ val MIE, MPIE = RegInit(False) @@ -337,7 +337,7 @@ class CsrPlugin(config : CsrPluginConfig) extends Plugin[VexRiscv] with Exceptio val exceptionPortCtrl = if(exceptionPortsInfos.nonEmpty) new Area{ val firstStageIndexWithExceptionPort = exceptionPortsInfos.map(i => indexOf(i.stage)).min val exceptionValids = Vec(Bool,stages.length) - val exceptionValidsRegs = Vec(Reg(Bool) init(False), stages.length).unsetRegIfNoAssignement + val exceptionValidsRegs = Vec(Reg(Bool) init(False), stages.length).allowUnsetRegToAvoidLatch val exceptionContext = Reg(ExceptionCause()) val pipelineHasException = exceptionValids.orR //TODO FMAX maybe could be partialy pipelined From 838c13d68b9ae8e1700d1d7a812debdd56aa2ba4 Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Fri, 10 Nov 2017 13:14:30 +0100 Subject: [PATCH 5/5] spinal.core.internals literals import --- src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala | 1 + 1 file changed, 1 insertion(+) diff --git a/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala b/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala index 299d084..b491f0b 100644 --- a/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala +++ b/src/main/scala/vexriscv/plugin/DecoderSimplePlugin.scala @@ -2,6 +2,7 @@ package vexriscv.plugin import vexriscv._ import spinal.core._ +import spinal.core.internals.Literal import spinal.lib._ import scala.collection.mutable