mhpmcounter28
Machine Hardware Performance Counter 28
Programmable hardware performance counter.
Attributes
Requirement |
|||
|---|---|---|---|
Defining extensions |
|
||
CSR Address |
0xb1c |
||
Length |
64-bit |
||
Privilege Mode |
M |
Field Summary
| Name | Location | Type | Reset Value |
|---|---|---|---|
63:0 |
[when,"HPM_COUNTER_EN[28]"] RW-H [when,"!(HPM_COUNTER_EN[28])"] RO |
UNDEFINED_LEGAL |
Fields
COUNT
- Location
-
63:0
- Description
Performance counter for event selected in mhpmevent28.EVENT.
Increments every time event occurs unless:
-
mcountinhibit.HPM28 <%- if ext?(:Smcdeleg) -%>or its alias
scountinhibit.HPM28<%- end -%> is set <%- if ext?(:Sscofpmf) -%> -
mhpmevent28.MINH is set and the current privilege level is M <%- if ext?(:S) -%>
-
mhpmevent28.SINH <%- if ext?(:Ssccfg) -%>or its alias
hpmevent28..SINH<%- end -%> is set and the current privilege level is (H)S <%- end -%> <%- if ext?(:U) -%> -
mhpmevent28.UINH <%- if ext?(:Ssccfg) -%>or its alias
hpmevent28.SINH<%- end -%> is set and the current privilege level is U <%- end -%> <%- if ext?(:H) -%> -
mhpmevent28.VSINH <%- if ext?(:Ssccfg) -%>or its alias
hpmevent28.SINH<%- end -%> is set and the current privilege level is VS -
mhpmevent28.VUINH <%- if ext?(:Ssccfg) -%>or its alias
hpmevent28.SINH<%- end -%> is set and the current privilege level is VU <%- end -%> <%- end -%>
Unimplemented performance counter. Must be read-only 0 (access does not cause trap).
- Type
RW-H
RO
- Reset value
-
UNDEFINED_LEGAL
Software read
This CSR may return a value that is different from what is stored in hardware.
if (HPM_COUNTER_EN[28]) {
return read_hpm_counter(28);
} else {
return 0;
}