mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
Fix RVC step by step triggering next instruction branch predictor
This commit is contained in:
parent
6326736401
commit
8df2dcbd40
3 changed files with 11 additions and 0 deletions
|
@ -17,6 +17,7 @@ trait IBusFetcher{
|
|||
def pcValid(stage : Stage) : Bool
|
||||
def getInjectionPort() : Stream[Bits]
|
||||
def withRvc() : Boolean
|
||||
def forceNoDecode() : Unit
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -319,6 +319,10 @@ class DebugPlugin(var debugClockDomain : ClockDomain, hardwareBreakpointCount :
|
|||
if(pipeline.config.withRvc){
|
||||
val cleanStep = RegNext(stepIt && decode.arbitration.isFiring) init(False)
|
||||
execute.arbitration.flushNext setWhen(cleanStep)
|
||||
when(cleanStep){
|
||||
execute.arbitration.flushNext := True
|
||||
iBusFetcher.forceNoDecode()
|
||||
}
|
||||
}
|
||||
|
||||
io.resetOut := RegNext(resetIt)
|
||||
|
|
|
@ -33,6 +33,7 @@ abstract class IBusFetcherImpl(val resetVector : BigInt,
|
|||
// assert(!(cmdToRspStageCount == 1 && !injectorStage))
|
||||
assert(!(compressedGen && !decodePcGen))
|
||||
var fetcherHalt : Bool = null
|
||||
var forceNoDecodeCond : Bool = null
|
||||
var pcValids : Vec[Bool] = null
|
||||
def pcValid(stage : Stage) = pcValids(pipeline.indexOf(stage))
|
||||
var incomingInstruction : Bool = null
|
||||
|
@ -50,6 +51,7 @@ abstract class IBusFetcherImpl(val resetVector : BigInt,
|
|||
var predictionJumpInterface : Flow[UInt] = null
|
||||
|
||||
override def haltIt(): Unit = fetcherHalt := True
|
||||
override def forceNoDecode(): Unit = forceNoDecodeCond := True
|
||||
case class JumpInfo(interface : Flow[UInt], stage: Stage, priority : Int)
|
||||
val jumpInfos = ArrayBuffer[JumpInfo]()
|
||||
override def createJumpInterface(stage: Stage, priority : Int = 0): Flow[UInt] = {
|
||||
|
@ -63,6 +65,7 @@ abstract class IBusFetcherImpl(val resetVector : BigInt,
|
|||
// var decodeExceptionPort : Flow[ExceptionCause] = null
|
||||
override def setup(pipeline: VexRiscv): Unit = {
|
||||
fetcherHalt = False
|
||||
forceNoDecodeCond = False
|
||||
incomingInstruction = False
|
||||
if(resetVector == null) externalResetVector = in(UInt(32 bits).setName("externalResetVector"))
|
||||
|
||||
|
@ -408,6 +411,9 @@ abstract class IBusFetcherImpl(val resetVector : BigInt,
|
|||
})
|
||||
}
|
||||
|
||||
Component.current.addPrePopTask(() => {
|
||||
decode.arbitration.isValid clearWhen(forceNoDecodeCond)
|
||||
})
|
||||
|
||||
//Formal verification signals generation, miss prediction stuff ?
|
||||
val formal = new Area {
|
||||
|
|
Loading…
Reference in a new issue