I
NTEL
® X
EON
® P
ROCESSOR
7500 S
ERIES
U
NCORE
P
ROGRAMMING
G
UIDE
UNCORE PERFORMANCE MONITORING
2-101
Table 2-67. M_MSR_PMU_CNT_CTL{5-0} Register – Field Definitions
The M-Box performance monitor data registers are 48b wide. A counter overflow occurs when a carry
out bit from bit 47 is detected. Software can force all uncore counting to freeze after N events by
preloading a monitor with a count value of (2
48
- 1) - N and setting the control register to send a PMI to
the U-Box. Upon receipt of the PMI, the U-Box will disable counting (
). During the interval of time between overflow and global disable, the counter value
will wrap and continue to collect events.
In this way, software can capture the precise number of events that occurred between the time uncore
counting was enabled and when it was disabled (or ‘frozen’) with minimal skew.
If accessible, software can continuously read the data registers without disabling event collection.
Table 2-68. M_MSR_PMU_CNT_{5-0} Register – Field Definitions
The M-Box also includes a 16b timestamp unit that is incremented each M-Box clock tick. It is a free-
running counter unattached to the rest of the M-Box PMU, meaning it does not generate an event fed to
the other counters.
Field
Bits
HW
Reset
Val
Description
ig
63
0 Read zero; writes ignored. (?)
rsv
62:61
0 Reserved; Must write to 0 else behavior is undefined.
ig
60:25
0 Read zero; writes ignored. (?)
rsv
24:22
0 Reserved; Must write to 0 else behavior is undefined.
set_flag_sel
21:19
0 Selects the ‘set’ condition for enable flag. Secondary event select.
See
Table 2-84, “Performance Monitor Events for M-Box Events”
for
events elected by this field.
NOTE: Bit 7 (flag_mode) must be set to 1 to enable this field.
rsv
18:14
0 Reserved; Must write to 0 else behavior is undefined.
inc_sel
13:9
0 Selects increment signal for this counter. Primary event select.
See
Table 2-84, “Performance Monitor Events for M-Box Events”
for
events elected by this field.
rsv
8
0 Reserved; Must write to 0 else behavior is undefined.
flag_mode
7
0 Enable conditional counting using set_flag_sel
wrap_mode
6
0 Counter wrap mode. If set to 0, this counter will stop counting on
detection of over/underflow. If set to 1, this counter will wrap and
continue counting on detection of over/underflow.
storage_mode
5:4
0 Storage mode. If set to 0, no count enable flag is required. If set to 1,
count enable flag must have a value of 1 for counting to occur.
count_mode
3:2
0 00 - count will increase (up)
01 - count will decrease (dn)
10 - count can increase and decrease
pmi_en
1
0 Enable PMON interrupt on counter over/underflow.
en
0
0 Enable counting
Field
Bits
HW
Reset
Val
Description
event_count
47:0
0 48-bit performance event counter