mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
Fix MulDiveIterative plugin when RSx have hazard in the execute stage
This commit is contained in:
parent
67028cdb48
commit
bb9261773b
1 changed files with 1 additions and 1 deletions
|
@ -80,7 +80,7 @@ class MulDivIterativePlugin(genMul : Boolean = true,
|
||||||
|
|
||||||
//FrontendOK is only used for CPU configs without memory/writeback stages, were it is required to wait one extra cycle
|
//FrontendOK is only used for CPU configs without memory/writeback stages, were it is required to wait one extra cycle
|
||||||
// to let's the frontend process rs1 rs2 registers
|
// to let's the frontend process rs1 rs2 registers
|
||||||
val frontendOk = if(flushStage != execute) True else RegInit(False) setWhen(arbitration.isValid && ((if(genDiv) input(IS_DIV) else False) || (if(genMul) input(IS_MUL) else False))) clearWhen(arbitration.isMoving)
|
val frontendOk = if(flushStage != execute) True else RegInit(False) setWhen(arbitration.isValid && !pipeline.service(classOf[HazardService]).hazardOnExecuteRS && ((if(genDiv) input(IS_DIV) else False) || (if(genMul) input(IS_MUL) else False))) clearWhen(arbitration.isMoving)
|
||||||
|
|
||||||
val mul = ifGen(genMul) (if(customMul != null) customMul(rs1,rs2,memory,pipeline) else new Area{
|
val mul = ifGen(genMul) (if(customMul != null) customMul(rs1,rs2,memory,pipeline) else new Area{
|
||||||
assert(isPow2(mulUnrollFactor))
|
assert(isPow2(mulUnrollFactor))
|
||||||
|
|
Loading…
Reference in a new issue