cregit-Linux how code gets into the kernel

Release 4.14 arch/powerpc/perf/hv-24x7.h

/* SPDX-License-Identifier: GPL-2.0 */
#ifndef LINUX_POWERPC_PERF_HV_24X7_H_

#define LINUX_POWERPC_PERF_HV_24X7_H_

#include <linux/types.h>


enum hv_perf_domains {

#define DOMAIN(n, v, x, c) HV_PERF_DOMAIN_##n = v,
#include "hv-24x7-domains.h"

#undef DOMAIN
	
HV_PERF_DOMAIN_MAX,
};


#define H24x7_REQUEST_SIZE(iface_version)	(iface_version == 1 ? 16 : 32)


struct hv_24x7_request {
	/* PHYSICAL domains require enabling via phyp/hmc. */
	
__u8 performance_domain;
	
__u8 reserved[0x1];

	/* bytes to read starting at @data_offset. must be a multiple of 8 */
	
__be16 data_size;

	/*
         * byte offset within the perf domain to read from. must be 8 byte
         * aligned
         */
	
__be32 data_offset;

	/*
         * only valid for VIRTUAL_PROCESSOR domains, ignored for others.
         * -1 means "current partition only"
         *  Enabling via phyp/hmc required for non-"-1" values. 0 forbidden
         *  unless requestor is 0.
         */
	
__be16 starting_lpar_ix;

	/*
         * Ignored when @starting_lpar_ix == -1
         * Ignored when @performance_domain is not VIRTUAL_PROCESSOR_*
         * -1 means "infinite" or all
         */
	
__be16 max_num_lpars;

	/* chip, core, or virtual processor based on @performance_domain */
	
__be16 starting_ix;
	
__be16 max_ix;

	/* The following fields were added in v2 of the 24x7 interface. */

	
__u8 starting_thread_group_ix;

	/* -1 means all thread groups starting at @starting_thread_group_ix */
	
__u8 max_num_thread_groups;

	
__u8 reserved2[0xE];

} __packed;


struct hv_24x7_request_buffer {
	/* 0 - ? */
	/* 1 - ? */
	
__u8 interface_version;
	
__u8 num_requests;
	
__u8 reserved[0xE];
	
struct hv_24x7_request requests[];

} __packed;


struct hv_24x7_result_element_v1 {
	
__be16 lpar_ix;

	/*
         * represents the core, chip, or virtual processor based on the
         * request's @performance_domain
         */
	
__be16 domain_ix;

	/* -1 if @performance_domain does not refer to a virtual processor */
	
__be32 lpar_cfg_instance_id;

	/* size = @result_element_data_size of containing result. */
	
__u64 element_data[];

} __packed;

/*
 * We need a separate struct for v2 because the offset of @element_data changed
 * between versions.
 */

struct hv_24x7_result_element_v2 {
	
__be16 lpar_ix;

	/*
         * represents the core, chip, or virtual processor based on the
         * request's @performance_domain
         */
	
__be16 domain_ix;

	/* -1 if @performance_domain does not refer to a virtual processor */
	
__be32 lpar_cfg_instance_id;

	
__u8 thread_group_ix;

	
__u8 reserved[7];

	/* size = @result_element_data_size of containing result. */
	
__u64 element_data[];

} __packed;


struct hv_24x7_result {
	/*
         * The index of the 24x7 Request Structure in the 24x7 Request Buffer
         * used to request this result.
         */
	
__u8 result_ix;

	/*
         * 0 = not all result elements fit into the buffer, additional requests
         *     required
         * 1 = all result elements were returned
         */
	
__u8 results_complete;
	
__be16 num_elements_returned;

	/*
         * This is a copy of @data_size from the corresponding hv_24x7_request
         *
         * Warning: to obtain the size of each element in @elements you have
         * to add the size of the other members of the result_element struct.
         */
	
__be16 result_element_data_size;
	
__u8 reserved[0x2];

	/*
         * Either
         *      struct hv_24x7_result_element_v1[@num_elements_returned]
         * or
         *      struct hv_24x7_result_element_v2[@num_elements_returned]
         *
         * depending on the interface_version field of the
         * struct hv_24x7_data_result_buffer containing this result.
         */
	
char elements[];

} __packed;


struct hv_24x7_data_result_buffer {
	/* See versioning for request buffer */
	
__u8 interface_version;

	
__u8 num_results;
	
__u8 reserved[0x1];
	
__u8 failing_request_ix;
	
__be32 detailed_rc;
	
__be64 cec_cfg_instance_id;
	
__be64 catalog_version_num;
	
__u8 reserved2[0x8];
	/* WARNING: only valid for the first result due to variable sizes of
         *          results */
	
struct hv_24x7_result results[]; /* [@num_results] */

} __packed;

#endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Cody P Schafer18573.41%225.00%
Thiago Jung Bauermann6023.81%225.00%
Sukadev Bhattiprolu51.98%225.00%
Greg Kroah-Hartman10.40%112.50%
Michael Ellerman10.40%112.50%
Total252100.00%8100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.