diff --git a/rocketv/src/CSR.scala b/rocketv/src/CSR.scala index af5bbfae1..e122aace8 100644 --- a/rocketv/src/CSR.scala +++ b/rocketv/src/CSR.scala @@ -1320,7 +1320,10 @@ class CSR(val parameter: CSRParameter) } val setVlReadData: UInt = Wire(UInt(xLen.W)) - io.rw.rdata := Mux1H(for ((k, v) <- read_mapping) yield decoded_addr(k) -> v).asUInt | setVlReadData + val cseReadData: UInt = Mux1H(for ((k, v) <- read_mapping) yield decoded_addr(k) -> v).asUInt + io.rw.rdata := io.vectorCsr.map(s => + Mux(s, setVlReadData, cseReadData) + ).getOrElse(cseReadData) // cover access to register val coverable_counters = read_mapping.filterNot { @@ -1733,6 +1736,12 @@ class CSR(val parameter: CSRParameter) vector.get.states("vill") := true.B } } + // v csr write + when(csr_wen) { + when(decoded_addr(CSRs.vxrm)) { + vector.get.states("vxrm") := wdata + } + } } else { setVlReadData := 0.U }