xref: /freebsd/lib/libpmc/pmc.haswelluc.3 (revision 2e620256bd76c449c835c604e404483437743011)
1.\" Copyright (c) 2013 Hiren Panchasara <hiren.panchasara@gmail.com>
2.\" All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\"
13.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
14.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
17.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23.\" SUCH DAMAGE.
24.\"
25.Dd March 22, 2013
26.Dt PMC.HASWELLUC 3
27.Os
28.Sh NAME
29.Nm pmc.haswelluc
30.Nd uncore measurement events for
31.Tn Intel
32.Tn Haswell
33family CPUs
34.Sh LIBRARY
35.Lb libpmc
36.Sh SYNOPSIS
37.In pmc.h
38.Sh DESCRIPTION
39.Tn Intel
40.Tn "Haswell"
41CPUs contain PMCs conforming to version 3 of the
42.Tn Intel
43performance measurement architecture.
44These CPUs contain two classes of PMCs:
45.Bl -tag -width "Li PMC_CLASS_UCP"
46.It Li PMC_CLASS_UCF
47Fixed-function counters that count only one hardware event per counter.
48.It Li PMC_CLASS_UCP
49Programmable counters that may be configured to count one of a defined
50set of hardware events.
51.El
52.Pp
53The number of PMCs available in each class and their widths need to be
54determined at run time by calling
55.Xr pmc_cpuinfo 3 .
56.Pp
57Intel Haswell PMCs are documented in
58.Rs
59.%B "Intel(R) 64 and IA-32 Architectures Software Developers Manual"
60.%T "Combined Volumes: 1, 2A, 2B, 2C, 3A, 3B and 3C"
61.%N "Order Number: 325462-045US"
62.%D January 2013
63.%Q "Intel Corporation"
64.Re
65.Ss HASWELL UNCORE FIXED FUNCTION PMCS
66These PMCs and their supported events are documented in
67.Xr pmc.ucf 3 .
68Not all CPUs in this family implement fixed-function counters.
69.Ss HASWELL UNCORE PROGRAMMABLE PMCS
70The programmable PMCs support the following capabilities:
71.Bl -column "PMC_CAP_INTERRUPT" "Support"
72.It Em Capability Ta Em Support
73.It PMC_CAP_CASCADE Ta \&No
74.It PMC_CAP_EDGE Ta Yes
75.It PMC_CAP_INTERRUPT Ta \&No
76.It PMC_CAP_INVERT Ta Yes
77.It PMC_CAP_READ Ta Yes
78.It PMC_CAP_PRECISE Ta \&No
79.It PMC_CAP_SYSTEM Ta \&No
80.It PMC_CAP_TAGGING Ta \&No
81.It PMC_CAP_THRESHOLD Ta Yes
82.It PMC_CAP_USER Ta \&No
83.It PMC_CAP_WRITE Ta Yes
84.El
85.Ss Event Qualifiers
86Event specifiers for these PMCs support the following common
87qualifiers:
88.Bl -tag -width indent
89.It Li cmask= Ns Ar value
90Configure the PMC to increment only if the number of configured
91events measured in a cycle is greater than or equal to
92.Ar value .
93.It Li edge
94Configure the PMC to count the number of de-asserted to asserted
95transitions of the conditions expressed by the other qualifiers.
96If specified, the counter will increment only once whenever a
97condition becomes true, irrespective of the number of clocks during
98which the condition remains true.
99.It Li inv
100Invert the sense of comparison when the
101.Dq Li cmask
102qualifier is present, making the counter increment when the number of
103events per cycle is less than the value specified by the
104.Dq Li cmask
105qualifier.
106.El
107.Ss Event Specifiers (Programmable PMCs)
108Haswell programmable PMCs support the following events:
109.Bl -tag -width indent
110.It Li UNC_CBO_XSNP_RESPONSE.MISS
111.Pq Event 22H , Umask 01H
112A snoop misses in some processor core.
113.It Li UNC_CBO_XSNP_RESPONSE.INVAL
114.Pq Event 22H , Umask 02H
115A snoop invalidates a non-modified line in some
116processor core.
117.It Li UNC_CBO_XSNP_RESPONSE.HIT
118.Pq Event 22H , Umask 04H
119A snoop hits a non-modified line in some processor
120core.
121.It Li UNC_CBO_XSNP_RESPONSE.HITM
122.Pq Event 22H , Umask 08H
123A snoop hits a modified line in some processor core.
124.It Li UNC_CBO_XSNP_RESPONSE.INVAL_M
125.Pq Event 22H , Umask 10H
126A snoop invalidates a modified line in some processor
127core.
128.It Li UNC_CBO_XSNP_RESPONSE.EXTERNAL_FILTER
129.Pq Event 22H , Umask 20H
130Filter on cross-core snoops initiated by this Cbox due
131to external snoop request.
132.It Li UNC_CBO_XSNP_RESPONSE.XCORE_FILTER
133.Pq Event 22H , Umask 40H
134Filter on cross-core snoops initiated by this Cbox due
135to processor core memory request.
136.It Li UNC_CBO_XSNP_RESPONSE.EVICTION_FILTER
137.Pq Event 22H , Umask 80H
138Filter on cross-core snoops initiated by this Cbox due
139to LLC eviction.
140.It Li UNC_CBO_CACHE_LOOKUP.M
141.Pq Event 34H , Umask 01H
142LLC lookup request that access cache and found line in
143M-state.
144.It Li UNC_CBO_CACHE_LOOKUP.ES
145.Pq Event 34H , Umask 06H
146LLC lookup request that access cache and found line in
147E or S state.
148.It Li UNC_CBO_CACHE_LOOKUP.I
149.Pq Event 34H , Umask 08H
150LLC lookup request that access cache and found line in
151I-state.
152.It Li UNC_CBO_CACHE_LOOKUP.READ_FILTER
153.Pq Event 34H , Umask 10H
154Filter on processor core initiated cacheable read
155requests.
156Must combine with at least one of 01H, 02H, 04H, 08H.
157.It Li UNC_CBO_CACHE_LOOKUP.WRITE_FILTER
158.Pq Event 34H , Umask 20H
159Filter on processor core initiated cacheable write requests.
160Must combine with at least one of 01H, 02H, 04H, 08H.
161.It Li UNC_CBO_CACHE_LOOKUP.EXTSNP_FILTER
162.Pq Event 34H , Umask 40H
163Filter on external snoop requests.
164Must combine with at least one of 01H, 02H, 04H, 08H.
165.It Li UNC_CBO_CACHE_LOOKUP.ANY_REQUEST_FILTER
166.Pq Event 34H , Umask 80H
167Filter on any IRQ or IPQ initiated requests including
168uncacheable, non-coherent requests.
169Must combine with at least one of 01H, 02H, 04H, 08H.
170.It Li UNC_ARB_TRK_OCCUPANCY.ALL
171.Pq Event 80H , Umask 01H
172Counts cycles weighted by the number of requests
173waiting for data returning from the memory controller.
174Accounts for coherent and non-coherent requests
175initiated by IA cores, processor graphic units, or LLC.
176.It Li UNC_ARB_TRK_REQUEST.ALL
177.Pq Event 81H , Umask 01H
178Counts the number of coherent and in-coherent
179requests initiated by IA cores, processor graphic units,
180or LLC.
181.It Li UNC_ARB_TRK_REQUEST.WRITES
182.Pq Event 81H , Umask 20H
183Counts the number of allocated write entries, include
184full, partial, and LLC evictions.
185.It Li UNC_ARB_TRK_REQUEST.EVICTIONS
186.Pq Event 81H , Umask 80H
187Counts the number of LLC evictions allocated.
188.It Li UNC_ARB_COH , Umask TRK_OCCUPANCY.ALL
189.Pq Event 83H , Umask 01H
190Cycles weighted by number of requests pending in
191Coherency Tracker.
192.It Li UNC_ARB_COH , Umask TRK_REQUEST.ALL
193.Pq Event 84H , Umask 01H
194Number of requests allocated in Coherency Tracker.
195.El
196.Sh SEE ALSO
197.Xr pmc 3 ,
198.Xr pmc.atom 3 ,
199.Xr pmc.core 3 ,
200.Xr pmc.corei7 3 ,
201.Xr pmc.corei7uc 3 ,
202.Xr pmc.haswell 3 ,
203.Xr pmc.iaf 3 ,
204.Xr pmc.k7 3 ,
205.Xr pmc.k8 3 ,
206.Xr pmc.sandybridge 3 ,
207.Xr pmc.sandybridgeuc 3 ,
208.Xr pmc.sandybridgexeon 3 ,
209.Xr pmc.soft 3 ,
210.Xr pmc.tsc 3 ,
211.Xr pmc.ucf 3 ,
212.Xr pmc.westmere 3 ,
213.Xr pmc.westmereuc 3 ,
214.Xr pmc_cpuinfo 3 ,
215.Xr pmclog 3 ,
216.Xr hwpmc 4
217.Sh HISTORY
218The
219.Nm pmc
220library first appeared in
221.Fx 6.0 .
222.Sh AUTHORS
223.An -nosplit
224The
225.Lb libpmc
226library was written by
227.An Joseph Koshy Aq Mt jkoshy@FreeBSD.org .
228The support for the Haswell
229microarchitecture was added by
230.An Hiren Panchasara Aq Mt hiren.panchasara@gmail.com .
231