Skip to content

Commit

Permalink
[om] use AnyClassType to work around Seq[SomeClassType.Type]
Browse files Browse the repository at this point in the history
  • Loading branch information
sequencer committed Apr 25, 2024
1 parent 87944ae commit 696bef7
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 10 deletions.
9 changes: 4 additions & 5 deletions t1/src/Lane.scala
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import chisel3._
import chisel3.experimental.hierarchy.{Definition, Instance, Instantiate, instantiable, public}
import chisel3.experimental.{SerializableModule, SerializableModuleParameter}
import chisel3.probe.{Probe, ProbeValue, define}
import chisel3.properties.{Class, ClassType, Path, Property}
import chisel3.properties.{AnyClassType, Class, ClassType, Path, Property}
import chisel3.util._
import chisel3.util.experimental.decode.DecodeBundle
import org.chipsalliance.t1.rtl.decoder.Decoder
Expand All @@ -16,11 +16,10 @@ import org.chipsalliance.t1.rtl.vrf.{RamType, VRF, VRFParam, VRFProbe}

@instantiable
class LaneOM extends Class {
val vfuOMType: ClassType = Definition(new VFUOM).getClassType
@public
val vfus = IO(Output(Property[Seq[vfuOMType.Type]]()))
val vfus = IO(Output(Property[Seq[AnyClassType]]()))
@public
val vfusIn = IO(Input(Property[Seq[vfuOMType.Type]]()))
val vfusIn = IO(Input(Property[Seq[AnyClassType]]()))
vfus := vfusIn
}

Expand Down Expand Up @@ -823,7 +822,7 @@ class Lane(val parameter: LaneParameter) extends Module with SerializableModule[
executeOccupied,
VFUNotClear
)
omInstance.vfusIn := Property(vfus.map(_.om.as(Definition(new VFUOM).getClassType)))
omInstance.vfusIn := Property(vfus.map(_.om.asAnyClassType))

// It’s been a long time since I selected it. Need pipe
val queueBeforeMaskWrite: Queue[VRFWriteRequest] =
Expand Down
9 changes: 4 additions & 5 deletions t1/src/T1.scala
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import chisel3.util._
import chisel3.util.experimental.decode._
import tilelink.{TLBundle, TLBundleParameter, TLChannelAParameter, TLChannelDParameter}
import chisel3.probe.{Probe, ProbeValue, define, force}
import chisel3.properties.{Class, ClassType, Property}
import chisel3.properties.{AnyClassType, Class, ClassType, Property}
import chisel3.util.experimental.BitSet
import org.chipsalliance.t1.rtl.decoder.Decoder
import org.chipsalliance.t1.rtl.lsu.{LSU, LSUParameter, LSUProbe}
Expand All @@ -22,11 +22,10 @@ import org.chipsalliance.t1.rtl.vrf.{RamType, VRFParam, VRFProbe}
// 3. Lane(Retime, VRF memory type, id, multiple instances(does it affect dedup? not for sure))
@instantiable
class T1OM extends Class {
val laneOMType: ClassType = Definition(new LaneOM).getClassType
@public
val lanes = IO(Output(Property[Seq[laneOMType.Type]]()))
val lanes = IO(Output(Property[Seq[AnyClassType]]()))
@public
val lanesIn = IO(Input(Property[Seq[laneOMType.Type]]()))
val lanesIn = IO(Input(Property[Seq[AnyClassType]]()))
lanes := lanesIn
}

Expand Down Expand Up @@ -1514,7 +1513,7 @@ class T1(val parameter: T1Parameter) extends Module with SerializableModule[T1Pa
lane
}

omInstance.lanesIn := Property(laneVec.map(_.om.as(Definition(new LaneOM).getClassType)))
omInstance.lanesIn := Property(laneVec.map(_.om.asAnyClassType))

define(lsuProbe, lsu.probe)

Expand Down

0 comments on commit 696bef7

Please sign in to comment.