root/arch/powerpc/perf/hv-24x7.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   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

/* [<][>][^][v][top][bottom][index][help] */