mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
DivPlugin is now based MulDivIterativePlugin (Smaller)
This commit is contained in:
parent
f133e69fed
commit
91031f8d75
1 changed files with 69 additions and 65 deletions
|
@ -2,70 +2,74 @@ package vexriscv.plugin
|
|||
|
||||
import vexriscv.{VexRiscv, _}
|
||||
import spinal.core._
|
||||
import spinal.lib.math.MixedDivider
|
||||
|
||||
class DivPlugin extends Plugin[VexRiscv]{
|
||||
object IS_DIV extends Stageable(Bool)
|
||||
// DivPlugin was by the past a standalone plugin, but now it use the MulDivIterativePlugin implementation
|
||||
class DivPlugin extends MulDivIterativePlugin(genMul = false, genDiv = true, mulUnroolFactor = 1, divUnroolFactor = 1)
|
||||
|
||||
override def setup(pipeline: VexRiscv): Unit = {
|
||||
import Riscv._
|
||||
import pipeline.config._
|
||||
|
||||
val actions = List[(Stageable[_ <: BaseType],Any)](
|
||||
SRC1_CTRL -> Src1CtrlEnum.RS,
|
||||
SRC2_CTRL -> Src2CtrlEnum.RS,
|
||||
REGFILE_WRITE_VALID -> True,
|
||||
BYPASSABLE_EXECUTE_STAGE -> False,
|
||||
BYPASSABLE_MEMORY_STAGE -> True,
|
||||
RS1_USE -> True,
|
||||
RS2_USE -> True,
|
||||
IS_DIV -> True
|
||||
)
|
||||
|
||||
val decoderService = pipeline.service(classOf[DecoderService])
|
||||
decoderService.addDefault(IS_DIV, False)
|
||||
decoderService.add(List(
|
||||
DIVX -> actions
|
||||
))
|
||||
|
||||
}
|
||||
|
||||
override def build(pipeline: VexRiscv): Unit = {
|
||||
import pipeline._
|
||||
import pipeline.config._
|
||||
|
||||
val divider = new MixedDivider(32, 32, true) //cmd >-> rsp
|
||||
|
||||
//Send request to the divider component
|
||||
execute plug new Area {
|
||||
import execute._
|
||||
|
||||
divider.io.cmd.valid := False
|
||||
divider.io.cmd.numerator := input(SRC1)
|
||||
divider.io.cmd.denominator := input(SRC2)
|
||||
divider.io.cmd.signed := !input(INSTRUCTION)(12)
|
||||
|
||||
when(arbitration.isValid && input(IS_DIV)) {
|
||||
divider.io.cmd.valid := !arbitration.isStuckByOthers && !arbitration.removeIt
|
||||
arbitration.haltItself := memory.arbitration.isValid && memory.input(IS_DIV)
|
||||
}
|
||||
}
|
||||
|
||||
//Collect response from the divider component, REGFILE_WRITE_DATA overriding
|
||||
memory plug new Area{
|
||||
import memory._
|
||||
|
||||
divider.io.flush := memory.arbitration.removeIt
|
||||
divider.io.rsp.ready := !arbitration.isStuckByOthers
|
||||
|
||||
when(arbitration.isValid && input(IS_DIV)) {
|
||||
arbitration.haltItself := !divider.io.rsp.valid
|
||||
|
||||
output(REGFILE_WRITE_DATA) := Mux(input(INSTRUCTION)(13), divider.io.rsp.remainder, divider.io.rsp.quotient).asBits
|
||||
}
|
||||
|
||||
|
||||
divider.io.rsp.payload.error.allowPruning
|
||||
}
|
||||
}
|
||||
}
|
||||
//import spinal.lib.math.MixedDivider
|
||||
//
|
||||
//class DivPlugin extends Plugin[VexRiscv]{
|
||||
// object IS_DIV extends Stageable(Bool)
|
||||
//
|
||||
// override def setup(pipeline: VexRiscv): Unit = {
|
||||
// import Riscv._
|
||||
// import pipeline.config._
|
||||
//
|
||||
// val actions = List[(Stageable[_ <: BaseType],Any)](
|
||||
// SRC1_CTRL -> Src1CtrlEnum.RS,
|
||||
// SRC2_CTRL -> Src2CtrlEnum.RS,
|
||||
// REGFILE_WRITE_VALID -> True,
|
||||
// BYPASSABLE_EXECUTE_STAGE -> False,
|
||||
// BYPASSABLE_MEMORY_STAGE -> True,
|
||||
// RS1_USE -> True,
|
||||
// RS2_USE -> True,
|
||||
// IS_DIV -> True
|
||||
// )
|
||||
//
|
||||
// val decoderService = pipeline.service(classOf[DecoderService])
|
||||
// decoderService.addDefault(IS_DIV, False)
|
||||
// decoderService.add(List(
|
||||
// DIVX -> actions
|
||||
// ))
|
||||
//
|
||||
// }
|
||||
//
|
||||
// override def build(pipeline: VexRiscv): Unit = {
|
||||
// import pipeline._
|
||||
// import pipeline.config._
|
||||
//
|
||||
// val divider = new MixedDivider(32, 32, true) //cmd >-> rsp
|
||||
//
|
||||
// //Send request to the divider component
|
||||
// execute plug new Area {
|
||||
// import execute._
|
||||
//
|
||||
// divider.io.cmd.valid := False
|
||||
// divider.io.cmd.numerator := input(SRC1)
|
||||
// divider.io.cmd.denominator := input(SRC2)
|
||||
// divider.io.cmd.signed := !input(INSTRUCTION)(12)
|
||||
//
|
||||
// when(arbitration.isValid && input(IS_DIV)) {
|
||||
// divider.io.cmd.valid := !arbitration.isStuckByOthers && !arbitration.removeIt
|
||||
// arbitration.haltItself := memory.arbitration.isValid && memory.input(IS_DIV)
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// //Collect response from the divider component, REGFILE_WRITE_DATA overriding
|
||||
// memory plug new Area{
|
||||
// import memory._
|
||||
//
|
||||
// divider.io.flush := memory.arbitration.removeIt
|
||||
// divider.io.rsp.ready := !arbitration.isStuckByOthers
|
||||
//
|
||||
// when(arbitration.isValid && input(IS_DIV)) {
|
||||
// arbitration.haltItself := !divider.io.rsp.valid
|
||||
//
|
||||
// output(REGFILE_WRITE_DATA) := Mux(input(INSTRUCTION)(13), divider.io.rsp.remainder, divider.io.rsp.quotient).asBits
|
||||
// }
|
||||
//
|
||||
//
|
||||
// divider.io.rsp.payload.error.allowPruning
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
|
|
Loading…
Reference in a new issue