Add option to remove basic counters (mcycle/minstret)
This commit is contained in:
		| @@ -342,8 +342,6 @@ class CSRFile(perfEventSets: EventSets = new EventSets(Seq()))(implicit p: Param | ||||
|     CSRs.mimpid -> UInt(0), | ||||
|     CSRs.marchid -> UInt(0), | ||||
|     CSRs.mvendorid -> UInt(0), | ||||
|     CSRs.mcycle -> reg_cycle, | ||||
|     CSRs.minstret -> reg_instret, | ||||
|     CSRs.misa -> reg_misa, | ||||
|     CSRs.mstatus -> read_mstatus, | ||||
|     CSRs.mtvec -> reg_mtvec, | ||||
| @@ -371,14 +369,34 @@ class CSRFile(perfEventSets: EventSets = new EventSets(Seq()))(implicit p: Param | ||||
|   if (usingFPU) | ||||
|     read_mapping ++= fp_csrs | ||||
|  | ||||
|   for (((e, c), i) <- (reg_hpmevent.padTo(CSR.nHPM, UInt(0)) | ||||
|                        zip reg_hpmcounter.map(x => x: UInt).padTo(CSR.nHPM, UInt(0))) zipWithIndex) { | ||||
|     read_mapping += (i + CSR.firstHPE) -> e // mhpmeventN | ||||
|     read_mapping += (i + CSR.firstMHPC) -> c // mhpmcounterN | ||||
|     if (usingUser) read_mapping += (i + CSR.firstHPC) -> c // hpmcounterN | ||||
|   if (coreParams.haveBasicCounters) { | ||||
|     read_mapping += CSRs.mcycle -> reg_cycle | ||||
|     read_mapping += CSRs.minstret -> reg_instret | ||||
|  | ||||
|     for (((e, c), i) <- (reg_hpmevent.padTo(CSR.nHPM, UInt(0)) | ||||
|                          zip reg_hpmcounter.map(x => x: UInt).padTo(CSR.nHPM, UInt(0))) zipWithIndex) { | ||||
|       read_mapping += (i + CSR.firstHPE) -> e // mhpmeventN | ||||
|       read_mapping += (i + CSR.firstMHPC) -> c // mhpmcounterN | ||||
|       if (usingUser) read_mapping += (i + CSR.firstHPC) -> c // hpmcounterN | ||||
|       if (xLen == 32) { | ||||
|         read_mapping += (i + CSR.firstMHPCH) -> c // mhpmcounterNh | ||||
|         if (usingUser) read_mapping += (i + CSR.firstHPCH) -> c // hpmcounterNh | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if (usingUser) { | ||||
|       read_mapping += CSRs.mcounteren -> reg_mcounteren | ||||
|       read_mapping += CSRs.cycle -> reg_cycle | ||||
|       read_mapping += CSRs.instret -> reg_instret | ||||
|     } | ||||
|  | ||||
|     if (xLen == 32) { | ||||
|       read_mapping += (i + CSR.firstMHPCH) -> c // mhpmcounterNh | ||||
|       if (usingUser) read_mapping += (i + CSR.firstHPCH) -> c // hpmcounterNh | ||||
|       read_mapping += CSRs.mcycleh -> (reg_cycle >> 32) | ||||
|       read_mapping += CSRs.minstreth -> (reg_instret >> 32) | ||||
|       if (usingUser) { | ||||
|         read_mapping += CSRs.cycleh -> (reg_cycle >> 32) | ||||
|         read_mapping += CSRs.instreth -> (reg_instret >> 32) | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
| @@ -411,21 +429,6 @@ class CSRFile(perfEventSets: EventSets = new EventSets(Seq()))(implicit p: Param | ||||
|     read_mapping += CSRs.medeleg -> reg_medeleg | ||||
|   } | ||||
|  | ||||
|   if (usingUser) { | ||||
|     read_mapping += CSRs.mcounteren -> reg_mcounteren | ||||
|     read_mapping += CSRs.cycle -> reg_cycle | ||||
|     read_mapping += CSRs.instret -> reg_instret | ||||
|   } | ||||
|  | ||||
|   if (xLen == 32) { | ||||
|     read_mapping += CSRs.mcycleh -> (reg_cycle >> 32) | ||||
|     read_mapping += CSRs.minstreth -> (reg_instret >> 32) | ||||
|     if (usingUser) { | ||||
|       read_mapping += CSRs.cycleh -> (reg_cycle >> 32) | ||||
|       read_mapping += CSRs.instreth -> (reg_instret >> 32) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   val pmpCfgPerCSR = xLen / new PMPConfig().getWidth | ||||
|   def pmpCfgIndex(i: Int) = (xLen / 32) * (i / pmpCfgPerCSR) | ||||
|   if (reg_pmp.nonEmpty) { | ||||
| @@ -629,8 +632,10 @@ class CSRFile(perfEventSets: EventSets = new EventSets(Seq()))(implicit p: Param | ||||
|       writeCounter(i + CSR.firstMHPC, c, wdata) | ||||
|       when (decoded_addr(i + CSR.firstHPE)) { e := perfEventSets.maskEventSelector(wdata) } | ||||
|     } | ||||
|     writeCounter(CSRs.mcycle, reg_cycle, wdata) | ||||
|     writeCounter(CSRs.minstret, reg_instret, wdata) | ||||
|     if (coreParams.haveBasicCounters) { | ||||
|       writeCounter(CSRs.mcycle, reg_cycle, wdata) | ||||
|       writeCounter(CSRs.minstret, reg_instret, wdata) | ||||
|     } | ||||
|  | ||||
|     if (usingFPU) { | ||||
|       when (decoded_addr(CSRs.fflags)) { reg_fflags := wdata } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ case class RocketCoreParams( | ||||
|   nBreakpoints: Int = 1, | ||||
|   nPMPs: Int = 8, | ||||
|   nPerfCounters: Int = 0, | ||||
|   haveBasicCounters: Boolean = true, | ||||
|   nL2TLBEntries: Int = 0, | ||||
|   mtvecInit: Option[BigInt] = Some(BigInt(0)), | ||||
|   mtvecWritable: Boolean = true, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user