diff options
| -rw-r--r-- | tools/arch/x86/include/asm/cpufeatures.h | 2 | ||||
| -rw-r--r-- | tools/arch/x86/include/asm/disabled-features.h | 8 | ||||
| -rw-r--r-- | tools/include/uapi/asm-generic/unistd.h | 4 | ||||
| -rw-r--r-- | tools/include/uapi/drm/i915_drm.h | 8 | ||||
| -rw-r--r-- | tools/include/uapi/linux/in.h | 10 | ||||
| -rw-r--r-- | tools/include/uapi/linux/kvm.h | 19 | ||||
| -rw-r--r-- | tools/include/uapi/linux/prctl.h | 8 | ||||
| -rw-r--r-- | tools/perf/Makefile.perf | 4 | ||||
| -rw-r--r-- | tools/perf/builtin-stat.c | 3 | ||||
| -rw-r--r-- | tools/perf/tests/shell/lib/probe_vfs_getname.sh | 3 | ||||
| -rwxr-xr-x | tools/perf/trace/beauty/prctl_option.sh | 2 | ||||
| -rw-r--r-- | tools/perf/util/annotate.c | 8 | ||||
| -rw-r--r-- | tools/perf/util/callchain.c | 32 | ||||
| -rw-r--r-- | tools/perf/util/callchain.h | 1 | ||||
| -rw-r--r-- | tools/perf/util/machine.c | 2 | ||||
| -rw-r--r-- | tools/perf/util/strbuf.c | 1 | ||||
| -rw-r--r-- | tools/thermal/tmon/Makefile | 2 | 
17 files changed, 89 insertions, 28 deletions
| diff --git a/tools/arch/x86/include/asm/cpufeatures.h b/tools/arch/x86/include/asm/cpufeatures.h index 28c4a502b419..6d6122524711 100644 --- a/tools/arch/x86/include/asm/cpufeatures.h +++ b/tools/arch/x86/include/asm/cpufeatures.h @@ -281,9 +281,11 @@  #define X86_FEATURE_CLZERO		(13*32+ 0) /* CLZERO instruction */  #define X86_FEATURE_IRPERF		(13*32+ 1) /* Instructions Retired Count */  #define X86_FEATURE_XSAVEERPTR		(13*32+ 2) /* Always save/restore FP error pointers */ +#define X86_FEATURE_WBNOINVD		(13*32+ 9) /* WBNOINVD instruction */  #define X86_FEATURE_AMD_IBPB		(13*32+12) /* "" Indirect Branch Prediction Barrier */  #define X86_FEATURE_AMD_IBRS		(13*32+14) /* "" Indirect Branch Restricted Speculation */  #define X86_FEATURE_AMD_STIBP		(13*32+15) /* "" Single Thread Indirect Branch Predictors */ +#define X86_FEATURE_AMD_STIBP_ALWAYS_ON	(13*32+17) /* "" Single Thread Indirect Branch Predictors always-on preferred */  #define X86_FEATURE_AMD_SSBD		(13*32+24) /* "" Speculative Store Bypass Disable */  #define X86_FEATURE_VIRT_SSBD		(13*32+25) /* Virtualized Speculative Store Bypass Disable */  #define X86_FEATURE_AMD_SSB_NO		(13*32+26) /* "" Speculative Store Bypass is fixed in hardware. */ diff --git a/tools/arch/x86/include/asm/disabled-features.h b/tools/arch/x86/include/asm/disabled-features.h index 33833d1909af..a5ea841cc6d2 100644 --- a/tools/arch/x86/include/asm/disabled-features.h +++ b/tools/arch/x86/include/asm/disabled-features.h @@ -16,6 +16,12 @@  # define DISABLE_MPX	(1<<(X86_FEATURE_MPX & 31))  #endif +#ifdef CONFIG_X86_SMAP +# define DISABLE_SMAP	0 +#else +# define DISABLE_SMAP	(1<<(X86_FEATURE_SMAP & 31)) +#endif +  #ifdef CONFIG_X86_INTEL_UMIP  # define DISABLE_UMIP	0  #else @@ -68,7 +74,7 @@  #define DISABLED_MASK6	0  #define DISABLED_MASK7	(DISABLE_PTI)  #define DISABLED_MASK8	0 -#define DISABLED_MASK9	(DISABLE_MPX) +#define DISABLED_MASK9	(DISABLE_MPX|DISABLE_SMAP)  #define DISABLED_MASK10	0  #define DISABLED_MASK11	0  #define DISABLED_MASK12	0 diff --git a/tools/include/uapi/asm-generic/unistd.h b/tools/include/uapi/asm-generic/unistd.h index c7f3321fbe43..d90127298f12 100644 --- a/tools/include/uapi/asm-generic/unistd.h +++ b/tools/include/uapi/asm-generic/unistd.h @@ -738,9 +738,11 @@ __SYSCALL(__NR_statx,     sys_statx)  __SC_COMP(__NR_io_pgetevents, sys_io_pgetevents, compat_sys_io_pgetevents)  #define __NR_rseq 293  __SYSCALL(__NR_rseq, sys_rseq) +#define __NR_kexec_file_load 294 +__SYSCALL(__NR_kexec_file_load,     sys_kexec_file_load)  #undef __NR_syscalls -#define __NR_syscalls 294 +#define __NR_syscalls 295  /*   * 32 bit systems traditionally used different diff --git a/tools/include/uapi/drm/i915_drm.h b/tools/include/uapi/drm/i915_drm.h index a4446f452040..298b2e197744 100644 --- a/tools/include/uapi/drm/i915_drm.h +++ b/tools/include/uapi/drm/i915_drm.h @@ -412,6 +412,14 @@ typedef struct drm_i915_irq_wait {  	int irq_seq;  } drm_i915_irq_wait_t; +/* + * Different modes of per-process Graphics Translation Table, + * see I915_PARAM_HAS_ALIASING_PPGTT + */ +#define I915_GEM_PPGTT_NONE	0 +#define I915_GEM_PPGTT_ALIASING	1 +#define I915_GEM_PPGTT_FULL	2 +  /* Ioctl to query kernel params:   */  #define I915_PARAM_IRQ_ACTIVE            1 diff --git a/tools/include/uapi/linux/in.h b/tools/include/uapi/linux/in.h index 48e8a225b985..f6052e70bf40 100644 --- a/tools/include/uapi/linux/in.h +++ b/tools/include/uapi/linux/in.h @@ -266,10 +266,14 @@ struct sockaddr_in {  #define	IN_CLASSD(a)		((((long int) (a)) & 0xf0000000) == 0xe0000000)  #define	IN_MULTICAST(a)		IN_CLASSD(a) -#define IN_MULTICAST_NET	0xF0000000 +#define	IN_MULTICAST_NET	0xe0000000 -#define	IN_EXPERIMENTAL(a)	((((long int) (a)) & 0xf0000000) == 0xf0000000) -#define	IN_BADCLASS(a)		IN_EXPERIMENTAL((a)) +#define	IN_BADCLASS(a)		((((long int) (a) ) == 0xffffffff) +#define	IN_EXPERIMENTAL(a)	IN_BADCLASS((a)) + +#define	IN_CLASSE(a)		((((long int) (a)) & 0xf0000000) == 0xf0000000) +#define	IN_CLASSE_NET		0xffffffff +#define	IN_CLASSE_NSHIFT	0  /* Address to accept any incoming messages. */  #define	INADDR_ANY		((unsigned long int) 0x00000000) diff --git a/tools/include/uapi/linux/kvm.h b/tools/include/uapi/linux/kvm.h index 2b7a652c9fa4..6d4ea4b6c922 100644 --- a/tools/include/uapi/linux/kvm.h +++ b/tools/include/uapi/linux/kvm.h @@ -492,6 +492,17 @@ struct kvm_dirty_log {  	};  }; +/* for KVM_CLEAR_DIRTY_LOG */ +struct kvm_clear_dirty_log { +	__u32 slot; +	__u32 num_pages; +	__u64 first_page; +	union { +		void __user *dirty_bitmap; /* one bit per page */ +		__u64 padding2; +	}; +}; +  /* for KVM_SET_SIGNAL_MASK */  struct kvm_signal_mask {  	__u32 len; @@ -975,6 +986,8 @@ struct kvm_ppc_resize_hpt {  #define KVM_CAP_HYPERV_ENLIGHTENED_VMCS 163  #define KVM_CAP_EXCEPTION_PAYLOAD 164  #define KVM_CAP_ARM_VM_IPA_SIZE 165 +#define KVM_CAP_MANUAL_DIRTY_LOG_PROTECT 166 +#define KVM_CAP_HYPERV_CPUID 167  #ifdef KVM_CAP_IRQ_ROUTING @@ -1421,6 +1434,12 @@ struct kvm_enc_region {  #define KVM_GET_NESTED_STATE         _IOWR(KVMIO, 0xbe, struct kvm_nested_state)  #define KVM_SET_NESTED_STATE         _IOW(KVMIO,  0xbf, struct kvm_nested_state) +/* Available with KVM_CAP_MANUAL_DIRTY_LOG_PROTECT */ +#define KVM_CLEAR_DIRTY_LOG          _IOWR(KVMIO, 0xc0, struct kvm_clear_dirty_log) + +/* Available with KVM_CAP_HYPERV_CPUID */ +#define KVM_GET_SUPPORTED_HV_CPUID _IOWR(KVMIO, 0xc1, struct kvm_cpuid2) +  /* Secure Encrypted Virtualization command */  enum sev_cmd_id {  	/* Guest initialization commands */ diff --git a/tools/include/uapi/linux/prctl.h b/tools/include/uapi/linux/prctl.h index b17201edfa09..b4875a93363a 100644 --- a/tools/include/uapi/linux/prctl.h +++ b/tools/include/uapi/linux/prctl.h @@ -220,4 +220,12 @@ struct prctl_mm_map {  # define PR_SPEC_DISABLE		(1UL << 2)  # define PR_SPEC_FORCE_DISABLE		(1UL << 3) +/* Reset arm64 pointer authentication keys */ +#define PR_PAC_RESET_KEYS		54 +# define PR_PAC_APIAKEY			(1UL << 0) +# define PR_PAC_APIBKEY			(1UL << 1) +# define PR_PAC_APDAKEY			(1UL << 2) +# define PR_PAC_APDBKEY			(1UL << 3) +# define PR_PAC_APGAKEY			(1UL << 4) +  #endif /* _LINUX_PRCTL_H */ diff --git a/tools/perf/Makefile.perf b/tools/perf/Makefile.perf index ff29c3372ec3..2921f829a0f4 100644 --- a/tools/perf/Makefile.perf +++ b/tools/perf/Makefile.perf @@ -524,12 +524,14 @@ $(arch_errno_name_array): $(arch_errno_tbl)  all: shell_compatibility_test $(ALL_PROGRAMS) $(LANG_BINDINGS) $(OTHER_PROGRAMS) +# Create python binding output directory if not already present +_dummy := $(shell [ -d '$(OUTPUT)python' ] || mkdir -p '$(OUTPUT)python') +  $(OUTPUT)python/perf.so: $(PYTHON_EXT_SRCS) $(PYTHON_EXT_DEPS) $(LIBTRACEEVENT_DYNAMIC_LIST)  	$(QUIET_GEN)LDSHARED="$(CC) -pthread -shared" \          CFLAGS='$(CFLAGS)' LDFLAGS='$(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS)' \  	  $(PYTHON_WORD) util/setup.py \  	  --quiet build_ext; \ -	mkdir -p $(OUTPUT)python && \  	cp $(PYTHON_EXTBUILD_LIB)perf*.so $(OUTPUT)python/  please_set_SHELL_PATH_to_a_more_modern_shell: diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 1410d66192f7..63a3afc7f32b 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c @@ -561,7 +561,8 @@ try_again:  					break;  			}  		} -		wait4(child_pid, &status, 0, &stat_config.ru_data); +		if (child_pid != -1) +			wait4(child_pid, &status, 0, &stat_config.ru_data);  		if (workload_exec_errno) {  			const char *emsg = str_error_r(workload_exec_errno, msg, sizeof(msg)); diff --git a/tools/perf/tests/shell/lib/probe_vfs_getname.sh b/tools/perf/tests/shell/lib/probe_vfs_getname.sh index 1c16e56cd93e..7cb99b433888 100644 --- a/tools/perf/tests/shell/lib/probe_vfs_getname.sh +++ b/tools/perf/tests/shell/lib/probe_vfs_getname.sh @@ -13,7 +13,8 @@ add_probe_vfs_getname() {  	local verbose=$1  	if [ $had_vfs_getname -eq 1 ] ; then  		line=$(perf probe -L getname_flags 2>&1 | egrep 'result.*=.*filename;' | sed -r 's/[[:space:]]+([[:digit:]]+)[[:space:]]+result->uptr.*/\1/') -		perf probe $verbose "vfs_getname=getname_flags:${line} pathname=result->name:string" +		perf probe -q       "vfs_getname=getname_flags:${line} pathname=result->name:string" || \ +		perf probe $verbose "vfs_getname=getname_flags:${line} pathname=filename:string"  	fi  } diff --git a/tools/perf/trace/beauty/prctl_option.sh b/tools/perf/trace/beauty/prctl_option.sh index d32f8f1124af..3109d7b05e11 100755 --- a/tools/perf/trace/beauty/prctl_option.sh +++ b/tools/perf/trace/beauty/prctl_option.sh @@ -4,7 +4,7 @@  [ $# -eq 1 ] && header_dir=$1 || header_dir=tools/include/uapi/linux/  printf "static const char *prctl_options[] = {\n" -regex='^#define[[:space:]]+PR_([GS]ET\w+)[[:space:]]*([[:xdigit:]]+).*' +regex='^#define[[:space:]]+PR_(\w+)[[:space:]]*([[:xdigit:]]+).*'  egrep $regex ${header_dir}/prctl.h | grep -v PR_SET_PTRACER | \  	sed -r "s/$regex/\2 \1/g"	| \  	sort -n | xargs printf "\t[%s] = \"%s\",\n" diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c index ac9805e0bc76..70de8f6b3aee 100644 --- a/tools/perf/util/annotate.c +++ b/tools/perf/util/annotate.c @@ -1723,15 +1723,14 @@ static int symbol__disassemble(struct symbol *sym, struct annotate_args *args)  	err = asprintf(&command,  		 "%s %s%s --start-address=0x%016" PRIx64  		 " --stop-address=0x%016" PRIx64 -		 " -l -d %s %s -C \"%s\" 2>/dev/null|grep -v \"%s:\"|expand", +		 " -l -d %s %s -C \"$1\" 2>/dev/null|grep -v \"$1:\"|expand",  		 opts->objdump_path ?: "objdump",  		 opts->disassembler_style ? "-M " : "",  		 opts->disassembler_style ?: "",  		 map__rip_2objdump(map, sym->start),  		 map__rip_2objdump(map, sym->end),  		 opts->show_asm_raw ? "" : "--no-show-raw", -		 opts->annotate_src ? "-S" : "", -		 symfs_filename, symfs_filename); +		 opts->annotate_src ? "-S" : "");  	if (err < 0) {  		pr_err("Failure allocating memory for the command to run\n"); @@ -1756,7 +1755,8 @@ static int symbol__disassemble(struct symbol *sym, struct annotate_args *args)  		close(stdout_fd[0]);  		dup2(stdout_fd[1], 1);  		close(stdout_fd[1]); -		execl("/bin/sh", "sh", "-c", command, NULL); +		execl("/bin/sh", "sh", "-c", command, "--", symfs_filename, +		      NULL);  		perror(command);  		exit(-1);  	} diff --git a/tools/perf/util/callchain.c b/tools/perf/util/callchain.c index 32ef7bdca1cf..dc2212e12184 100644 --- a/tools/perf/util/callchain.c +++ b/tools/perf/util/callchain.c @@ -766,6 +766,7 @@ static enum match_result match_chain(struct callchain_cursor_node *node,  			cnode->cycles_count += node->branch_flags.cycles;  			cnode->iter_count += node->nr_loop_iter;  			cnode->iter_cycles += node->iter_cycles; +			cnode->from_count++;  		}  	} @@ -1345,10 +1346,10 @@ static int branch_to_str(char *bf, int bfsize,  static int branch_from_str(char *bf, int bfsize,  			   u64 branch_count,  			   u64 cycles_count, u64 iter_count, -			   u64 iter_cycles) +			   u64 iter_cycles, u64 from_count)  {  	int printed = 0, i = 0; -	u64 cycles; +	u64 cycles, v = 0;  	cycles = cycles_count / branch_count;  	if (cycles) { @@ -1357,14 +1358,16 @@ static int branch_from_str(char *bf, int bfsize,  				bf + printed, bfsize - printed);  	} -	if (iter_count) { -		printed += count_pri64_printf(i++, "iter", -				iter_count, -				bf + printed, bfsize - printed); +	if (iter_count && from_count) { +		v = iter_count / from_count; +		if (v) { +			printed += count_pri64_printf(i++, "iter", +					v, bf + printed, bfsize - printed); -		printed += count_pri64_printf(i++, "avg_cycles", -				iter_cycles / iter_count, -				bf + printed, bfsize - printed); +			printed += count_pri64_printf(i++, "avg_cycles", +					iter_cycles / iter_count, +					bf + printed, bfsize - printed); +		}  	}  	if (i) @@ -1377,6 +1380,7 @@ static int counts_str_build(char *bf, int bfsize,  			     u64 branch_count, u64 predicted_count,  			     u64 abort_count, u64 cycles_count,  			     u64 iter_count, u64 iter_cycles, +			     u64 from_count,  			     struct branch_type_stat *brtype_stat)  {  	int printed; @@ -1389,7 +1393,8 @@ static int counts_str_build(char *bf, int bfsize,  				predicted_count, abort_count, brtype_stat);  	} else {  		printed = branch_from_str(bf, bfsize, branch_count, -				cycles_count, iter_count, iter_cycles); +				cycles_count, iter_count, iter_cycles, +				from_count);  	}  	if (!printed) @@ -1402,13 +1407,14 @@ static int callchain_counts_printf(FILE *fp, char *bf, int bfsize,  				   u64 branch_count, u64 predicted_count,  				   u64 abort_count, u64 cycles_count,  				   u64 iter_count, u64 iter_cycles, +				   u64 from_count,  				   struct branch_type_stat *brtype_stat)  {  	char str[256];  	counts_str_build(str, sizeof(str), branch_count,  			 predicted_count, abort_count, cycles_count, -			 iter_count, iter_cycles, brtype_stat); +			 iter_count, iter_cycles, from_count, brtype_stat);  	if (fp)  		return fprintf(fp, "%s", str); @@ -1422,6 +1428,7 @@ int callchain_list_counts__printf_value(struct callchain_list *clist,  	u64 branch_count, predicted_count;  	u64 abort_count, cycles_count;  	u64 iter_count, iter_cycles; +	u64 from_count;  	branch_count = clist->branch_count;  	predicted_count = clist->predicted_count; @@ -1429,11 +1436,12 @@ int callchain_list_counts__printf_value(struct callchain_list *clist,  	cycles_count = clist->cycles_count;  	iter_count = clist->iter_count;  	iter_cycles = clist->iter_cycles; +	from_count = clist->from_count;  	return callchain_counts_printf(fp, bf, bfsize, branch_count,  				       predicted_count, abort_count,  				       cycles_count, iter_count, iter_cycles, -				       &clist->brtype_stat); +				       from_count, &clist->brtype_stat);  }  static void free_callchain_node(struct callchain_node *node) diff --git a/tools/perf/util/callchain.h b/tools/perf/util/callchain.h index 154560b1eb65..99d38ac019b8 100644 --- a/tools/perf/util/callchain.h +++ b/tools/perf/util/callchain.h @@ -118,6 +118,7 @@ struct callchain_list {  		bool		has_children;  	};  	u64			branch_count; +	u64			from_count;  	u64			predicted_count;  	u64			abort_count;  	u64			cycles_count; diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c index 6fcb3bce0442..143f7057d581 100644 --- a/tools/perf/util/machine.c +++ b/tools/perf/util/machine.c @@ -2005,7 +2005,7 @@ static void save_iterations(struct iterations *iter,  {  	int i; -	iter->nr_loop_iter = nr; +	iter->nr_loop_iter++;  	iter->cycles = 0;  	for (i = 0; i < nr; i++) diff --git a/tools/perf/util/strbuf.c b/tools/perf/util/strbuf.c index 9005fbe0780e..23092fd6451d 100644 --- a/tools/perf/util/strbuf.c +++ b/tools/perf/util/strbuf.c @@ -109,7 +109,6 @@ static int strbuf_addv(struct strbuf *sb, const char *fmt, va_list ap)  			return ret;  		}  		len = vsnprintf(sb->buf + sb->len, sb->alloc - sb->len, fmt, ap_saved); -		va_end(ap_saved);  		if (len > strbuf_avail(sb)) {  			pr_debug("this should not happen, your vsnprintf is broken");  			va_end(ap_saved); diff --git a/tools/thermal/tmon/Makefile b/tools/thermal/tmon/Makefile index 89a2444c1df2..59e417ec3e13 100644 --- a/tools/thermal/tmon/Makefile +++ b/tools/thermal/tmon/Makefile @@ -6,7 +6,7 @@ VERSION = 1.0  BINDIR=usr/bin  WARNFLAGS=-Wall -Wshadow -W -Wformat -Wimplicit-function-declaration -Wimplicit-int -override CFLAGS+= -O1 ${WARNFLAGS} +override CFLAGS+= $(call cc-option,-O3,-O1) ${WARNFLAGS}  # Add "-fstack-protector" only if toolchain supports it.  override CFLAGS+= $(call cc-option,-fstack-protector-strong)  CC?= $(CROSS_COMPILE)gcc | 
