Skip to content

Commit

Permalink
[rtl] fix elaborate.
Browse files Browse the repository at this point in the history
  • Loading branch information
qinjun-li authored and sequencer committed Nov 3, 2024
1 parent ddbb167 commit 70291f0
Show file tree
Hide file tree
Showing 6 changed files with 42 additions and 17 deletions.
13 changes: 6 additions & 7 deletions t1/src/Lane.scala
Original file line number Diff line number Diff line change
Expand Up @@ -818,14 +818,13 @@ class Lane(val parameter: LaneParameter) extends Module with SerializableModule[

// cross write bus <> write queue
crossLaneWriteQueue.zipWithIndex.foreach { case (queue, index) =>
val port = writeBusPort(index)
// ((counter << 1) >> parameter.vrfParam.vrfOffsetBits).low(3)
val registerIncreaseBase = parameter.vrfParam.vrfOffsetBits - 1
val port = writeBusPort(index)
val baseIndex = slotControl.head.laneRequest.vd ## 0.U(parameter.vrfOffsetBits.W)
val indexGrowth: UInt = changeUIntSize(port.enq.bits.counter ## index.U(1.W), port.enq.bits.counter.getWidth)
val finalIndex: UInt = baseIndex + indexGrowth
queue.enq.valid := port.enq.valid
queue.enq.bits.vd :=
// 3: 8 reg => log(2, 8)
slotControl.head.laneRequest.vd + port.enq.bits.counter(registerIncreaseBase + 3 - 1, registerIncreaseBase)
queue.enq.bits.offset := port.enq.bits.counter ## index.U(1.W)
queue.enq.bits.vd := finalIndex >> parameter.vrfOffsetBits
queue.enq.bits.offset := finalIndex
queue.enq.bits.data := port.enq.bits.data
queue.enq.bits.last := DontCare
queue.enq.bits.instructionIndex := port.enq.bits.instructionIndex
Expand Down
7 changes: 7 additions & 0 deletions t1/src/VectorFunctionUnit.scala
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,13 @@ object VFUInstantiateParameter {
case (false, true) => VFUInstantiateParameter.zvbb(vLen, dLen)
case (true, true) => VFUInstantiateParameter.zvbbFP(vLen, dLen)
}
case "huge" =>
(fp, zvbb) match {
case (false, false) => VFUInstantiateParameter.smallInt(vLen, dLen)
case (true, false) => VFUInstantiateParameter.hugeFP(vLen, dLen)
case (false, true) => VFUInstantiateParameter.zvbb(vLen, dLen)
case (true, true) => VFUInstantiateParameter.zvbbFP(vLen, dLen)
}
}

// instantiate each module and connect to all scoreboards
Expand Down
2 changes: 1 addition & 1 deletion t1/src/laneStage/LaneExecutionBridge.scala
Original file line number Diff line number Diff line change
Expand Up @@ -411,7 +411,7 @@ class LaneExecutionBridge(parameter: LaneParameter, isLastSlot: Boolean, slotInd
maskResult(1, 0) <<
(recordQueue.deq.bits.groupCounter(3, 0) ## false.B),
// 1 bit per data group, it will had 32 data groups -> executeIndex1H << 1 * groupCounter(4, 0)
maskResult(0) << recordQueue.deq.bits.groupCounter(4, 0)
maskResult(0) << recordQueue.deq.bits.groupCounter(4.min(parameter.groupNumberBits - 1), 0)
)
).asUInt

Expand Down
20 changes: 14 additions & 6 deletions t1/src/laneStage/LaneStage1.scala
Original file line number Diff line number Diff line change
Expand Up @@ -212,27 +212,35 @@ class LaneStage1(parameter: LaneParameter, isLastSlot: Boolean) extends Module {

// cross read enqueue
queueBeforeCheckLSB.foreach { q =>
q.enq.bits.vs := Mux(
val baseVs = Mux(
enqueue.bits.decodeResult(Decoder.vwmacc),
// cross read vd for vwmacc, since it need dual [[dataPathWidth]], use vs2 port to read LSB part of it.
enqueue.bits.vd,
// read vs2 for other instruction
enqueue.bits.vs2
) + groupCounter(parameter.groupNumberBits - 2, parameter.vrfOffsetBits - 1)
)
val baseIndex = baseVs ## 0.U(parameter.vrfOffsetBits.W)
val indexGrowth: UInt = changeUIntSize(groupCounter ## false.B, groupCounter.getWidth)
val finalIndex: UInt = baseIndex + indexGrowth
q.enq.bits.vs := finalIndex >> parameter.vrfOffsetBits
q.enq.bits.readSource := Mux(enqueue.bits.decodeResult(Decoder.vwmacc), 2.U, 1.U)
q.enq.bits.offset := groupCounter(parameter.vrfOffsetBits - 2, 0) ## false.B
q.enq.bits.offset := finalIndex
}

queueBeforeCheckMSB.foreach { q =>
q.enq.bits.vs := Mux(
val baseVs = Mux(
enqueue.bits.decodeResult(Decoder.vwmacc),
// cross read vd for vwmacc
enqueue.bits.vd,
// cross lane access use vs2
enqueue.bits.vs2
) + groupCounter(parameter.groupNumberBits - 2, parameter.vrfOffsetBits - 1)
)
val baseIndex = baseVs ## 0.U(parameter.vrfOffsetBits.W)
val indexGrowth: UInt = changeUIntSize(groupCounter ## true.B, groupCounter.getWidth)
val finalIndex: UInt = baseIndex + indexGrowth
q.enq.bits.vs := finalIndex >> parameter.vrfOffsetBits
q.enq.bits.readSource := Mux(enqueue.bits.decodeResult(Decoder.vwmacc), 2.U, 1.U)
q.enq.bits.offset := groupCounter(parameter.vrfOffsetBits - 2, 0) ## true.B
q.enq.bits.offset := finalIndex
}

// read pipe
Expand Down
9 changes: 9 additions & 0 deletions t1/src/package.scala
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,15 @@ package object rtl {
})
}

def changeUIntSize(data: UInt, size: Int, sign: Boolean = false): UInt = {
if (data.getWidth >= size) {
data(size - 1, 0)
} else {
val extend = if (sign) data(data.getWidth - 1) else false.B
Fill(size - data.getWidth, extend) ## data
}
}

def calculateSegmentWriteMask(
datapath: Int,
laneNumber: Int,
Expand Down
8 changes: 5 additions & 3 deletions t1/src/vrf/VRF.scala
Original file line number Diff line number Diff line change
Expand Up @@ -268,8 +268,9 @@ class VRF(val parameter: VRFParam) extends Module with SerializableModule[VRFPar
val portFireCount: UInt = PopCount(VecInit(readRequests.map(_.fire) :+ write.fire))
dontTouch(portFireCount)

val writeBank: UInt =
if (parameter.rfBankNum == 1) true.B else UIntToOH(write.bits.offset(log2Ceil(parameter.rfBankNum) - 1, 0))
val writeIndex: UInt = write.bits.vd ## write.bits.offset
val writeBank: UInt =
if (parameter.rfBankNum == 1) true.B else UIntToOH(writeIndex(log2Ceil(parameter.rfBankNum) - 1, 0))

// Add one more record slot to prevent there is no free slot when the instruction comes in
// (the slot will die a few cycles later than the instruction)
Expand Down Expand Up @@ -350,8 +351,9 @@ class VRF(val parameter: VRFParam) extends Module with SerializableModule[VRFPar
.reduce(_ && _) && portConflictCheck
}
val validCorrect: Bool = if (i == (readRequests.size - 1)) v.valid && checkResult.get else v.valid
val address = v.bits.vs ## v.bits.offset
// select bank
val bank = if (parameter.rfBankNum == 1) true.B else UIntToOH(v.bits.offset(log2Ceil(parameter.rfBankNum) - 1, 0))
val bank = if (parameter.rfBankNum == 1) true.B else UIntToOH(address(log2Ceil(parameter.rfBankNum) - 1, 0))
val pipeBank = Pipe(true.B, bank, parameter.vrfReadLatency).bits
val bankCorrect = Mux(validCorrect, bank, 0.U(parameter.rfBankNum.W))
val readPortCheckSelect = parameter.ramType match {
Expand Down

0 comments on commit 70291f0

Please sign in to comment.