Skip to content

Commit

Permalink
[rtl] fix uncertain state(wip).
Browse files Browse the repository at this point in the history
  • Loading branch information
qinjun-li committed Jul 31, 2024
1 parent f427490 commit cb7cfcb
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 2 deletions.
35 changes: 35 additions & 0 deletions t1/src/laneStage/ReadStageRRArbiter.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// SPDX-License-Identifier: Apache-2.0
// SPDX-FileCopyrightText: 2022 Jiuyang Liu <[email protected]>

package org.chipsalliance.t1.rtl.lane

import chisel3._
import chisel3.util.{Decoupled, Mux1H}

class ArbiterIO[T <: Data](gen: T, n: Int) extends Bundle {
val in = Flipped(Vec(n, Decoupled(gen)))
val out = Decoupled(gen)
}

class ReadStageRRArbiter[T <: Data](val gen: T, val n: Int) extends Module {
require(n<=2, "Only 2 were needed, so only 2 were made.")
val io = IO(new ArbiterIO(gen, n))
if (n == 2) {
// Choose the first one first
val choseMask = RegInit(true.B)
val select: Vec[Bool] = VecInit(Seq(
io.in.head.valid && (choseMask || !io.in.last.valid),
io.in.last.valid && (!choseMask || !io.in.head.valid)
))
io.out.valid := io.in.map(_.valid).reduce(_ || _)
io.out.bits := Mux1H(select, io.in.map(_.bits))
io.in.zip(select).foreach {case (in, s) =>
in.ready := s && io.out.ready
}
when(io.out.fire) {
choseMask := io.in.last.fire
}
} else {
io.out <> io.in.head
}
}
2 changes: 1 addition & 1 deletion t1/src/laneStage/VrfReadPipe.scala
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ class VrfReadPipe(parameter: LaneParameter, arbitrate: Boolean = false) extends
Option.when(arbitrate)(IO(Decoupled(UInt(parameter.datapathWidth.W))))

// arbitrate
val reqArbitrate = Module(new RRArbiter(enqEntryType, if(arbitrate) 2 else 1))
val reqArbitrate = Module(new ReadStageRRArbiter(enqEntryType, if(arbitrate) 2 else 1))

(Seq(enqueue) ++ contender).zip(reqArbitrate.io.in).zip(Seq(dequeue) ++ contenderDequeue).foreach {
case ((source, sink), deq) =>
Expand Down
6 changes: 5 additions & 1 deletion t1/src/vrf/VRF.scala
Original file line number Diff line number Diff line change
Expand Up @@ -329,7 +329,11 @@ class VRF(val parameter: VRFParam) extends Module with SerializableModule[VRFPar
bankReadF(i) := bankCorrect & (~o)
bankReadS(i) := bankCorrect & (~t) & o
val pipeFirstUsed = Pipe(true.B, firstUsed, parameter.vrfReadLatency).bits
readResults(i) := Mux(pipeFirstUsed, Mux1H(pipeBank, readResultS), Mux1H(pipeBank, readResultF))
val pipeFire = Pipe(true.B, v.fire, parameter.vrfReadLatency).bits
readResults(i) := Mux1H(Seq(
(!pipeFirstUsed && pipeFire, Mux1H(pipeBank, readResultF)),
(pipeFirstUsed && pipeFire, Mux1H(pipeBank, readResultS)),
))
(o | bankCorrect, (bankCorrect & o) | t)
}
// @todo @Clo91eaf check write port is ready.
Expand Down

0 comments on commit cb7cfcb

Please sign in to comment.