Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/arch/powerpc/perf/hv-24x7.h
26451 views
1
/* SPDX-License-Identifier: GPL-2.0 */
2
#ifndef LINUX_POWERPC_PERF_HV_24X7_H_
3
#define LINUX_POWERPC_PERF_HV_24X7_H_
4
5
#include <linux/types.h>
6
7
enum hv_perf_domains {
8
#define DOMAIN(n, v, x, c) HV_PERF_DOMAIN_##n = v,
9
#include "hv-24x7-domains.h"
10
#undef DOMAIN
11
HV_PERF_DOMAIN_MAX,
12
};
13
14
#define H24x7_REQUEST_SIZE(iface_version) (iface_version == 1 ? 16 : 32)
15
16
struct hv_24x7_request {
17
/* PHYSICAL domains require enabling via phyp/hmc. */
18
__u8 performance_domain;
19
__u8 reserved[0x1];
20
21
/* bytes to read starting at @data_offset. must be a multiple of 8 */
22
__be16 data_size;
23
24
/*
25
* byte offset within the perf domain to read from. must be 8 byte
26
* aligned
27
*/
28
__be32 data_offset;
29
30
/*
31
* only valid for VIRTUAL_PROCESSOR domains, ignored for others.
32
* -1 means "current partition only"
33
* Enabling via phyp/hmc required for non-"-1" values. 0 forbidden
34
* unless requestor is 0.
35
*/
36
__be16 starting_lpar_ix;
37
38
/*
39
* Ignored when @starting_lpar_ix == -1
40
* Ignored when @performance_domain is not VIRTUAL_PROCESSOR_*
41
* -1 means "infinite" or all
42
*/
43
__be16 max_num_lpars;
44
45
/* chip, core, or virtual processor based on @performance_domain */
46
__be16 starting_ix;
47
__be16 max_ix;
48
49
/* The following fields were added in v2 of the 24x7 interface. */
50
51
__u8 starting_thread_group_ix;
52
53
/* -1 means all thread groups starting at @starting_thread_group_ix */
54
__u8 max_num_thread_groups;
55
56
__u8 reserved2[0xE];
57
} __packed;
58
59
struct hv_24x7_request_buffer {
60
/* 0 - ? */
61
/* 1 - ? */
62
__u8 interface_version;
63
__u8 num_requests;
64
__u8 reserved[0xE];
65
struct hv_24x7_request requests[];
66
} __packed;
67
68
struct hv_24x7_result_element_v1 {
69
__be16 lpar_ix;
70
71
/*
72
* represents the core, chip, or virtual processor based on the
73
* request's @performance_domain
74
*/
75
__be16 domain_ix;
76
77
/* -1 if @performance_domain does not refer to a virtual processor */
78
__be32 lpar_cfg_instance_id;
79
80
/* size = @result_element_data_size of containing result. */
81
__u64 element_data[];
82
} __packed;
83
84
/*
85
* We need a separate struct for v2 because the offset of @element_data changed
86
* between versions.
87
*/
88
struct hv_24x7_result_element_v2 {
89
__be16 lpar_ix;
90
91
/*
92
* represents the core, chip, or virtual processor based on the
93
* request's @performance_domain
94
*/
95
__be16 domain_ix;
96
97
/* -1 if @performance_domain does not refer to a virtual processor */
98
__be32 lpar_cfg_instance_id;
99
100
__u8 thread_group_ix;
101
102
__u8 reserved[7];
103
104
/* size = @result_element_data_size of containing result. */
105
__u64 element_data[];
106
} __packed;
107
108
struct hv_24x7_result {
109
/*
110
* The index of the 24x7 Request Structure in the 24x7 Request Buffer
111
* used to request this result.
112
*/
113
__u8 result_ix;
114
115
/*
116
* 0 = not all result elements fit into the buffer, additional requests
117
* required
118
* 1 = all result elements were returned
119
*/
120
__u8 results_complete;
121
__be16 num_elements_returned;
122
123
/*
124
* This is a copy of @data_size from the corresponding hv_24x7_request
125
*
126
* Warning: to obtain the size of each element in @elements you have
127
* to add the size of the other members of the result_element struct.
128
*/
129
__be16 result_element_data_size;
130
__u8 reserved[0x2];
131
132
/*
133
* Either
134
* struct hv_24x7_result_element_v1[@num_elements_returned]
135
* or
136
* struct hv_24x7_result_element_v2[@num_elements_returned]
137
*
138
* depending on the interface_version field of the
139
* struct hv_24x7_data_result_buffer containing this result.
140
*/
141
char elements[];
142
} __packed;
143
144
struct hv_24x7_data_result_buffer {
145
/* See versioning for request buffer */
146
__u8 interface_version;
147
148
__u8 num_results;
149
__u8 reserved[0x1];
150
__u8 failing_request_ix;
151
__be32 detailed_rc;
152
__be64 cec_cfg_instance_id;
153
__be64 catalog_version_num;
154
__u8 reserved2[0x8];
155
/* WARNING: only valid for the first result due to variable sizes of
156
* results */
157
struct hv_24x7_result results[]; /* [@num_results] */
158
} __packed;
159
160
#endif
161
162