mhpmcounter27

Machine Hardware Performance Counter 27

Programmable hardware performance counter.

Attributes

Defining Extension

  • Smhpm, version >= 0

CSR Address

0xb1b

Length

64-bit

Privilege Mode

M

Format

mhpmcounter27 format
Figure 1. mhpmcounter27 format

Field Summary

Name Location Type Reset Value

mhpmcounter27.COUNT

63:0

[when,"HPM_COUNTER_EN[27]"] RW-H

[when,"!(HPM_COUNTER_EN[27])"] RO

[when,"HPM_COUNTER_EN[27]"] UNDEFINED_LEGAL

[when,"!(HPM_COUNTER_EN[27])"] 0

Fields

COUNT

Location

63:0

Description

Performance counter for event selected in mhpmevent27.EVENT.

Increments every time event occurs unless:

  • mcountinhibit.HPM27 <%- if ext?(:Smcdeleg) -%>or its alias scountinhibit.HPM27<%- end -%> is set <%- if ext?(:Sscofpmf) -%>

  • mhpmevent27.MINH is set and the current privilege level is M <%- if ext?(:S) -%>

  • mhpmevent27.SINH <%- if ext?(:Ssccfg) -%>or its alias hpmevent27..SINH<%- end -%> is set and the current privilege level is (H)S <%- end -%> <%- if ext?(:U) -%>

  • mhpmevent27.UINH <%- if ext?(:Ssccfg) -%>or its alias hpmevent27.SINH<%- end -%> is set and the current privilege level is U <%- end -%> <%- if ext?(:H) -%>

  • mhpmevent27.VSINH <%- if ext?(:Ssccfg) -%>or its alias hpmevent27.SINH<%- end -%> is set and the current privilege level is VS

  • mhpmevent27.VUINH <%- if ext?(:Ssccfg) -%>or its alias hpmevent27.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
0

Software read

This CSR may return a value that is different from what is stored in hardware.

if (HPM_COUNTER_EN[27]) {
  return read_hpm_counter(27);
} else {
  return 0;
}