mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
IBusSimplePlugin add relaxedPcCalculation
This commit is contained in:
parent
c48c7170e8
commit
0919308a8f
1 changed files with 47 additions and 8 deletions
|
@ -111,9 +111,11 @@ class IBusSimplePlugin(interfaceKeepData : Boolean, catchAccessFault : Boolean,
|
||||||
def keepPcPlus4 = false
|
def keepPcPlus4 = false
|
||||||
def decodePcGen = true
|
def decodePcGen = true
|
||||||
def compressedGen = true
|
def compressedGen = true
|
||||||
def cmdToRspStageCount = 3
|
def cmdToRspStageCount = 1
|
||||||
def rspStageGen = true
|
def rspStageGen = false
|
||||||
def injectorReadyCutGen = true
|
def injectorReadyCutGen = true
|
||||||
|
def relaxedPcCalculation = true
|
||||||
|
assert(cmdToRspStageCount >= 1)
|
||||||
assert(!(compressedGen && !decodePcGen))
|
assert(!(compressedGen && !decodePcGen))
|
||||||
lazy val fetcherHalt = False
|
lazy val fetcherHalt = False
|
||||||
lazy val decodeNextPcValid = Bool
|
lazy val decodeNextPcValid = Bool
|
||||||
|
@ -165,9 +167,11 @@ class IBusSimplePlugin(interfaceKeepData : Boolean, catchAccessFault : Boolean,
|
||||||
|
|
||||||
def flush = jump.pcLoad.valid
|
def flush = jump.pcLoad.valid
|
||||||
|
|
||||||
val fetchPc = new Area {
|
class PcFetch extends Area{
|
||||||
val output = Stream(UInt(32 bits))
|
val output = Stream(UInt(32 bits))
|
||||||
|
}
|
||||||
|
|
||||||
|
val fetchPc = if(relaxedPcCalculation) new PcFetch {
|
||||||
//PC calculation without Jump
|
//PC calculation without Jump
|
||||||
val pcReg = Reg(UInt(32 bits)) init (resetVector) addAttribute (Verilator.public)
|
val pcReg = Reg(UInt(32 bits)) init (resetVector) addAttribute (Verilator.public)
|
||||||
val pcPlus4 = pcReg + 4
|
val pcPlus4 = pcReg + 4
|
||||||
|
@ -188,10 +192,44 @@ class IBusSimplePlugin(interfaceKeepData : Boolean, catchAccessFault : Boolean,
|
||||||
pcReg := jump.pcLoad.payload
|
pcReg := jump.pcLoad.payload
|
||||||
}
|
}
|
||||||
|
|
||||||
|
output.valid := RegNext(True) init (False) // && !jump.pcLoad.valid
|
||||||
|
|
||||||
output.valid := (RegNext(True) init (False)) // && !jump.pcLoad.valid
|
|
||||||
output.payload := pcReg
|
output.payload := pcReg
|
||||||
|
} else new PcFetch{
|
||||||
|
//PC calculation without Jump
|
||||||
|
val pcReg = Reg(UInt(32 bits)) init(resetVector) addAttribute(Verilator.public)
|
||||||
|
val inc = RegInit(False)
|
||||||
|
|
||||||
|
val pc = pcReg + (inc ## B"00").asUInt
|
||||||
|
val samplePcNext = False
|
||||||
|
|
||||||
|
when(jump.pcLoad.valid) {
|
||||||
|
inc := False
|
||||||
|
samplePcNext := True
|
||||||
|
pc := jump.pcLoad.payload
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
when(output.fire){
|
||||||
|
inc := True
|
||||||
|
samplePcNext := True
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
when(samplePcNext) {
|
||||||
|
pcReg := pc
|
||||||
|
}
|
||||||
|
|
||||||
|
if(compressedGen) {
|
||||||
|
when(output.fire) {
|
||||||
|
pcReg(1 downto 0) := 0
|
||||||
|
when(pc(1)){
|
||||||
|
inc := True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
output.valid := RegNext(True) init (False)
|
||||||
|
output.payload := pc
|
||||||
}
|
}
|
||||||
|
|
||||||
val decodePc = ifGen(decodePcGen)(new Area {
|
val decodePc = ifGen(decodePcGen)(new Area {
|
||||||
|
@ -240,13 +278,14 @@ class IBusSimplePlugin(interfaceKeepData : Boolean, catchAccessFault : Boolean,
|
||||||
}
|
}
|
||||||
|
|
||||||
val iBusRsp = new Area {
|
val iBusRsp = new Area {
|
||||||
val input = recursive[Stream[UInt]](iBusCmd.output, cmdToRspStageCount, x => x.m2sPipe(flush))//iBusCmd.output.m2sPipe(flush)// ASYNC .throwWhen(flush)
|
val inputFirstStage = if(relaxedPcCalculation) iBusCmd.output.m2sPipe(flush) else iBusCmd.output.m2sPipe().throwWhen(flush)
|
||||||
|
val input = recursive[Stream[UInt]](inputFirstStage, cmdToRspStageCount - 1, x => x.m2sPipe(flush))//iBusCmd.output.m2sPipe(flush)// ASYNC .throwWhen(flush)
|
||||||
|
|
||||||
//Manage flush for iBus transactions in flight
|
//Manage flush for iBus transactions in flight
|
||||||
val discardCounter = Reg(UInt(log2Up(pendingMax + 1) bits)) init (0)
|
val discardCounter = Reg(UInt(log2Up(pendingMax + 1) bits)) init (0)
|
||||||
discardCounter := discardCounter - (iBus.rsp.fire && discardCounter =/= 0).asUInt
|
discardCounter := discardCounter - (iBus.rsp.fire && discardCounter =/= 0).asUInt
|
||||||
when(flush) {
|
when(flush) {
|
||||||
discardCounter := iBusCmd.pendingCmdNext
|
discardCounter := (if(relaxedPcCalculation) iBusCmd.pendingCmdNext else iBusCmd.pendingCmd - iBus.rsp.fire.asUInt)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue