Skip to content

Commit

Permalink
[tets] Distinguish between vector write and vector commit.
Browse files Browse the repository at this point in the history
  • Loading branch information
qinjun-li committed Sep 26, 2024
1 parent 5131743 commit dcc4301
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 16 deletions.
28 changes: 15 additions & 13 deletions rocketv/src/RocketCore.scala
Original file line number Diff line number Diff line change
Expand Up @@ -39,16 +39,17 @@ class FPUScoreboardProbe extends Bundle {
}

class RocketProbe(param: RocketParameter) extends Bundle {
val rfWen: Bool = Bool()
val rfWaddr: UInt = UInt(param.lgNXRegs.W)
val rfWdata: UInt = UInt(param.xLen.W)
val rfWen: Bool = Bool()
val rfWaddr: UInt = UInt(param.lgNXRegs.W)
val rfWdata: UInt = UInt(param.xLen.W)
// rocket is idle
val waitWen: Bool = new Bool()
val waitWaddr: UInt = UInt(param.lgNXRegs.W)
val isVector: Bool = Bool()
val idle: Bool = Bool()
val waitWen: Bool = new Bool()
val waitWaddr: UInt = UInt(param.lgNXRegs.W)
val isVectorCommit: Bool = Bool()
val isVectorWrite: Bool = Bool()
val idle: Bool = Bool()
// fpu score board
val fpuScoreboard: Option[FPUScoreboardProbe] = Option.when(param.usingFPU)(new FPUScoreboardProbe)
val fpuScoreboard: Option[FPUScoreboardProbe] = Option.when(param.usingFPU)(new FPUScoreboardProbe)
}

object RocketParameter {
Expand Down Expand Up @@ -1616,14 +1617,15 @@ class Rocket(val parameter: RocketParameter)
probeWire.rfWaddr := rfWaddr
probeWire.rfWdata := rfWdata

probeWire.waitWen := wbSetSboard && wbWen
probeWire.waitWaddr := wbWaddr
probeWire.waitWen := wbSetSboard && wbWen
probeWire.waitWaddr := wbWaddr
// vector commit || vector write rd
probeWire.isVector := io.t1.map { t1 =>
probeWire.isVectorCommit := io.t1.map { t1 =>
wbRegValid && wbRegDecodeOutput(parameter.decoderParameter.vector) &&
!wbRegDecodeOutput(parameter.decoderParameter.vectorCSR)
}.getOrElse(false.B) || t1RetireQueue.map(q => q.io.deq.fire).getOrElse(false.B)
probeWire.idle := vectorEmpty
}.getOrElse(false.B)
probeWire.isVectorWrite := t1RetireQueue.map(q => q.io.deq.fire).getOrElse(false.B)
probeWire.idle := vectorEmpty

probeWire.fpuScoreboard.foreach { case fpProbe =>
fpProbe.memSetScoreBoard := wbValid && wbDcacheMiss && wbRegDecodeOutput(parameter.decoderParameter.wfd)
Expand Down
6 changes: 3 additions & 3 deletions t1rocketemu/src/TestBench.scala
Original file line number Diff line number Diff line change
Expand Up @@ -189,13 +189,13 @@ class TestBench(generator: SerializableModuleGenerator[T1RocketTile, T1RocketTil

// output the probes
// rocket reg write
when(rocketProbe.rfWen && !rocketProbe.isVector && rocketProbe.rfWaddr =/= 0.U && !(rocketProbe.waitWen && rocketProbe.waitWaddr =/= 0.U))(
when(rocketProbe.rfWen && !rocketProbe.isVectorWrite && rocketProbe.rfWaddr =/= 0.U && !(rocketProbe.waitWen && rocketProbe.waitWaddr =/= 0.U))(
printf(
cf"""{"event":"RegWrite","idx":${rocketProbe.rfWaddr},"data":"${rocketProbe.rfWdata}%x","cycle":${simulationTime}}\n"""
)
)

when(rocketProbe.waitWen && !rocketProbe.isVector && rocketProbe.waitWaddr =/= 0.U)(
when(rocketProbe.waitWen && !rocketProbe.isVectorCommit && rocketProbe.waitWaddr =/= 0.U)(
printf(
cf"""{"event":"RegWriteWait","idx":${rocketProbe.waitWaddr},"cycle":${simulationTime}}\n"""
)
Expand All @@ -210,7 +210,7 @@ class TestBench(generator: SerializableModuleGenerator[T1RocketTile, T1RocketTil
fpuParameter.fLen,
fpuParameter.minFLen
)))
val isVectorForLLWrite = RegNext(rocketProbe.isVector, false.B)
val isVectorForLLWrite = RegNext(rocketProbe.isVectorWrite, false.B)

fpToIEEE.io.clock := clock
fpToIEEE.io.reset := reset
Expand Down

0 comments on commit dcc4301

Please sign in to comment.