diff options
Diffstat (limited to 'tools/lib/perf/include')
| -rw-r--r-- | tools/lib/perf/include/internal/evsel.h | 4 | ||||
| -rw-r--r-- | tools/lib/perf/include/perf/cpumap.h | 2 | ||||
| -rw-r--r-- | tools/lib/perf/include/perf/event.h | 58 | ||||
| -rw-r--r-- | tools/lib/perf/include/perf/evsel.h | 4 | 
4 files changed, 61 insertions, 7 deletions
| diff --git a/tools/lib/perf/include/internal/evsel.h b/tools/lib/perf/include/internal/evsel.h index 2a912a1f1989..a99a75d9e78f 100644 --- a/tools/lib/perf/include/internal/evsel.h +++ b/tools/lib/perf/include/internal/evsel.h @@ -30,6 +30,10 @@ struct perf_sample_id {  	struct perf_cpu		 cpu;  	pid_t			 tid; +	/* Guest machine pid and VCPU, valid only if machine_pid is non-zero */ +	pid_t			 machine_pid; +	struct perf_cpu		 vcpu; +  	/* Holds total ID period value for PERF_SAMPLE_READ processing. */  	u64			 period;  }; diff --git a/tools/lib/perf/include/perf/cpumap.h b/tools/lib/perf/include/perf/cpumap.h index 24de795b09bb..03aceb72a783 100644 --- a/tools/lib/perf/include/perf/cpumap.h +++ b/tools/lib/perf/include/perf/cpumap.h @@ -23,7 +23,7 @@ LIBPERF_API void perf_cpu_map__put(struct perf_cpu_map *map);  LIBPERF_API struct perf_cpu perf_cpu_map__cpu(const struct perf_cpu_map *cpus, int idx);  LIBPERF_API int perf_cpu_map__nr(const struct perf_cpu_map *cpus);  LIBPERF_API bool perf_cpu_map__empty(const struct perf_cpu_map *map); -LIBPERF_API struct perf_cpu perf_cpu_map__max(struct perf_cpu_map *map); +LIBPERF_API struct perf_cpu perf_cpu_map__max(const struct perf_cpu_map *map);  LIBPERF_API bool perf_cpu_map__has(const struct perf_cpu_map *map, struct perf_cpu cpu);  #define perf_cpu_map__for_each_cpu(cpu, idx, cpus)		\ diff --git a/tools/lib/perf/include/perf/event.h b/tools/lib/perf/include/perf/event.h index e7758707cadd..93bf93a59c99 100644 --- a/tools/lib/perf/include/perf/event.h +++ b/tools/lib/perf/include/perf/event.h @@ -6,6 +6,7 @@  #include <linux/types.h>  #include <linux/limits.h>  #include <linux/bpf.h> +#include <linux/compiler.h>  #include <sys/types.h> /* pid_t */  #define event_contains(obj, mem) ((obj).header.size > offsetof(typeof(obj), mem)) @@ -76,7 +77,7 @@ struct perf_record_lost_samples {  };  /* - * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID + * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID | PERF_FORMAT_LOST   */  struct perf_record_read {  	struct perf_event_header header; @@ -85,6 +86,7 @@ struct perf_record_read {  	__u64			 time_enabled;  	__u64			 time_running;  	__u64			 id; +	__u64			 lost;  };  struct perf_record_throttle { @@ -153,22 +155,60 @@ enum {  	PERF_CPU_MAP__MASK = 1,  }; +/* + * Array encoding of a perf_cpu_map where nr is the number of entries in cpu[] + * and each entry is a value for a CPU in the map. + */  struct cpu_map_entries {  	__u16			 nr;  	__u16			 cpu[];  }; -struct perf_record_record_cpu_map { +/* Bitmap encoding of a perf_cpu_map where bitmap entries are 32-bit. */ +struct perf_record_mask_cpu_map32 { +	/* Number of mask values. */ +	__u16			 nr; +	/* Constant 4. */ +	__u16			 long_size; +	/* Bitmap data. */ +	__u32			 mask[]; +}; + +/* Bitmap encoding of a perf_cpu_map where bitmap entries are 64-bit. */ +struct perf_record_mask_cpu_map64 { +	/* Number of mask values. */  	__u16			 nr; +	/* Constant 8. */  	__u16			 long_size; -	unsigned long		 mask[]; +	/* Legacy padding. */ +	char                     __pad[4]; +	/* Bitmap data. */ +	__u64			 mask[];  }; -struct perf_record_cpu_map_data { +/* + * 'struct perf_record_cpu_map_data' is packed as unfortunately an earlier + * version had unaligned data and we wish to retain file format compatibility. + * -irogers + */ +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wpacked" +#pragma GCC diagnostic ignored "-Wattributes" + +struct __packed perf_record_cpu_map_data {  	__u16			 type; -	char			 data[]; +	union { +		/* Used when type == PERF_CPU_MAP__CPUS. */ +		struct cpu_map_entries cpus_data; +		/* Used when type == PERF_CPU_MAP__MASK and long_size == 4. */ +		struct perf_record_mask_cpu_map32 mask32_data; +		/* Used when type == PERF_CPU_MAP__MASK and long_size == 8. */ +		struct perf_record_mask_cpu_map64 mask64_data; +	};  }; +#pragma GCC diagnostic pop +  struct perf_record_cpu_map {  	struct perf_event_header	 header;  	struct perf_record_cpu_map_data	 data; @@ -237,6 +277,11 @@ struct id_index_entry {  	__u64			 tid;  }; +struct id_index_entry_2 { +	__u64			 machine_pid; +	__u64			 vcpu; +}; +  struct perf_record_id_index {  	struct perf_event_header header;  	__u64			 nr; @@ -274,6 +319,8 @@ struct perf_record_auxtrace_error {  	__u64			 ip;  	__u64			 time;  	char			 msg[MAX_AUXTRACE_ERROR_MSG]; +	__u32			 machine_pid; +	__u32			 vcpu;  };  struct perf_record_aux { @@ -389,6 +436,7 @@ enum perf_user_event_type { /* above any possible kernel type */  	PERF_RECORD_TIME_CONV			= 79,  	PERF_RECORD_HEADER_FEATURE		= 80,  	PERF_RECORD_COMPRESSED			= 81, +	PERF_RECORD_FINISHED_INIT		= 82,  	PERF_RECORD_HEADER_MAX  }; diff --git a/tools/lib/perf/include/perf/evsel.h b/tools/lib/perf/include/perf/evsel.h index 699c0ed97d34..6f92204075c2 100644 --- a/tools/lib/perf/include/perf/evsel.h +++ b/tools/lib/perf/include/perf/evsel.h @@ -18,8 +18,10 @@ struct perf_counts_values {  			uint64_t val;  			uint64_t ena;  			uint64_t run; +			uint64_t id; +			uint64_t lost;  		}; -		uint64_t values[3]; +		uint64_t values[5];  	};  }; | 
