Skip to content

Commit

Permalink
[rocketv] fix vsetvl.
Browse files Browse the repository at this point in the history
  • Loading branch information
qinjun-li committed Aug 24, 2024
1 parent 55127d9 commit 9f8a050
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 9 deletions.
28 changes: 20 additions & 8 deletions rocketv/src/CSR.scala
Original file line number Diff line number Diff line change
Expand Up @@ -815,8 +815,7 @@ class CSR(val parameter: CSRParameter)
CSRs.vxrm -> v.states("vxrm"),
CSRs.vcsr -> v.states("vxrm") ## v.states("vxsat"),
CSRs.vstart -> v.states("vstart"),
CSRs.vtype -> v.states("vlmul") ## v.states("vsew") ## v.states("vta") ## v.states("vma") ## 0.U(23.W) ## v
.states("vill"),
CSRs.vtype -> v.states("vill") ## 0.U(23.W) ## v.states("vma") ## v.states("vta") ## v.states("vsew") ## v.states("vlmul"),
CSRs.vl -> v.states("vl"),
CSRs.vlenb -> v.constants("vlenb")
)
Expand Down Expand Up @@ -1702,6 +1701,9 @@ class CSR(val parameter: CSRParameter)
vsetvl -> io.wbRegRS2.get(7, 0)
)
)
// todo: xLen -> vector.elen
val vlmulIllList = Seq(0.U, 1.U, 2.U, 3.U)++ Option.when(xLen>=16)(7.U) ++ Option.when(xLen>=32)(6.U) ++ Option.when(xLen>=64)(5.U)
val vlmulIll: Bool = vlmulIllList.map(_ === newVType(2, 0)).reduce(_ || _)
// vlmax = vlen * lmul / sew
val vlmax: UInt = (true.B << (log2Ceil(vLen) - 6) << (newVType(2, 0) + 3.U) >> newVType(5, 3)).asUInt
// set vl
Expand All @@ -1713,13 +1715,23 @@ class CSR(val parameter: CSRParameter)
vsetivli -> io.inst(0)(19, 15)
)
)
setVlReadData := Mux(io.retire(0) && io.vectorCsr.getOrElse(false.B), setVL, 0.U)
setVlReadData := Mux(io.retire(0) && io.vectorCsr.getOrElse(false.B) && vlmulIll, setVL, 0.U)
when(io.retire(0) && io.vectorCsr.get) {
vector.get.states("vl") := setVL
vector.get.states("vlmul") := newVType(2, 0)
vector.get.states("vsew") := newVType(5, 3)
vector.get.states("vta") := newVType(6)
vector.get.states("vma") := newVType(7)
when(vlmulIll) {
vector.get.states("vl") := setVL
vector.get.states("vlmul") := newVType(2, 0)
vector.get.states("vsew") := newVType(5, 3)
vector.get.states("vta") := newVType(6)
vector.get.states("vma") := newVType(7)
vector.get.states("vill") := false.B
} otherwise {
vector.get.states("vl") := 0.U
vector.get.states("vlmul") := 0.U
vector.get.states("vsew") := 0.U
vector.get.states("vta") := 0.U
vector.get.states("vma") := 0.U
vector.get.states("vill") := true.B
}
}
} else {
setVlReadData := 0.U
Expand Down
2 changes: 1 addition & 1 deletion rocketv/src/csr/V.scala
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ class V(vlen: Int, hypervisor: Boolean) {
case "vsew" => Some(0.U)
case "vta" => Some(false.B)
case "vma" => Some(false.B)
case "vill" => Some(true.B)
case "vill" => Some(false.B)
// The vector extension must have a consistent state at reset. In particular, vtype and vl must have values that can be read and then restored with a single vsetvl instruction.
case "vl" => Some(0.U)
// The vstart, vxrm, vxsat CSRs can have arbitrary values at reset.
Expand Down

0 comments on commit 9f8a050

Please sign in to comment.