From 0e89ebecedce18dd44030ebfb6c954553ee6f7bf Mon Sep 17 00:00:00 2001 From: Dolu1990 Date: Wed, 9 Jun 2021 11:26:58 +0200 Subject: [PATCH] Improve FPU rs1 timings --- src/main/scala/vexriscv/ip/fpu/FpuCore.scala | 5 +- .../scala/vexriscv/plugin/FpuPlugin.scala | 53 +------------------ 2 files changed, 5 insertions(+), 53 deletions(-) diff --git a/src/main/scala/vexriscv/ip/fpu/FpuCore.scala b/src/main/scala/vexriscv/ip/fpu/FpuCore.scala index ffe057239..657b2fb4f 100644 --- a/src/main/scala/vexriscv/ip/fpu/FpuCore.scala +++ b/src/main/scala/vexriscv/ip/fpu/FpuCore.scala @@ -229,7 +229,7 @@ case class FpuCore( portCount : Int, p : FpuParameter) extends Component{ val useRs1, useRs2, useRs3, useRd = False switch(input.opcode){ is(p.Opcode.LOAD) { useRd := True } - is(p.Opcode.STORE) { useRs1 := True } + is(p.Opcode.STORE) { useRs2 := True } is(p.Opcode.ADD) { useRd := True; useRs1 := True; useRs2 := True } is(p.Opcode.MUL) { useRd := True; useRs1 := True; useRs2 := True } is(p.Opcode.DIV) { useRd := True; useRs1 := True; useRs2 := True } @@ -255,6 +255,9 @@ case class FpuCore( portCount : Int, p : FpuParameter) extends Component{ val hits = (0 to 3).map(id => uses(id) && rfBusy(id)) val hazard = hits.orR || !rf.init.done || commitLogic(portId).pending.full val output = input.haltWhen(hazard) + when(input.opcode === p.Opcode.STORE){ + output.rs1 := input.rs2 //Datapath optimisation to unify rs source in the store pipeline + } when(input.valid && rf.init.done){ scoreboard.targetWrite.address := input.rd scoreboard.targetWrite.data := !rfTargets.last diff --git a/src/main/scala/vexriscv/plugin/FpuPlugin.scala b/src/main/scala/vexriscv/plugin/FpuPlugin.scala index a24799299..3e664f51b 100644 --- a/src/main/scala/vexriscv/plugin/FpuPlugin.scala +++ b/src/main/scala/vexriscv/plugin/FpuPlugin.scala @@ -165,57 +165,6 @@ class FpuPlugin(externalFpu : Boolean = false, // exposeEncoding() } - def exposeEncoding(): Unit ={ - val d = pipeline.service(classOf[DecoderSimplePlugin]) - val commits, rsps, rs1, commitsN, rspsN, rs1N = ArrayBuffer[MaskedLiteral]() - def filter(encoding : Int, list : ArrayBuffer[MaskedLiteral]) = list.filter(e => (e.value & 0x7F) == encoding) - def filterNotLs(list : ArrayBuffer[MaskedLiteral]) = list.filter(e => !List(0x7, 0x27).contains(e.value & 0x7F)) - - for((key, t) <- d.encodings; if(t.map(_._1).contains(FPU_ENABLE)); - (s, v) <- t){ - def isSet = v.head.source.asInstanceOf[Literal].getValue == 1 - if(s == FPU_COMMIT) (if(isSet)commits += key else commitsN += key) - if(s == FPU_RSP) (if(isSet)rsps += key else rspsN += key) - if(s == pipeline.config.RS1_USE) (if(isSet)rs1 += key else rs1N += key) - } - - val commitLut, rspLut, rs1Lut = Array.fill(32)(false) - filter(0x53,commits).foreach{m => - val idx = (m.value >> 27).toInt - commitLut(idx) = true - } - filter(0x53,commitsN).foreach{m => - val idx = (m.value >> 27).toInt - assert(!commitLut(idx)) - } - println("COMMIT => ") - println(commitLut.mkString(",")) - - - filter(0x53,rsps).foreach{m => - val idx = (m.value >> 27).toInt - rspLut(idx) = true - } - filter(0x53,rspsN).foreach{m => - val idx = (m.value >> 27).toInt - assert(!rspLut(idx)) - } - println("RSP => ") - println(rspLut.mkString(",")) - - filter(0x53,rs1).foreach{m => - val idx = (m.value >> 27).toInt - rs1Lut(idx) = true - } - filter(0x53,rs1N).foreach{m => - val idx = (m.value >> 27).toInt - assert(!rs1Lut(idx)) - } - println("rs1 => ") - println(rs1Lut.mkString(",")) - - } - override def build(pipeline: VexRiscv): Unit = { import pipeline._ import pipeline.config._ @@ -295,7 +244,7 @@ class FpuPlugin(externalFpu : Boolean = false, port.cmd.valid := arbitration.isValid && input(FPU_ENABLE) && !forked && !hazard port.cmd.opcode := input(FPU_OPCODE) port.cmd.arg := input(FPU_ARG) - port.cmd.rs1 := ((input(FPU_OPCODE) === FpuOpcode.STORE) ? input(INSTRUCTION)(rs2Range).asUInt | input(INSTRUCTION)(rs1Range).asUInt) + port.cmd.rs1 := input(INSTRUCTION)(rs1Range).asUInt port.cmd.rs2 := input(INSTRUCTION)(rs2Range).asUInt port.cmd.rs3 := input(INSTRUCTION)(rs3Range).asUInt port.cmd.rd := input(INSTRUCTION)(rdRange).asUInt