diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2022-07-02 09:28:36 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2022-07-02 09:28:36 -0700 | 
| commit | bb7c51268776941b7533374caabcaaed302b91e0 (patch) | |
| tree | ee85d082f387a196b91e87da6c3f2df3fe1c33b6 /tools/perf/util/bpf-utils.c | |
| parent | 5411de073362300d99bb35d46d77d656760e4606 (diff) | |
| parent | ff898552fb32d255517fb0676f9fa500664c484d (diff) | |
Merge tag 'perf-tools-fixes-for-v5.19-2022-07-02' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux
Pull perf tools fixes from Arnaldo Carvalho de Melo:
 - BPF program info linear (BPIL) data is accessed assuming 64-bit
   alignment resulting in undefined behavior as the data is just byte
   aligned. Fix it, Found using -fsanitize=undefined.
 - Fix 'perf offcpu' build on old kernels wrt task_struct's
   state/__state field.
 - Fix perf_event_attr.sample_type setting on the 'offcpu-time' event
   synthesized by the 'perf offcpu' tool.
 - Don't bail out when synthesizing PERF_RECORD_ events for pre-existing
   threads when one goes away while parsing its procfs entries.
 - Don't sort the task scan result from /proc, its not needed and
   introduces bugs when the main thread isn't the first one to be
   processed.
 - Fix uninitialized 'offset' variable on aarch64 in the unwind code.
 - Sync KVM headers with the kernel sources.
* tag 'perf-tools-fixes-for-v5.19-2022-07-02' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux:
  perf synthetic-events: Ignore dead threads during event synthesis
  perf synthetic-events: Don't sort the task scan result from /proc
  perf unwind: Fix unitialized 'offset' variable on aarch64
  tools headers UAPI: Sync linux/kvm.h with the kernel sources
  perf bpf: 8 byte align bpil data
  tools kvm headers arm64: Update KVM headers from the kernel sources
  perf offcpu: Accept allowed sample types only
  perf offcpu: Fix build failure on old kernels
Diffstat (limited to 'tools/perf/util/bpf-utils.c')
| -rw-r--r-- | tools/perf/util/bpf-utils.c | 5 | 
1 files changed, 2 insertions, 3 deletions
| diff --git a/tools/perf/util/bpf-utils.c b/tools/perf/util/bpf-utils.c index e271e05e51bc..80b1d2b3729b 100644 --- a/tools/perf/util/bpf-utils.c +++ b/tools/perf/util/bpf-utils.c @@ -149,11 +149,10 @@ get_bpf_prog_info_linear(int fd, __u64 arrays)  		count = bpf_prog_info_read_offset_u32(&info, desc->count_offset);  		size  = bpf_prog_info_read_offset_u32(&info, desc->size_offset); -		data_len += count * size; +		data_len += roundup(count * size, sizeof(__u64));  	}  	/* step 3: allocate continuous memory */ -	data_len = roundup(data_len, sizeof(__u64));  	info_linear = malloc(sizeof(struct perf_bpil) + data_len);  	if (!info_linear)  		return ERR_PTR(-ENOMEM); @@ -180,7 +179,7 @@ get_bpf_prog_info_linear(int fd, __u64 arrays)  		bpf_prog_info_set_offset_u64(&info_linear->info,  					     desc->array_offset,  					     ptr_to_u64(ptr)); -		ptr += count * size; +		ptr += roundup(count * size, sizeof(__u64));  	}  	/* step 5: call syscall again to get required arrays */ | 
