Commit 713eee84 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'perf-tools-2020-08-14' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux

Pull more perf tools updates from Arnaldo Carvalho de Melo:
 "Fixes:
   - Fixes for 'perf bench numa'.

   - Always memset source before memcpy in 'perf bench mem'.

   - Quote CC and CXX for their arguments to fix build in environments
     using those variables to pass more than just the compiler names.

   - Fix module symbol processing, addressing regression detected via
     "perf test".

   - Allow multiple probes in record+script_probe_vfs_getname.sh 'perf
     test' entry.

  Improvements:
   - Add script to autogenerate socket family name id->string table from
     copy of kernel header, used so far in 'perf trace'.

   - 'perf ftrace' improvements to provide similar options for this
     utility so that one can go from 'perf record', 'perf trace', etc to
     'perf ftrace' just by changing the name of the subcommand.

   - Prefer new "sched:sched_waking" trace event when it exists in 'perf
     sched' post processing.

   - Update POWER9 metrics to utilize other metrics.

   - Fall back to querying debuginfod if debuginfo not found locally.

  Miscellaneous:
   - Sync various kvm headers with kernel sources"

* tag 'perf-tools-2020-08-14' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux: (40 commits)
  perf ftrace: Make option description initials all capital letters
  perf build-ids: Fall back to debuginfod query if debuginfo not found
  perf bench numa: Remove dead code in parse_nodes_opt()
  perf stat: Update POWER9 metrics to utilize other metrics
  perf ftrace: Add change log
  perf: ftrace: Add set_tracing_options() to set all trace options
  perf ftrace: Add option --tid to filter by thread id
  perf ftrace: Add option -D/--delay to delay tracing
  perf: ftrace: Allow set graph depth by '--graph-opts'
  perf ftrace: Add support for trace option tracing_thresh
  perf ftrace: Add option 'verbose' to show more info for graph tracer
  perf ftrace: Add support for tracing option 'irq-info'
  perf ftrace: Add support for trace option funcgraph-irqs
  perf ftrace: Add support for trace option sleep-time
  perf ftrace: Add support for tracing option 'func_stack_trace'
  perf tools: Add general function to parse sublevel options
  perf ftrace: Add option '--inherit' to trace children processes
  perf ftrace: Show trace column header
  perf ftrace: Add option '-m/--buffer-size' to set per-cpu buffer size
  perf ftrace: Factor out function write_tracing_file_int()
  ...
parents 50f6c7db 492e4edb
...@@ -13566,6 +13566,7 @@ F: arch/*/kernel/perf_event*.c ...@@ -13566,6 +13566,7 @@ F: arch/*/kernel/perf_event*.c
F: include/linux/perf_event.h F: include/linux/perf_event.h
F: include/uapi/linux/perf_event.h F: include/uapi/linux/perf_event.h
F: kernel/events/* F: kernel/events/*
F: tools/lib/perf/
F: tools/perf/ F: tools/perf/
PERFORMANCE EVENTS SUBSYSTEM ARM64 PMU EVENTS PERFORMANCE EVENTS SUBSYSTEM ARM64 PMU EVENTS
......
...@@ -231,11 +231,13 @@ struct kvm_guest_debug_arch { ...@@ -231,11 +231,13 @@ struct kvm_guest_debug_arch {
#define KVM_SYNC_GSCB (1UL << 9) #define KVM_SYNC_GSCB (1UL << 9)
#define KVM_SYNC_BPBC (1UL << 10) #define KVM_SYNC_BPBC (1UL << 10)
#define KVM_SYNC_ETOKEN (1UL << 11) #define KVM_SYNC_ETOKEN (1UL << 11)
#define KVM_SYNC_DIAG318 (1UL << 12)
#define KVM_SYNC_S390_VALID_FIELDS \ #define KVM_SYNC_S390_VALID_FIELDS \
(KVM_SYNC_PREFIX | KVM_SYNC_GPRS | KVM_SYNC_ACRS | KVM_SYNC_CRS | \ (KVM_SYNC_PREFIX | KVM_SYNC_GPRS | KVM_SYNC_ACRS | KVM_SYNC_CRS | \
KVM_SYNC_ARCH0 | KVM_SYNC_PFAULT | KVM_SYNC_VRS | KVM_SYNC_RICCB | \ KVM_SYNC_ARCH0 | KVM_SYNC_PFAULT | KVM_SYNC_VRS | KVM_SYNC_RICCB | \
KVM_SYNC_FPRS | KVM_SYNC_GSCB | KVM_SYNC_BPBC | KVM_SYNC_ETOKEN) KVM_SYNC_FPRS | KVM_SYNC_GSCB | KVM_SYNC_BPBC | KVM_SYNC_ETOKEN | \
KVM_SYNC_DIAG318)
/* length and alignment of the sdnx as a power of two */ /* length and alignment of the sdnx as a power of two */
#define SDNXC 8 #define SDNXC 8
...@@ -264,7 +266,8 @@ struct kvm_sync_regs { ...@@ -264,7 +266,8 @@ struct kvm_sync_regs {
__u8 reserved2 : 7; __u8 reserved2 : 7;
__u8 padding1[51]; /* riccb needs to be 64byte aligned */ __u8 padding1[51]; /* riccb needs to be 64byte aligned */
__u8 riccb[64]; /* runtime instrumentation controls block */ __u8 riccb[64]; /* runtime instrumentation controls block */
__u8 padding2[192]; /* sdnx needs to be 256byte aligned */ __u64 diag318; /* diagnose 0x318 info */
__u8 padding2[184]; /* sdnx needs to be 256byte aligned */
union { union {
__u8 sdnx[SDNXL]; /* state description annex */ __u8 sdnx[SDNXL]; /* state description annex */
struct { struct {
......
...@@ -8,7 +8,7 @@ endif ...@@ -8,7 +8,7 @@ endif
feature_check = $(eval $(feature_check_code)) feature_check = $(eval $(feature_check_code))
define feature_check_code define feature_check_code
feature-$(1) := $(shell $(MAKE) OUTPUT=$(OUTPUT_FEATURES) CC=$(CC) CXX=$(CXX) CFLAGS="$(EXTRA_CFLAGS) $(FEATURE_CHECK_CFLAGS-$(1))" CXXFLAGS="$(EXTRA_CXXFLAGS) $(FEATURE_CHECK_CXXFLAGS-$(1))" LDFLAGS="$(LDFLAGS) $(FEATURE_CHECK_LDFLAGS-$(1))" -C $(feature_dir) $(OUTPUT_FEATURES)test-$1.bin >/dev/null 2>/dev/null && echo 1 || echo 0) feature-$(1) := $(shell $(MAKE) OUTPUT=$(OUTPUT_FEATURES) CC="$(CC)" CXX="$(CXX)" CFLAGS="$(EXTRA_CFLAGS) $(FEATURE_CHECK_CFLAGS-$(1))" CXXFLAGS="$(EXTRA_CXXFLAGS) $(FEATURE_CHECK_CXXFLAGS-$(1))" LDFLAGS="$(LDFLAGS) $(FEATURE_CHECK_LDFLAGS-$(1))" -C $(feature_dir) $(OUTPUT_FEATURES)test-$1.bin >/dev/null 2>/dev/null && echo 1 || echo 0)
endef endef
feature_set = $(eval $(feature_set_code)) feature_set = $(eval $(feature_set_code))
...@@ -98,7 +98,8 @@ FEATURE_TESTS_EXTRA := \ ...@@ -98,7 +98,8 @@ FEATURE_TESTS_EXTRA := \
llvm-version \ llvm-version \
clang \ clang \
libbpf \ libbpf \
libpfm4 libpfm4 \
libdebuginfod
FEATURE_TESTS ?= $(FEATURE_TESTS_BASIC) FEATURE_TESTS ?= $(FEATURE_TESTS_BASIC)
......
...@@ -26,6 +26,7 @@ FILES= \ ...@@ -26,6 +26,7 @@ FILES= \
test-libelf-gelf_getnote.bin \ test-libelf-gelf_getnote.bin \
test-libelf-getshdrstrndx.bin \ test-libelf-getshdrstrndx.bin \
test-libelf-mmap.bin \ test-libelf-mmap.bin \
test-libdebuginfod.bin \
test-libnuma.bin \ test-libnuma.bin \
test-numa_num_possible_cpus.bin \ test-numa_num_possible_cpus.bin \
test-libperl.bin \ test-libperl.bin \
...@@ -157,6 +158,9 @@ $(OUTPUT)test-libelf-gelf_getnote.bin: ...@@ -157,6 +158,9 @@ $(OUTPUT)test-libelf-gelf_getnote.bin:
$(OUTPUT)test-libelf-getshdrstrndx.bin: $(OUTPUT)test-libelf-getshdrstrndx.bin:
$(BUILD) -lelf $(BUILD) -lelf
$(OUTPUT)test-libdebuginfod.bin:
$(BUILD) -ldebuginfod
$(OUTPUT)test-libnuma.bin: $(OUTPUT)test-libnuma.bin:
$(BUILD) -lnuma $(BUILD) -lnuma
......
// SPDX-License-Identifier: GPL-2.0
#include <elfutils/debuginfod.h>
int main(void)
{
debuginfod_client* c = debuginfod_begin();
return (long)c;
}
...@@ -289,6 +289,7 @@ struct kvm_run { ...@@ -289,6 +289,7 @@ struct kvm_run {
/* KVM_EXIT_FAIL_ENTRY */ /* KVM_EXIT_FAIL_ENTRY */
struct { struct {
__u64 hardware_entry_failure_reason; __u64 hardware_entry_failure_reason;
__u32 cpu;
} fail_entry; } fail_entry;
/* KVM_EXIT_EXCEPTION */ /* KVM_EXIT_EXCEPTION */
struct { struct {
...@@ -1031,6 +1032,9 @@ struct kvm_ppc_resize_hpt { ...@@ -1031,6 +1032,9 @@ struct kvm_ppc_resize_hpt {
#define KVM_CAP_PPC_SECURE_GUEST 181 #define KVM_CAP_PPC_SECURE_GUEST 181
#define KVM_CAP_HALT_POLL 182 #define KVM_CAP_HALT_POLL 182
#define KVM_CAP_ASYNC_PF_INT 183 #define KVM_CAP_ASYNC_PF_INT 183
#define KVM_CAP_LAST_CPU 184
#define KVM_CAP_SMALLER_MAXPHYADDR 185
#define KVM_CAP_S390_DIAG318 186
#ifdef KVM_CAP_IRQ_ROUTING #ifdef KVM_CAP_IRQ_ROUTING
......
...@@ -91,6 +91,8 @@ ...@@ -91,6 +91,8 @@
/* Use message type V2 */ /* Use message type V2 */
#define VHOST_BACKEND_F_IOTLB_MSG_V2 0x1 #define VHOST_BACKEND_F_IOTLB_MSG_V2 0x1
/* IOTLB can accept batching hints */
#define VHOST_BACKEND_F_IOTLB_BATCH 0x2
#define VHOST_SET_BACKEND_FEATURES _IOW(VHOST_VIRTIO, 0x25, __u64) #define VHOST_SET_BACKEND_FEATURES _IOW(VHOST_VIRTIO, 0x25, __u64)
#define VHOST_GET_BACKEND_FEATURES _IOR(VHOST_VIRTIO, 0x26, __u64) #define VHOST_GET_BACKEND_FEATURES _IOR(VHOST_VIRTIO, 0x26, __u64)
......
...@@ -7,13 +7,13 @@ libperf-counting - counting interface ...@@ -7,13 +7,13 @@ libperf-counting - counting interface
DESCRIPTION DESCRIPTION
----------- -----------
The counting interface provides API to meassure and get count for specific perf events. The counting interface provides API to measure and get count for specific perf events.
The following test tries to explain count on `counting.c` example. The following test tries to explain count on `counting.c` example.
It is by no means complete guide to counting, but shows libperf basic API for counting. It is by no means complete guide to counting, but shows libperf basic API for counting.
The `counting.c` comes with libbperf package and can be compiled and run like: The `counting.c` comes with libperf package and can be compiled and run like:
[source,bash] [source,bash]
-- --
...@@ -26,7 +26,8 @@ count 176242, enabled 176242, run 176242 ...@@ -26,7 +26,8 @@ count 176242, enabled 176242, run 176242
It requires root access, because of the `PERF_COUNT_SW_CPU_CLOCK` event, It requires root access, because of the `PERF_COUNT_SW_CPU_CLOCK` event,
which is available only for root. which is available only for root.
The `counting.c` example monitors two events on the current process and displays their count, in a nutshel it: The `counting.c` example monitors two events on the current process and displays
their count, in a nutshell it:
* creates events * creates events
* adds them to the event list * adds them to the event list
...@@ -152,7 +153,7 @@ Configure event list with the thread map and open events: ...@@ -152,7 +153,7 @@ Configure event list with the thread map and open events:
-- --
Both events are created as disabled (note the `disabled = 1` assignment above), Both events are created as disabled (note the `disabled = 1` assignment above),
so we need to enable the whole list explicitely (both events). so we need to enable the whole list explicitly (both events).
From this moment events are counting and we can do our workload. From this moment events are counting and we can do our workload.
...@@ -167,7 +168,8 @@ When we are done we disable the events list. ...@@ -167,7 +168,8 @@ When we are done we disable the events list.
79 perf_evlist__disable(evlist); 79 perf_evlist__disable(evlist);
-- --
Now we need to get the counts from events, following code iterates throught the events list and read counts: Now we need to get the counts from events, following code iterates through the
events list and read counts:
[source,c] [source,c]
-- --
...@@ -178,7 +180,7 @@ Now we need to get the counts from events, following code iterates throught the ...@@ -178,7 +180,7 @@ Now we need to get the counts from events, following code iterates throught the
85 } 85 }
-- --
And finaly cleanup. And finally cleanup.
We close the whole events list (both events) and remove it together with the threads map: We close the whole events list (both events) and remove it together with the threads map:
......
...@@ -8,13 +8,13 @@ libperf-sampling - sampling interface ...@@ -8,13 +8,13 @@ libperf-sampling - sampling interface
DESCRIPTION DESCRIPTION
----------- -----------
The sampling interface provides API to meassure and get count for specific perf events. The sampling interface provides API to measure and get count for specific perf events.
The following test tries to explain count on `sampling.c` example. The following test tries to explain count on `sampling.c` example.
It is by no means complete guide to sampling, but shows libperf basic API for sampling. It is by no means complete guide to sampling, but shows libperf basic API for sampling.
The `sampling.c` comes with libbperf package and can be compiled and run like: The `sampling.c` comes with libperf package and can be compiled and run like:
[source,bash] [source,bash]
-- --
...@@ -33,7 +33,8 @@ cpu 0, pid 4465, tid 4470, ip 7f84fe0ebebf, period 176 ...@@ -33,7 +33,8 @@ cpu 0, pid 4465, tid 4470, ip 7f84fe0ebebf, period 176
It requires root access, because it uses hardware cycles event. It requires root access, because it uses hardware cycles event.
The `sampling.c` example profiles/samples all CPUs with hardware cycles, in a nutshel it: The `sampling.c` example profiles/samples all CPUs with hardware cycles, in a
nutshell it:
- creates events - creates events
- adds them to the event list - adds them to the event list
...@@ -90,7 +91,7 @@ Once the setup is complete we start by defining cycles event using the `struct p ...@@ -90,7 +91,7 @@ Once the setup is complete we start by defining cycles event using the `struct p
36 }; 36 };
-- --
Next step is to prepare cpus map. Next step is to prepare CPUs map.
In this case we will monitor all the available CPUs: In this case we will monitor all the available CPUs:
...@@ -152,7 +153,7 @@ Once the events list is open, we can create memory maps AKA perf ring buffers: ...@@ -152,7 +153,7 @@ Once the events list is open, we can create memory maps AKA perf ring buffers:
-- --
The event is created as disabled (note the `disabled = 1` assignment above), The event is created as disabled (note the `disabled = 1` assignment above),
so we need to enable the events list explicitely. so we need to enable the events list explicitly.
From this moment the cycles event is sampling. From this moment the cycles event is sampling.
...@@ -212,7 +213,7 @@ Each sample needs to get parsed: ...@@ -212,7 +213,7 @@ Each sample needs to get parsed:
106 cpu, pid, tid, ip, period); 106 cpu, pid, tid, ip, period);
-- --
And finaly cleanup. And finally cleanup.
We close the whole events list (both events) and remove it together with the threads map: We close the whole events list (both events) and remove it together with the threads map:
......
...@@ -29,7 +29,7 @@ SYNOPSIS ...@@ -29,7 +29,7 @@ SYNOPSIS
void libperf_init(libperf_print_fn_t fn); void libperf_init(libperf_print_fn_t fn);
-- --
*API to handle cpu maps:* *API to handle CPU maps:*
[source,c] [source,c]
-- --
...@@ -217,7 +217,7 @@ Following objects are key to the libperf interface: ...@@ -217,7 +217,7 @@ Following objects are key to the libperf interface:
[horizontal] [horizontal]
struct perf_cpu_map:: Provides a cpu list abstraction. struct perf_cpu_map:: Provides a CPU list abstraction.
struct perf_thread_map:: Provides a thread list abstraction. struct perf_thread_map:: Provides a thread list abstraction.
......
...@@ -614,8 +614,9 @@ trace.*:: ...@@ -614,8 +614,9 @@ trace.*::
ftrace.*:: ftrace.*::
ftrace.tracer:: ftrace.tracer::
Can be used to select the default tracer. Possible values are Can be used to select the default tracer when neither -G nor
'function' and 'function_graph'. -F option is not specified. Possible values are 'function' and
'function_graph'.
llvm.*:: llvm.*::
llvm.clang-path:: llvm.clang-path::
......
...@@ -24,16 +24,28 @@ OPTIONS ...@@ -24,16 +24,28 @@ OPTIONS
-t:: -t::
--tracer=:: --tracer=::
Tracer to use: function_graph or function. Tracer to use when neither -G nor -F option is not
specified: function_graph or function.
-v:: -v::
--verbose=:: --verbose=::
Verbosity level. Verbosity level.
-F::
--funcs::
List all available functions to trace.
-p:: -p::
--pid=:: --pid=::
Trace on existing process id (comma separated list). Trace on existing process id (comma separated list).
--tid=::
Trace on existing thread id (comma separated list).
-D::
--delay::
Time (ms) to wait before starting tracing after program start.
-a:: -a::
--all-cpus:: --all-cpus::
Force system-wide collection. Scripts run without a <command> Force system-wide collection. Scripts run without a <command>
...@@ -48,39 +60,58 @@ OPTIONS ...@@ -48,39 +60,58 @@ OPTIONS
Ranges of CPUs are specified with -: 0-2. Ranges of CPUs are specified with -: 0-2.
Default is to trace on all online CPUs. Default is to trace on all online CPUs.
-m::
--buffer-size::
Set the size of per-cpu tracing buffer, <size> is expected to
be a number with appended unit character - B/K/M/G.
--inherit::
Trace children processes spawned by our target.
-T:: -T::
--trace-funcs=:: --trace-funcs=::
Only trace functions given by the argument. Multiple functions Select function tracer and set function filter on the given
can be given by using this option more than once. The function function (or a glob pattern). Multiple functions can be given
argument also can be a glob pattern. It will be passed to by using this option more than once. The function argument also
'set_ftrace_filter' in tracefs. can be a glob pattern. It will be passed to 'set_ftrace_filter'
in tracefs.
-N:: -N::
--notrace-funcs=:: --notrace-funcs=::
Do not trace functions given by the argument. Like -T option, Select function tracer and do not trace functions given by the
this can be used more than once to specify multiple functions argument. Like -T option, this can be used more than once to
(or glob patterns). It will be passed to 'set_ftrace_notrace' specify multiple functions (or glob patterns). It will be
in tracefs. passed to 'set_ftrace_notrace' in tracefs.
--func-opts::
List of options allowed to set:
call-graph - Display kernel stack trace for function tracer.
irq-info - Display irq context info for function tracer.
-G:: -G::
--graph-funcs=:: --graph-funcs=::
Set graph filter on the given function (or a glob pattern). Select function_graph tracer and set graph filter on the given
This is useful for the function_graph tracer only and enables function (or a glob pattern). This is useful to trace for
tracing for functions executed from the given function. functions executed from the given function. This can be used more
This can be used more than once to specify multiple functions. than once to specify multiple functions. It will be passed to
It will be passed to 'set_graph_function' in tracefs. 'set_graph_function' in tracefs.
-g:: -g::
--nograph-funcs=:: --nograph-funcs=::
Set graph notrace filter on the given function (or a glob pattern). Select function_graph tracer and set graph notrace filter on the
Like -G option, this is useful for the function_graph tracer only given function (or a glob pattern). Like -G option, this is useful
and disables tracing for function executed from the given function. for the function_graph tracer only and disables tracing for function
This can be used more than once to specify multiple functions. executed from the given function. This can be used more than once to
It will be passed to 'set_graph_notrace' in tracefs. specify multiple functions. It will be passed to 'set_graph_notrace'
in tracefs.
-D:: --graph-opts::
--graph-depth=:: List of options allowed to set:
Set max depth for function graph tracer to follow nosleep-time - Measure on-CPU time only for function_graph tracer.
noirqs - Ignore functions that happen inside interrupt.
verbose - Show process names, PIDs, timestamps, etc.
thresh=<n> - Setup trace duration threshold in microseconds.
depth=<n> - Set max depth for function graph tracer to follow.
SEE ALSO SEE ALSO
-------- --------
......
...@@ -501,6 +501,14 @@ ifndef NO_LIBELF ...@@ -501,6 +501,14 @@ ifndef NO_LIBELF
CFLAGS += -DHAVE_ELF_GETSHDRSTRNDX_SUPPORT CFLAGS += -DHAVE_ELF_GETSHDRSTRNDX_SUPPORT
endif endif
ifndef NO_LIBDEBUGINFOD
$(call feature_check,libdebuginfod)
ifeq ($(feature-libdebuginfod), 1)
CFLAGS += -DHAVE_DEBUGINFOD_SUPPORT
EXTLIBS += -ldebuginfod
endif
endif
ifndef NO_DWARF ifndef NO_DWARF
ifeq ($(origin PERF_HAVE_DWARF_REGS), undefined) ifeq ($(origin PERF_HAVE_DWARF_REGS), undefined)
msg := $(warning DWARF register mappings have not been defined for architecture $(SRCARCH), DWARF support disabled); msg := $(warning DWARF register mappings have not been defined for architecture $(SRCARCH), DWARF support disabled);
......
...@@ -124,6 +124,8 @@ include ../scripts/utilities.mak ...@@ -124,6 +124,8 @@ include ../scripts/utilities.mak
# #
# Define LIBPFM4 to enable libpfm4 events extension. # Define LIBPFM4 to enable libpfm4 events extension.
# #
# Define NO_LIBDEBUGINFOD if you do not want support debuginfod
#
# As per kernel Makefile, avoid funny character set dependencies # As per kernel Makefile, avoid funny character set dependencies
unexport LC_ALL unexport LC_ALL
...@@ -418,6 +420,7 @@ export INSTALL SHELL_PATH ...@@ -418,6 +420,7 @@ export INSTALL SHELL_PATH
SHELL = $(SHELL_PATH) SHELL = $(SHELL_PATH)
beauty_linux_dir := $(srctree)/tools/perf/trace/beauty/include/linux/
linux_uapi_dir := $(srctree)/tools/include/uapi/linux linux_uapi_dir := $(srctree)/tools/include/uapi/linux
asm_generic_uapi_dir := $(srctree)/tools/include/uapi/asm-generic asm_generic_uapi_dir := $(srctree)/tools/include/uapi/asm-generic
arch_asm_uapi_dir := $(srctree)/tools/arch/$(SRCARCH)/include/uapi/asm/ arch_asm_uapi_dir := $(srctree)/tools/arch/$(SRCARCH)/include/uapi/asm/
...@@ -501,6 +504,12 @@ socket_ipproto_tbl := $(srctree)/tools/perf/trace/beauty/socket_ipproto.sh ...@@ -501,6 +504,12 @@ socket_ipproto_tbl := $(srctree)/tools/perf/trace/beauty/socket_ipproto.sh
$(socket_ipproto_array): $(linux_uapi_dir)/in.h $(socket_ipproto_tbl) $(socket_ipproto_array): $(linux_uapi_dir)/in.h $(socket_ipproto_tbl)
$(Q)$(SHELL) '$(socket_ipproto_tbl)' $(linux_uapi_dir) > $@ $(Q)$(SHELL) '$(socket_ipproto_tbl)' $(linux_uapi_dir) > $@
socket_arrays := $(beauty_outdir)/socket_arrays.c
socket_tbl := $(srctree)/tools/perf/trace/beauty/socket.sh
$(socket_arrays): $(beauty_linux_dir)/socket.h $(socket_tbl)
$(Q)$(SHELL) '$(socket_tbl)' $(beauty_linux_dir) > $@
vhost_virtio_ioctl_array := $(beauty_ioctl_outdir)/vhost_virtio_ioctl_array.c vhost_virtio_ioctl_array := $(beauty_ioctl_outdir)/vhost_virtio_ioctl_array.c
vhost_virtio_hdr_dir := $(srctree)/tools/include/uapi/linux vhost_virtio_hdr_dir := $(srctree)/tools/include/uapi/linux
vhost_virtio_ioctl_tbl := $(srctree)/tools/perf/trace/beauty/vhost_virtio_ioctl.sh vhost_virtio_ioctl_tbl := $(srctree)/tools/perf/trace/beauty/vhost_virtio_ioctl.sh
...@@ -697,6 +706,7 @@ prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h archheaders $(drm_ioc ...@@ -697,6 +706,7 @@ prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h archheaders $(drm_ioc
$(kcmp_type_array) \ $(kcmp_type_array) \
$(kvm_ioctl_array) \ $(kvm_ioctl_array) \
$(socket_ipproto_array) \ $(socket_ipproto_array) \
$(socket_arrays) \
$(vhost_virtio_ioctl_array) \ $(vhost_virtio_ioctl_array) \
$(madvise_behavior_array) \ $(madvise_behavior_array) \
$(mmap_flags_array) \ $(mmap_flags_array) \
...@@ -1006,6 +1016,7 @@ clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clea ...@@ -1006,6 +1016,7 @@ clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clea
$(OUTPUT)$(kvm_ioctl_array) \ $(OUTPUT)$(kvm_ioctl_array) \
$(OUTPUT)$(kcmp_type_array) \ $(OUTPUT)$(kcmp_type_array) \
$(OUTPUT)$(socket_ipproto_array) \ $(OUTPUT)$(socket_ipproto_array) \
$(OUTPUT)$(socket_arrays) \
$(OUTPUT)$(vhost_virtio_ioctl_array) \ $(OUTPUT)$(vhost_virtio_ioctl_array) \
$(OUTPUT)$(perf_ioctl_array) \ $(OUTPUT)$(perf_ioctl_array) \
$(OUTPUT)$(prctl_option_array) \ $(OUTPUT)$(prctl_option_array) \
......
...@@ -17,9 +17,9 @@ static unsigned int inner_iterations = 100000; ...@@ -17,9 +17,9 @@ static unsigned int inner_iterations = 100000;
static const struct option options[] = { static const struct option options[] = {
OPT_UINTEGER('i', "outer-iterations", &outer_iterations, OPT_UINTEGER('i', "outer-iterations", &outer_iterations,
"Number of outerer iterations used"), "Number of outer iterations used"),
OPT_UINTEGER('j', "inner-iterations", &inner_iterations, OPT_UINTEGER('j', "inner-iterations", &inner_iterations,
"Number of outerer iterations used"), "Number of inner iterations used"),
OPT_END() OPT_END()
}; };
......
...@@ -223,12 +223,8 @@ static int bench_mem_common(int argc, const char **argv, struct bench_mem_info * ...@@ -223,12 +223,8 @@ static int bench_mem_common(int argc, const char **argv, struct bench_mem_info *
return 0; return 0;
} }
static u64 do_memcpy_cycles(const struct function *r, size_t size, void *src, void *dst) static void memcpy_prefault(memcpy_t fn, size_t size, void *src, void *dst)
{ {
u64 cycle_start = 0ULL, cycle_end = 0ULL;
memcpy_t fn = r->fn.memcpy;
int i;
/* Make sure to always prefault zero pages even if MMAP_THRESH is crossed: */ /* Make sure to always prefault zero pages even if MMAP_THRESH is crossed: */
memset(src, 0, size); memset(src, 0, size);
...@@ -237,6 +233,15 @@ static u64 do_memcpy_cycles(const struct function *r, size_t size, void *src, vo ...@@ -237,6 +233,15 @@ static u64 do_memcpy_cycles(const struct function *r, size_t size, void *src, vo
* to not measure page fault overhead: * to not measure page fault overhead:
*/ */
fn(dst, src, size); fn(dst, src, size);
}
static u64 do_memcpy_cycles(const struct function *r, size_t size, void *src, void *dst)
{
u64 cycle_start = 0ULL, cycle_end = 0ULL;
memcpy_t fn = r->fn.memcpy;
int i;
memcpy_prefault(fn, size, src, dst);
cycle_start = get_cycles(); cycle_start = get_cycles();
for (i = 0; i < nr_loops; ++i) for (i = 0; i < nr_loops; ++i)
...@@ -252,11 +257,7 @@ static double do_memcpy_gettimeofday(const struct function *r, size_t size, void ...@@ -252,11 +257,7 @@ static double do_memcpy_gettimeofday(const struct function *r, size_t size, void
memcpy_t fn = r->fn.memcpy; memcpy_t fn = r->fn.memcpy;
int i; int i;
/* memcpy_prefault(fn, size, src, dst);
* We prefault the freshly allocated memory range here,
* to not measure page fault overhead:
*/
fn(dst, src, size);
BUG_ON(gettimeofday(&tv_start, NULL)); BUG_ON(gettimeofday(&tv_start, NULL));
for (i = 0; i < nr_loops; ++i) for (i = 0; i < nr_loops; ++i)
......
...@@ -247,17 +247,22 @@ static int is_node_present(int node) ...@@ -247,17 +247,22 @@ static int is_node_present(int node)
*/ */
static bool node_has_cpus(int node) static bool node_has_cpus(int node)
{ {
struct bitmask *cpu = numa_allocate_cpumask(); struct bitmask *cpumask = numa_allocate_cpumask();
unsigned int i; bool ret = false; /* fall back to nocpus */
int cpu;
if (cpu && !numa_node_to_cpus(node, cpu)) { BUG_ON(!cpumask);
for (i = 0; i < cpu->size; i++) { if (!numa_node_to_cpus(node, cpumask)) {
if (numa_bitmask_isbitset(cpu, i)) for (cpu = 0; cpu < (int)cpumask->size; cpu++) {
return true; if (numa_bitmask_isbitset(cpumask, cpu)) {
ret = true;
break;
}
} }
} }
numa_free_cpumask(cpumask);
return false; /* lets fall back to nocpus safely */ return ret;
} }
static cpu_set_t bind_to_cpu(int target_cpu) static cpu_set_t bind_to_cpu(int target_cpu)
...@@ -288,14 +293,10 @@ static cpu_set_t bind_to_cpu(int target_cpu) ...@@ -288,14 +293,10 @@ static cpu_set_t bind_to_cpu(int target_cpu)
static cpu_set_t bind_to_node(int target_node) static cpu_set_t bind_to_node(int target_node)
{ {
int cpus_per_node = g->p.nr_cpus / nr_numa_nodes();
cpu_set_t orig_mask, mask; cpu_set_t orig_mask, mask;
int cpu; int cpu;
int ret; int ret;
BUG_ON(cpus_per_node * nr_numa_nodes() != g->p.nr_cpus);
BUG_ON(!cpus_per_node);
ret = sched_getaffinity(0, sizeof(orig_mask), &orig_mask); ret = sched_getaffinity(0, sizeof(orig_mask), &orig_mask);
BUG_ON(ret); BUG_ON(ret);
...@@ -305,13 +306,16 @@ static cpu_set_t bind_to_node(int target_node) ...@@ -305,13 +306,16 @@ static cpu_set_t bind_to_node(int target_node)
for (cpu = 0; cpu < g->p.nr_cpus; cpu++) for (cpu = 0; cpu < g->p.nr_cpus; cpu++)
CPU_SET(cpu, &mask); CPU_SET(cpu, &mask);
} else { } else {
int cpu_start = (target_node + 0) * cpus_per_node; struct bitmask *cpumask = numa_allocate_cpumask();
int cpu_stop = (target_node + 1) * cpus_per_node;
BUG_ON(cpu_stop > g->p.nr_cpus); BUG_ON(!cpumask);
if (!numa_node_to_cpus(target_node, cpumask)) {
for (cpu = cpu_start; cpu < cpu_stop; cpu++) for (cpu = 0; cpu < (int)cpumask->size; cpu++) {
CPU_SET(cpu, &mask); if (numa_bitmask_isbitset(cpumask, cpu))
CPU_SET(cpu, &mask);
}
}
numa_free_cpumask(cpumask);
} }
ret = sched_setaffinity(0, sizeof(mask), &mask); ret = sched_setaffinity(0, sizeof(mask), &mask);
...@@ -729,8 +733,6 @@ static int parse_nodes_opt(const struct option *opt __maybe_unused, ...@@ -729,8 +733,6 @@ static int parse_nodes_opt(const struct option *opt __maybe_unused,
return -1; return -1;
return parse_node_list(arg); return parse_node_list(arg);
return 0;
} }
#define BIT(x) (1ul << x) #define BIT(x) (1ul << x)
...@@ -813,12 +815,12 @@ static u64 do_work(u8 *__data, long bytes, int nr, int nr_max, int loop, u64 val ...@@ -813,12 +815,12 @@ static u64 do_work(u8 *__data, long bytes, int nr, int nr_max, int loop, u64 val
} }
} }
} else if (!g->p.data_backwards || (nr + loop) & 1) { } else if (!g->p.data_backwards || (nr + loop) & 1) {
/* Process data forwards: */
d0 = data + off; d0 = data + off;
d = data + off + 1; d = data + off + 1;
d1 = data + words; d1 = data + words;
/* Process data forwards: */
for (;;) { for (;;) {
if (unlikely(d >= d1)) if (unlikely(d >= d1))
d = data; d = data;
...@@ -836,7 +838,6 @@ static u64 do_work(u8 *__data, long bytes, int nr, int nr_max, int loop, u64 val ...@@ -836,7 +838,6 @@ static u64 do_work(u8 *__data, long bytes, int nr, int nr_max, int loop, u64 val
d = data + off - 1; d = data + off - 1;
d1 = data + words; d1 = data + words;
/* Process data forwards: */
for (;;) { for (;;) {
if (unlikely(d < data)) if (unlikely(d < data))
d = data + words-1; d = data + words-1;
...@@ -1733,12 +1734,12 @@ static int run_bench_numa(const char *name, const char **argv) ...@@ -1733,12 +1734,12 @@ static int run_bench_numa(const char *name, const char **argv)
*/ */
static const char *tests[][MAX_ARGS] = { static const char *tests[][MAX_ARGS] = {
/* Basic single-stream NUMA bandwidth measurements: */ /* Basic single-stream NUMA bandwidth measurements: */
{ "RAM-bw-local,", "mem", "-p", "1", "-t", "1", "-P", "1024", { "RAM-bw-local,", "mem", "-p", "1", "-t", "1", "-P", "1024",
"-C" , "0", "-M", "0", OPT_BW_RAM }, "-C" , "0", "-M", "0", OPT_BW_RAM },
{ "RAM-bw-local-NOTHP,", { "RAM-bw-local-NOTHP,",
"mem", "-p", "1", "-t", "1", "-P", "1024", "mem", "-p", "1", "-t", "1", "-P", "1024",
"-C" , "0", "-M", "0", OPT_BW_RAM_NOTHP }, "-C" , "0", "-M", "0", OPT_BW_RAM_NOTHP },
{ "RAM-bw-remote,", "mem", "-p", "1", "-t", "1", "-P", "1024", { "RAM-bw-remote,", "mem", "-p", "1", "-t", "1", "-P", "1024",
"-C" , "0", "-M", "1", OPT_BW_RAM }, "-C" , "0", "-M", "1", OPT_BW_RAM },
/* 2-stream NUMA bandwidth measurements: */ /* 2-stream NUMA bandwidth measurements: */
...@@ -1755,7 +1756,7 @@ static const char *tests[][MAX_ARGS] = { ...@@ -1755,7 +1756,7 @@ static const char *tests[][MAX_ARGS] = {
{ " 1x3-convergence,", "mem", "-p", "1", "-t", "3", "-P", "512", OPT_CONV }, { " 1x3-convergence,", "mem", "-p", "1", "-t", "3", "-P", "512", OPT_CONV },
{ " 1x4-convergence,", "mem", "-p", "1", "-t", "4", "-P", "512", OPT_CONV }, { " 1x4-convergence,", "mem", "-p", "1", "-t", "4", "-P", "512", OPT_CONV },
{ " 1x6-convergence,", "mem", "-p", "1", "-t", "6", "-P", "1020", OPT_CONV }, { " 1x6-convergence,", "mem", "-p", "1", "-t", "6", "-P", "1020", OPT_CONV },
{ " 2x3-convergence,", "mem", "-p", "3", "-t", "3", "-P", "1020", OPT_CONV }, { " 2x3-convergence,", "mem", "-p", "2", "-t", "3", "-P", "1020", OPT_CONV },
{ " 3x3-convergence,", "mem", "-p", "3", "-t", "3", "-P", "1020", OPT_CONV }, { " 3x3-convergence,", "mem", "-p", "3", "-t", "3", "-P", "1020", OPT_CONV },
{ " 4x4-convergence,", "mem", "-p", "4", "-t", "4", "-P", "512", OPT_CONV }, { " 4x4-convergence,", "mem", "-p", "4", "-t", "4", "-P", "512", OPT_CONV },
{ " 4x4-convergence-NOTHP,", { " 4x4-convergence-NOTHP,",
...@@ -1780,24 +1781,24 @@ static const char *tests[][MAX_ARGS] = { ...@@ -1780,24 +1781,24 @@ static const char *tests[][MAX_ARGS] = {
"mem", "-p", "8", "-t", "1", "-P", " 512", OPT_BW_NOTHP }, "mem", "-p", "8", "-t", "1", "-P", " 512", OPT_BW_NOTHP },
{ "16x1-bw-process,", "mem", "-p", "16", "-t", "1", "-P", "256", OPT_BW }, { "16x1-bw-process,", "mem", "-p", "16", "-t", "1", "-P", "256", OPT_BW },
{ " 4x1-bw-thread,", "mem", "-p", "1", "-t", "4", "-T", "256", OPT_BW }, { " 1x4-bw-thread,", "mem", "-p", "1", "-t", "4", "-T", "256", OPT_BW },
{ " 8x1-bw-thread,", "mem", "-p", "1", "-t", "8", "-T", "256", OPT_BW }, { " 1x8-bw-thread,", "mem", "-p", "1", "-t", "8", "-T", "256", OPT_BW },
{ "16x1-bw-thread,", "mem", "-p", "1", "-t", "16", "-T", "128", OPT_BW }, { "1x16-bw-thread,", "mem", "-p", "1", "-t", "16", "-T", "128", OPT_BW },
{ "32x1-bw-thread,", "mem", "-p", "1", "-t", "32", "-T", "64", OPT_BW }, { "1x32-bw-thread,", "mem", "-p", "1", "-t", "32", "-T", "64", OPT_BW },
{ " 2x3-bw-thread,", "mem", "-p", "2", "-t", "3", "-P", "512", OPT_BW }, { " 2x3-bw-process,", "mem", "-p", "2", "-t", "3", "-P", "512", OPT_BW },
{ " 4x4-bw-thread,", "mem", "-p", "4", "-t", "4", "-P", "512", OPT_BW }, { " 4x4-bw-process,", "mem", "-p", "4", "-t", "4", "-P", "512", OPT_BW },
{ " 4x6-bw-thread,", "mem", "-p", "4", "-t", "6", "-P", "512", OPT_BW }, { " 4x6-bw-process,", "mem", "-p", "4", "-t", "6", "-P", "512", OPT_BW },
{ " 4x8-bw-thread,", "mem", "-p", "4", "-t", "8", "-P", "512", OPT_BW }, { " 4x8-bw-process,", "mem", "-p", "4", "-t", "8", "-P", "512", OPT_BW },
{ " 4x8-bw-thread-NOTHP,", { " 4x8-bw-process-NOTHP,",
"mem", "-p", "4", "-t", "8", "-P", "512", OPT_BW_NOTHP }, "mem", "-p", "4", "-t", "8", "-P", "512", OPT_BW_NOTHP },
{ " 3x3-bw-thread,", "mem", "-p", "3", "-t", "3", "-P", "512", OPT_BW }, { " 3x3-bw-process,", "mem", "-p", "3", "-t", "3", "-P", "512", OPT_BW },
{ " 5x5-bw-thread,", "mem", "-p", "5", "-t", "5", "-P", "512", OPT_BW }, { " 5x5-bw-process,", "mem", "-p", "5", "-t", "5", "-P", "512", OPT_BW },
{ "2x16-bw-thread,", "mem", "-p", "2", "-t", "16", "-P", "512", OPT_BW }, { "2x16-bw-process,", "mem", "-p", "2", "-t", "16", "-P", "512", OPT_BW },
{ "1x32-bw-thread,", "mem", "-p", "1", "-t", "32", "-P", "2048", OPT_BW }, { "1x32-bw-process,", "mem", "-p", "1", "-t", "32", "-P", "2048", OPT_BW },
{ "numa02-bw,", "mem", "-p", "1", "-t", "32", "-T", "32", OPT_BW }, { "numa02-bw,", "mem", "-p", "1", "-t", "32", "-T", "32", OPT_BW },
{ "numa02-bw-NOTHP,", "mem", "-p", "1", "-t", "32", "-T", "32", OPT_BW_NOTHP }, { "numa02-bw-NOTHP,", "mem", "-p", "1", "-t", "32", "-T", "32", OPT_BW_NOTHP },
{ "numa01-bw-thread,", "mem", "-p", "2", "-t", "16", "-T", "192", OPT_BW }, { "numa01-bw-thread,", "mem", "-p", "2", "-t", "16", "-T", "192", OPT_BW },
{ "numa01-bw-thread-NOTHP,", { "numa01-bw-thread-NOTHP,",
......
This diff is collapsed.
...@@ -2398,6 +2398,15 @@ static void timehist_print_wakeup_event(struct perf_sched *sched, ...@@ -2398,6 +2398,15 @@ static void timehist_print_wakeup_event(struct perf_sched *sched,
printf("\n"); printf("\n");
} }
static int timehist_sched_wakeup_ignore(struct perf_tool *tool __maybe_unused,
union perf_event *event __maybe_unused,
struct evsel *evsel __maybe_unused,
struct perf_sample *sample __maybe_unused,
struct machine *machine __maybe_unused)
{
return 0;
}
static int timehist_sched_wakeup_event(struct perf_tool *tool, static int timehist_sched_wakeup_event(struct perf_tool *tool,
union perf_event *event __maybe_unused, union perf_event *event __maybe_unused,
struct evsel *evsel, struct evsel *evsel,
...@@ -2958,9 +2967,10 @@ static int timehist_check_attr(struct perf_sched *sched, ...@@ -2958,9 +2967,10 @@ static int timehist_check_attr(struct perf_sched *sched,
static int perf_sched__timehist(struct perf_sched *sched) static int perf_sched__timehist(struct perf_sched *sched)
{ {
const struct evsel_str_handler handlers[] = { struct evsel_str_handler handlers[] = {
{ "sched:sched_switch", timehist_sched_switch_event, }, { "sched:sched_switch", timehist_sched_switch_event, },
{ "sched:sched_wakeup", timehist_sched_wakeup_event, }, { "sched:sched_wakeup", timehist_sched_wakeup_event, },
{ "sched:sched_waking", timehist_sched_wakeup_event, },
{ "sched:sched_wakeup_new", timehist_sched_wakeup_event, }, { "sched:sched_wakeup_new", timehist_sched_wakeup_event, },
}; };
const struct evsel_str_handler migrate_handlers[] = { const struct evsel_str_handler migrate_handlers[] = {
...@@ -3018,6 +3028,11 @@ static int perf_sched__timehist(struct perf_sched *sched) ...@@ -3018,6 +3028,11 @@ static int perf_sched__timehist(struct perf_sched *sched)
setup_pager(); setup_pager();
/* prefer sched_waking if it is captured */
if (perf_evlist__find_tracepoint_by_name(session->evlist,
"sched:sched_waking"))
handlers[1].handler = timehist_sched_wakeup_ignore;
/* setup per-evsel handlers */ /* setup per-evsel handlers */
if (perf_session__set_tracepoints_handlers(session, handlers)) if (perf_session__set_tracepoints_handlers(session, handlers))
goto out; goto out;
...@@ -3330,12 +3345,16 @@ static int __cmd_record(int argc, const char **argv) ...@@ -3330,12 +3345,16 @@ static int __cmd_record(int argc, const char **argv)
"-e", "sched:sched_stat_iowait", "-e", "sched:sched_stat_iowait",
"-e", "sched:sched_stat_runtime", "-e", "sched:sched_stat_runtime",
"-e", "sched:sched_process_fork", "-e", "sched:sched_process_fork",
"-e", "sched:sched_wakeup",
"-e", "sched:sched_wakeup_new", "-e", "sched:sched_wakeup_new",
"-e", "sched:sched_migrate_task", "-e", "sched:sched_migrate_task",
}; };
struct tep_event *waking_event;
rec_argc = ARRAY_SIZE(record_args) + argc - 1; /*
* +2 for either "-e", "sched:sched_wakeup" or
* "-e", "sched:sched_waking"
*/
rec_argc = ARRAY_SIZE(record_args) + 2 + argc - 1;
rec_argv = calloc(rec_argc + 1, sizeof(char *)); rec_argv = calloc(rec_argc + 1, sizeof(char *));
if (rec_argv == NULL) if (rec_argv == NULL)
...@@ -3344,6 +3363,13 @@ static int __cmd_record(int argc, const char **argv) ...@@ -3344,6 +3363,13 @@ static int __cmd_record(int argc, const char **argv)
for (i = 0; i < ARRAY_SIZE(record_args); i++) for (i = 0; i < ARRAY_SIZE(record_args); i++)
rec_argv[i] = strdup(record_args[i]); rec_argv[i] = strdup(record_args[i]);
rec_argv[i++] = "-e";
waking_event = trace_event__tp_format("sched", "sched_waking");
if (!IS_ERR(waking_event))
rec_argv[i++] = strdup("sched:sched_waking");
else
rec_argv[i++] = strdup("sched:sched_wakeup");
for (j = 1; j < (unsigned int)argc; j++, i++) for (j = 1; j < (unsigned int)argc; j++, i++)
rec_argv[i] = argv[j]; rec_argv[i] = argv[j];
......
...@@ -128,6 +128,9 @@ check arch/x86/lib/insn.c '-I "^#include [\"<]\(../include/\)*asm/in ...@@ -128,6 +128,9 @@ check arch/x86/lib/insn.c '-I "^#include [\"<]\(../include/\)*asm/in
# diff non-symmetric files # diff non-symmetric files
check_2 tools/perf/arch/x86/entry/syscalls/syscall_64.tbl arch/x86/entry/syscalls/syscall_64.tbl check_2 tools/perf/arch/x86/entry/syscalls/syscall_64.tbl arch/x86/entry/syscalls/syscall_64.tbl
# These will require a beauty_check when we get some more like that
check_2 tools/perf/trace/beauty/include/linux/socket.h include/linux/socket.h
# check duplicated library files # check duplicated library files
check_2 tools/perf/util/hashmap.h tools/lib/bpf/hashmap.h check_2 tools/perf/util/hashmap.h tools/lib/bpf/hashmap.h
check_2 tools/perf/util/hashmap.c tools/lib/bpf/hashmap.c check_2 tools/perf/util/hashmap.c tools/lib/bpf/hashmap.c
......
...@@ -20,13 +20,13 @@ file=$(mktemp /tmp/temporary_file.XXXXX) ...@@ -20,13 +20,13 @@ file=$(mktemp /tmp/temporary_file.XXXXX)
record_open_file() { record_open_file() {
echo "Recording open file:" echo "Recording open file:"
perf record -o ${perfdata} -e probe:vfs_getname touch $file perf record -o ${perfdata} -e probe:vfs_getname\* touch $file
} }
perf_script_filenames() { perf_script_filenames() {
echo "Looking at perf.data file for vfs_getname records for the file we touched:" echo "Looking at perf.data file for vfs_getname records for the file we touched:"
perf script -i ${perfdata} | \ perf script -i ${perfdata} | \
egrep " +touch +[0-9]+ +\[[0-9]+\] +[0-9]+\.[0-9]+: +probe:vfs_getname: +\([[:xdigit:]]+\) +pathname=\"${file}\"" egrep " +touch +[0-9]+ +\[[0-9]+\] +[0-9]+\.[0-9]+: +probe:vfs_getname[_0-9]*: +\([[:xdigit:]]+\) +pathname=\"${file}\""
} }
add_probe_vfs_getname || skip_if_no_debuginfo add_probe_vfs_getname || skip_if_no_debuginfo
......
This diff is collapsed.
...@@ -7,14 +7,7 @@ ...@@ -7,14 +7,7 @@
#include <sys/un.h> #include <sys/un.h>
#include <arpa/inet.h> #include <arpa/inet.h>
static const char *socket_families[] = { #include "trace/beauty/generated/socket_arrays.c"
"UNSPEC", "LOCAL", "INET", "AX25", "IPX", "APPLETALK", "NETROM",
"BRIDGE", "ATMPVC", "X25", "INET6", "ROSE", "DECnet", "NETBEUI",
"SECURITY", "KEY", "NETLINK", "PACKET", "ASH", "ECONET", "ATMSVC",
"RDS", "SNA", "IRDA", "PPPOX", "WANPIPE", "LLC", "IB", "CAN", "TIPC",
"BLUETOOTH", "IUCV", "RXRPC", "ISDN", "PHONET", "IEEE802154", "CAIF",
"ALG", "NFC", "VSOCK",
};
DEFINE_STRARRAY(socket_families, "PF_"); DEFINE_STRARRAY(socket_families, "PF_");
static size_t af_inet__scnprintf(struct sockaddr *sa, char *bf, size_t size) static size_t af_inet__scnprintf(struct sockaddr *sa, char *bf, size_t size)
......
#!/bin/sh
# SPDX-License-Identifier: LGPL-2.1
# This one uses a copy from the kernel sources headers that is in a
# place used just for these tools/perf/beauty/ usage, we shouldn't not
# put it in tools/include/linux otherwise they would be used in the
# normal compiler building process and would drag needless stuff from the
# kernel.
# When what these scripts need is already in tools/include/ then use it,
# otherwise grab and check the copy from the kernel sources just for these
# string table building scripts.
[ $# -eq 1 ] && header_dir=$1 || header_dir=tools/perf/trace/beauty/include/linux/
printf "static const char *socket_families[] = {\n"
# #define AF_LOCAL 1 /* POSIX name for AF_UNIX */
regex='^#define[[:space:]]+AF_(\w+)[[:space:]]+([[:digit:]]+).*'
egrep $regex ${header_dir}/socket.h | \
sed -r "s/$regex/\2 \1/g" | \
xargs printf "\t[%s] = \"%s\",\n" | \
egrep -v "\"(UNIX|MAX)\""
printf "};\n"
...@@ -117,6 +117,7 @@ endif ...@@ -117,6 +117,7 @@ endif
perf-y += parse-branch-options.o perf-y += parse-branch-options.o
perf-y += dump-insn.o perf-y += dump-insn.o
perf-y += parse-regs-options.o perf-y += parse-regs-options.o
perf-y += parse-sublevel-options.o
perf-y += term.o perf-y += term.o
perf-y += help-unknown-cmd.o perf-y += help-unknown-cmd.o
perf-y += mem-events.o perf-y += mem-events.o
......
...@@ -31,6 +31,10 @@ ...@@ -31,6 +31,10 @@
#include "probe-file.h" #include "probe-file.h"
#include "strlist.h" #include "strlist.h"
#ifdef HAVE_DEBUGINFOD_SUPPORT
#include <elfutils/debuginfod.h>
#endif
#include <linux/ctype.h> #include <linux/ctype.h>
#include <linux/zalloc.h> #include <linux/zalloc.h>
...@@ -636,6 +640,21 @@ static char *build_id_cache__find_debug(const char *sbuild_id, ...@@ -636,6 +640,21 @@ static char *build_id_cache__find_debug(const char *sbuild_id,
if (realname && access(realname, R_OK)) if (realname && access(realname, R_OK))
zfree(&realname); zfree(&realname);
nsinfo__mountns_exit(&nsc); nsinfo__mountns_exit(&nsc);
#ifdef HAVE_DEBUGINFOD_SUPPORT
if (realname == NULL) {
debuginfod_client* c = debuginfod_begin();
if (c != NULL) {
int fd = debuginfod_find_debuginfo(c,
(const unsigned char*)sbuild_id, 0,
&realname);
if (fd >= 0)
close(fd); /* retaining reference by realname */
debuginfod_end(c);
}
}
#endif
out: out:
free(debugfile); free(debugfile);
return realname; return realname;
......
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include "target.h" #include "target.h"
#include "ui/helpline.h" #include "ui/helpline.h"
#include "ui/ui.h" #include "ui/ui.h"
#include "util/parse-sublevel-options.h"
#include <linux/ctype.h> #include <linux/ctype.h>
...@@ -173,65 +174,37 @@ void trace_event(union perf_event *event) ...@@ -173,65 +174,37 @@ void trace_event(union perf_event *event)
trace_event_printer, event); trace_event_printer, event);
} }
static struct debug_variable { static struct sublevel_option debug_opts[] = {
const char *name; { .name = "verbose", .value_ptr = &verbose },
int *ptr; { .name = "ordered-events", .value_ptr = &debug_ordered_events},
} debug_variables[] = { { .name = "stderr", .value_ptr = &redirect_to_stderr},
{ .name = "verbose", .ptr = &verbose }, { .name = "data-convert", .value_ptr = &debug_data_convert },
{ .name = "ordered-events", .ptr = &debug_ordered_events}, { .name = "perf-event-open", .value_ptr = &debug_peo_args },
{ .name = "stderr", .ptr = &redirect_to_stderr},
{ .name = "data-convert", .ptr = &debug_data_convert },
{ .name = "perf-event-open", .ptr = &debug_peo_args },
{ .name = NULL, } { .name = NULL, }
}; };
int perf_debug_option(const char *str) int perf_debug_option(const char *str)
{ {
struct debug_variable *var = &debug_variables[0]; int ret;
char *vstr, *s = strdup(str);
int v = 1;
vstr = strchr(s, '=');
if (vstr)
*vstr++ = 0;
while (var->name) {
if (!strcmp(s, var->name))
break;
var++;
}
if (!var->name) {
pr_err("Unknown debug variable name '%s'\n", s);
free(s);
return -1;
}
if (vstr) { ret = perf_parse_sublevel_options(str, debug_opts);
v = atoi(vstr); if (ret)
/* return ret;
* Allow only values in range (0, 10),
* otherwise set 0.
*/
v = (v < 0) || (v > 10) ? 0 : v;
}
if (quiet) /* Allow only verbose value in range (0, 10), otherwise set 0. */
v = -1; verbose = (verbose < 0) || (verbose > 10) ? 0 : verbose;
*var->ptr = v;
free(s);
return 0; return 0;
} }
int perf_quiet_option(void) int perf_quiet_option(void)
{ {
struct debug_variable *var = &debug_variables[0]; struct sublevel_option *opt = &debug_opts[0];
/* disable all debug messages */ /* disable all debug messages */
while (var->name) { while (opt->name) {
*var->ptr = -1; *opt->value_ptr = -1;
var++; opt++;
} }
return 0; return 0;
......
...@@ -1265,7 +1265,7 @@ struct dso *dso__new_id(const char *name, struct dso_id *id) ...@@ -1265,7 +1265,7 @@ struct dso *dso__new_id(const char *name, struct dso_id *id)
dso->has_build_id = 0; dso->has_build_id = 0;
dso->has_srcline = 1; dso->has_srcline = 1;
dso->a2l_fails = 1; dso->a2l_fails = 1;
dso->kernel = DSO_TYPE_USER; dso->kernel = DSO_SPACE__USER;
dso->needs_swap = DSO_SWAP__UNSET; dso->needs_swap = DSO_SWAP__UNSET;
dso->comp = COMP_ID__NONE; dso->comp = COMP_ID__NONE;
RB_CLEAR_NODE(&dso->rb_node); RB_CLEAR_NODE(&dso->rb_node);
......
...@@ -46,10 +46,10 @@ enum dso_binary_type { ...@@ -46,10 +46,10 @@ enum dso_binary_type {
DSO_BINARY_TYPE__NOT_FOUND, DSO_BINARY_TYPE__NOT_FOUND,
}; };
enum dso_kernel_type { enum dso_space_type {
DSO_TYPE_USER = 0, DSO_SPACE__USER = 0,
DSO_TYPE_KERNEL, DSO_SPACE__KERNEL,
DSO_TYPE_GUEST_KERNEL DSO_SPACE__KERNEL_GUEST
}; };
enum dso_swap_type { enum dso_swap_type {
...@@ -160,7 +160,7 @@ struct dso { ...@@ -160,7 +160,7 @@ struct dso {
void *a2l; void *a2l;
char *symsrc_filename; char *symsrc_filename;
unsigned int a2l_fails; unsigned int a2l_fails;
enum dso_kernel_type kernel; enum dso_space_type kernel;
enum dso_swap_type needs_swap; enum dso_swap_type needs_swap;
enum dso_binary_type symtab_type; enum dso_binary_type symtab_type;
enum dso_binary_type binary_type; enum dso_binary_type binary_type;
......
...@@ -2056,7 +2056,7 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev, ...@@ -2056,7 +2056,7 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev,
struct machine *machine; struct machine *machine;
u16 cpumode; u16 cpumode;
struct dso *dso; struct dso *dso;
enum dso_kernel_type dso_type; enum dso_space_type dso_space;
machine = perf_session__findnew_machine(session, bev->pid); machine = perf_session__findnew_machine(session, bev->pid);
if (!machine) if (!machine)
...@@ -2066,14 +2066,14 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev, ...@@ -2066,14 +2066,14 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev,
switch (cpumode) { switch (cpumode) {
case PERF_RECORD_MISC_KERNEL: case PERF_RECORD_MISC_KERNEL:
dso_type = DSO_TYPE_KERNEL; dso_space = DSO_SPACE__KERNEL;
break; break;
case PERF_RECORD_MISC_GUEST_KERNEL: case PERF_RECORD_MISC_GUEST_KERNEL:
dso_type = DSO_TYPE_GUEST_KERNEL; dso_space = DSO_SPACE__KERNEL_GUEST;
break; break;
case PERF_RECORD_MISC_USER: case PERF_RECORD_MISC_USER:
case PERF_RECORD_MISC_GUEST_USER: case PERF_RECORD_MISC_GUEST_USER:
dso_type = DSO_TYPE_USER; dso_space = DSO_SPACE__USER;
break; break;
default: default:
goto out; goto out;
...@@ -2085,14 +2085,13 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev, ...@@ -2085,14 +2085,13 @@ static int __event_process_build_id(struct perf_record_header_build_id *bev,
dso__set_build_id(dso, &bev->build_id); dso__set_build_id(dso, &bev->build_id);
if (dso_type != DSO_TYPE_USER) { if (dso_space != DSO_SPACE__USER) {
struct kmod_path m = { .name = NULL, }; struct kmod_path m = { .name = NULL, };
if (!kmod_path__parse_name(&m, filename) && m.kmod) if (!kmod_path__parse_name(&m, filename) && m.kmod)
dso__set_module_info(dso, &m, machine); dso__set_module_info(dso, &m, machine);
else
dso->kernel = dso_type;
dso->kernel = dso_space;
free(m.name); free(m.name);
} }
......
...@@ -703,7 +703,7 @@ static struct dso *machine__findnew_module_dso(struct machine *machine, ...@@ -703,7 +703,7 @@ static struct dso *machine__findnew_module_dso(struct machine *machine,
dso__set_module_info(dso, m, machine); dso__set_module_info(dso, m, machine);
dso__set_long_name(dso, strdup(filename), true); dso__set_long_name(dso, strdup(filename), true);
dso->kernel = DSO_TYPE_KERNEL; dso->kernel = DSO_SPACE__KERNEL;
} }
dso__get(dso); dso__get(dso);
...@@ -753,7 +753,7 @@ static int machine__process_ksymbol_register(struct machine *machine, ...@@ -753,7 +753,7 @@ static int machine__process_ksymbol_register(struct machine *machine,
struct dso *dso = dso__new(event->ksymbol.name); struct dso *dso = dso__new(event->ksymbol.name);
if (dso) { if (dso) {
dso->kernel = DSO_TYPE_KERNEL; dso->kernel = DSO_SPACE__KERNEL;
map = map__new2(0, dso); map = map__new2(0, dso);
} }
...@@ -971,14 +971,14 @@ static struct dso *machine__get_kernel(struct machine *machine) ...@@ -971,14 +971,14 @@ static struct dso *machine__get_kernel(struct machine *machine)
vmlinux_name = symbol_conf.vmlinux_name; vmlinux_name = symbol_conf.vmlinux_name;
kernel = machine__findnew_kernel(machine, vmlinux_name, kernel = machine__findnew_kernel(machine, vmlinux_name,
"[kernel]", DSO_TYPE_KERNEL); "[kernel]", DSO_SPACE__KERNEL);
} else { } else {
if (symbol_conf.default_guest_vmlinux_name) if (symbol_conf.default_guest_vmlinux_name)
vmlinux_name = symbol_conf.default_guest_vmlinux_name; vmlinux_name = symbol_conf.default_guest_vmlinux_name;
kernel = machine__findnew_kernel(machine, vmlinux_name, kernel = machine__findnew_kernel(machine, vmlinux_name,
"[guest.kernel]", "[guest.kernel]",
DSO_TYPE_GUEST_KERNEL); DSO_SPACE__KERNEL_GUEST);
} }
if (kernel != NULL && (!kernel->has_build_id)) if (kernel != NULL && (!kernel->has_build_id))
...@@ -1606,7 +1606,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1606,7 +1606,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
union perf_event *event) union perf_event *event)
{ {
struct map *map; struct map *map;
enum dso_kernel_type kernel_type; enum dso_space_type dso_space;
bool is_kernel_mmap; bool is_kernel_mmap;
/* If we have maps from kcore then we do not need or want any others */ /* If we have maps from kcore then we do not need or want any others */
...@@ -1614,9 +1614,9 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1614,9 +1614,9 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
return 0; return 0;
if (machine__is_host(machine)) if (machine__is_host(machine))
kernel_type = DSO_TYPE_KERNEL; dso_space = DSO_SPACE__KERNEL;
else else
kernel_type = DSO_TYPE_GUEST_KERNEL; dso_space = DSO_SPACE__KERNEL_GUEST;
is_kernel_mmap = memcmp(event->mmap.filename, is_kernel_mmap = memcmp(event->mmap.filename,
machine->mmap_name, machine->mmap_name,
...@@ -1676,7 +1676,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1676,7 +1676,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
if (kernel == NULL) if (kernel == NULL)
goto out_problem; goto out_problem;
kernel->kernel = kernel_type; kernel->kernel = dso_space;
if (__machine__create_kernel_maps(machine, kernel) < 0) { if (__machine__create_kernel_maps(machine, kernel) < 0) {
dso__put(kernel); dso__put(kernel);
goto out_problem; goto out_problem;
......
...@@ -486,7 +486,7 @@ u64 map__rip_2objdump(struct map *map, u64 rip) ...@@ -486,7 +486,7 @@ u64 map__rip_2objdump(struct map *map, u64 rip)
* kernel modules also have DSO_TYPE_USER in dso->kernel, * kernel modules also have DSO_TYPE_USER in dso->kernel,
* but all kernel modules are ET_REL, so won't get here. * but all kernel modules are ET_REL, so won't get here.
*/ */
if (map->dso->kernel == DSO_TYPE_USER) if (map->dso->kernel == DSO_SPACE__USER)
return rip + map->dso->text_offset; return rip + map->dso->text_offset;
return map->unmap_ip(map, rip) - map->reloc; return map->unmap_ip(map, rip) - map->reloc;
...@@ -516,7 +516,7 @@ u64 map__objdump_2mem(struct map *map, u64 ip) ...@@ -516,7 +516,7 @@ u64 map__objdump_2mem(struct map *map, u64 ip)
* kernel modules also have DSO_TYPE_USER in dso->kernel, * kernel modules also have DSO_TYPE_USER in dso->kernel,
* but all kernel modules are ET_REL, so won't get here. * but all kernel modules are ET_REL, so won't get here.
*/ */
if (map->dso->kernel == DSO_TYPE_USER) if (map->dso->kernel == DSO_SPACE__USER)
return map->unmap_ip(map, ip - map->dso->text_offset); return map->unmap_ip(map, ip - map->dso->text_offset);
return ip + map->reloc; return ip + map->reloc;
......
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
#include <stdio.h>
#include "util/debug.h"
#include "util/parse-sublevel-options.h"
static int parse_one_sublevel_option(const char *str,
struct sublevel_option *opts)
{
struct sublevel_option *opt = opts;
char *vstr, *s = strdup(str);
int v = 1;
if (!s) {
pr_err("no memory\n");
return -1;
}
vstr = strchr(s, '=');
if (vstr)
*vstr++ = 0;
while (opt->name) {
if (!strcmp(s, opt->name))
break;
opt++;
}
if (!opt->name) {
pr_err("Unknown option name '%s'\n", s);
free(s);
return -1;
}
if (vstr)
v = atoi(vstr);
*opt->value_ptr = v;
free(s);
return 0;
}
/* parse options like --foo a=<n>,b,c... */
int perf_parse_sublevel_options(const char *str, struct sublevel_option *opts)
{
char *s = strdup(str);
char *p = NULL;
int ret;
if (!s) {
pr_err("no memory\n");
return -1;
}
p = strtok(s, ",");
while (p) {
ret = parse_one_sublevel_option(p, opts);
if (ret) {
free(s);
return ret;
}
p = strtok(NULL, ",");
}
free(s);
return 0;
}
#ifndef _PERF_PARSE_SUBLEVEL_OPTIONS_H
#define _PERF_PARSE_SUBLEVEL_OPTIONS_H
struct sublevel_option {
const char *name;
int *value_ptr;
};
int perf_parse_sublevel_options(const char *str, struct sublevel_option *opts);
#endif
\ No newline at end of file
...@@ -789,7 +789,7 @@ int symsrc__init(struct symsrc *ss, struct dso *dso, const char *name, ...@@ -789,7 +789,7 @@ int symsrc__init(struct symsrc *ss, struct dso *dso, const char *name,
if (ss->opdshdr.sh_type != SHT_PROGBITS) if (ss->opdshdr.sh_type != SHT_PROGBITS)
ss->opdsec = NULL; ss->opdsec = NULL;
if (dso->kernel == DSO_TYPE_USER) if (dso->kernel == DSO_SPACE__USER)
ss->adjust_symbols = true; ss->adjust_symbols = true;
else else
ss->adjust_symbols = elf__needs_adjust_symbols(ehdr); ss->adjust_symbols = elf__needs_adjust_symbols(ehdr);
...@@ -872,7 +872,7 @@ static int dso__process_kernel_symbol(struct dso *dso, struct map *map, ...@@ -872,7 +872,7 @@ static int dso__process_kernel_symbol(struct dso *dso, struct map *map,
* kallsyms and identity maps. Overwrite it to * kallsyms and identity maps. Overwrite it to
* map to the kernel dso. * map to the kernel dso.
*/ */
if (*remap_kernel && dso->kernel) { if (*remap_kernel && dso->kernel && !kmodule) {
*remap_kernel = false; *remap_kernel = false;
map->start = shdr->sh_addr + ref_reloc(kmap); map->start = shdr->sh_addr + ref_reloc(kmap);
map->end = map->start + shdr->sh_size; map->end = map->start + shdr->sh_size;
...@@ -1068,7 +1068,7 @@ int dso__load_sym(struct dso *dso, struct map *map, struct symsrc *syms_ss, ...@@ -1068,7 +1068,7 @@ int dso__load_sym(struct dso *dso, struct map *map, struct symsrc *syms_ss,
* Initial kernel and module mappings do not map to the dso. * Initial kernel and module mappings do not map to the dso.
* Flag the fixups. * Flag the fixups.
*/ */
if (dso->kernel || kmodule) { if (dso->kernel) {
remap_kernel = true; remap_kernel = true;
adjust_kernel_syms = dso->adjust_symbols; adjust_kernel_syms = dso->adjust_symbols;
} }
...@@ -1130,7 +1130,7 @@ int dso__load_sym(struct dso *dso, struct map *map, struct symsrc *syms_ss, ...@@ -1130,7 +1130,7 @@ int dso__load_sym(struct dso *dso, struct map *map, struct symsrc *syms_ss,
(sym.st_value & 1)) (sym.st_value & 1))
--sym.st_value; --sym.st_value;
if (dso->kernel || kmodule) { if (dso->kernel) {
if (dso__process_kernel_symbol(dso, map, &sym, &shdr, kmaps, kmap, &curr_dso, &curr_map, if (dso__process_kernel_symbol(dso, map, &sym, &shdr, kmaps, kmap, &curr_dso, &curr_map,
section_name, adjust_kernel_syms, kmodule, &remap_kernel)) section_name, adjust_kernel_syms, kmodule, &remap_kernel))
goto out_elf_end; goto out_elf_end;
......
...@@ -808,7 +808,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta, ...@@ -808,7 +808,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta,
if (strcmp(curr_map->dso->short_name, module)) { if (strcmp(curr_map->dso->short_name, module)) {
if (curr_map != initial_map && if (curr_map != initial_map &&
dso->kernel == DSO_TYPE_GUEST_KERNEL && dso->kernel == DSO_SPACE__KERNEL_GUEST &&
machine__is_default_guest(machine)) { machine__is_default_guest(machine)) {
/* /*
* We assume all symbols of a module are * We assume all symbols of a module are
...@@ -865,7 +865,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta, ...@@ -865,7 +865,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta,
goto add_symbol; goto add_symbol;
} }
if (dso->kernel == DSO_TYPE_GUEST_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
snprintf(dso_name, sizeof(dso_name), snprintf(dso_name, sizeof(dso_name),
"[guest.kernel].%d", "[guest.kernel].%d",
kernel_range++); kernel_range++);
...@@ -909,7 +909,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta, ...@@ -909,7 +909,7 @@ static int maps__split_kallsyms(struct maps *kmaps, struct dso *dso, u64 delta,
} }
if (curr_map != initial_map && if (curr_map != initial_map &&
dso->kernel == DSO_TYPE_GUEST_KERNEL && dso->kernel == DSO_SPACE__KERNEL_GUEST &&
machine__is_default_guest(kmaps->machine)) { machine__is_default_guest(kmaps->machine)) {
dso__set_loaded(curr_map->dso); dso__set_loaded(curr_map->dso);
} }
...@@ -1387,7 +1387,7 @@ static int dso__load_kcore(struct dso *dso, struct map *map, ...@@ -1387,7 +1387,7 @@ static int dso__load_kcore(struct dso *dso, struct map *map,
* Set the data type and long name so that kcore can be read via * Set the data type and long name so that kcore can be read via
* dso__data_read_addr(). * dso__data_read_addr().
*/ */
if (dso->kernel == DSO_TYPE_GUEST_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
dso->binary_type = DSO_BINARY_TYPE__GUEST_KCORE; dso->binary_type = DSO_BINARY_TYPE__GUEST_KCORE;
else else
dso->binary_type = DSO_BINARY_TYPE__KCORE; dso->binary_type = DSO_BINARY_TYPE__KCORE;
...@@ -1451,7 +1451,7 @@ int __dso__load_kallsyms(struct dso *dso, const char *filename, ...@@ -1451,7 +1451,7 @@ int __dso__load_kallsyms(struct dso *dso, const char *filename,
symbols__fixup_end(&dso->symbols); symbols__fixup_end(&dso->symbols);
symbols__fixup_duplicate(&dso->symbols); symbols__fixup_duplicate(&dso->symbols);
if (dso->kernel == DSO_TYPE_GUEST_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
dso->symtab_type = DSO_BINARY_TYPE__GUEST_KALLSYMS; dso->symtab_type = DSO_BINARY_TYPE__GUEST_KALLSYMS;
else else
dso->symtab_type = DSO_BINARY_TYPE__KALLSYMS; dso->symtab_type = DSO_BINARY_TYPE__KALLSYMS;
...@@ -1537,17 +1537,17 @@ static bool dso__is_compatible_symtab_type(struct dso *dso, bool kmod, ...@@ -1537,17 +1537,17 @@ static bool dso__is_compatible_symtab_type(struct dso *dso, bool kmod,
case DSO_BINARY_TYPE__MIXEDUP_UBUNTU_DEBUGINFO: case DSO_BINARY_TYPE__MIXEDUP_UBUNTU_DEBUGINFO:
case DSO_BINARY_TYPE__BUILDID_DEBUGINFO: case DSO_BINARY_TYPE__BUILDID_DEBUGINFO:
case DSO_BINARY_TYPE__OPENEMBEDDED_DEBUGINFO: case DSO_BINARY_TYPE__OPENEMBEDDED_DEBUGINFO:
return !kmod && dso->kernel == DSO_TYPE_USER; return !kmod && dso->kernel == DSO_SPACE__USER;
case DSO_BINARY_TYPE__KALLSYMS: case DSO_BINARY_TYPE__KALLSYMS:
case DSO_BINARY_TYPE__VMLINUX: case DSO_BINARY_TYPE__VMLINUX:
case DSO_BINARY_TYPE__KCORE: case DSO_BINARY_TYPE__KCORE:
return dso->kernel == DSO_TYPE_KERNEL; return dso->kernel == DSO_SPACE__KERNEL;
case DSO_BINARY_TYPE__GUEST_KALLSYMS: case DSO_BINARY_TYPE__GUEST_KALLSYMS:
case DSO_BINARY_TYPE__GUEST_VMLINUX: case DSO_BINARY_TYPE__GUEST_VMLINUX:
case DSO_BINARY_TYPE__GUEST_KCORE: case DSO_BINARY_TYPE__GUEST_KCORE:
return dso->kernel == DSO_TYPE_GUEST_KERNEL; return dso->kernel == DSO_SPACE__KERNEL_GUEST;
case DSO_BINARY_TYPE__GUEST_KMODULE: case DSO_BINARY_TYPE__GUEST_KMODULE:
case DSO_BINARY_TYPE__GUEST_KMODULE_COMP: case DSO_BINARY_TYPE__GUEST_KMODULE_COMP:
...@@ -1650,9 +1650,9 @@ int dso__load(struct dso *dso, struct map *map) ...@@ -1650,9 +1650,9 @@ int dso__load(struct dso *dso, struct map *map)
dso->symtab_type == DSO_BINARY_TYPE__GUEST_KMODULE_COMP; dso->symtab_type == DSO_BINARY_TYPE__GUEST_KMODULE_COMP;
if (dso->kernel && !kmod) { if (dso->kernel && !kmod) {
if (dso->kernel == DSO_TYPE_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL)
ret = dso__load_kernel_sym(dso, map); ret = dso__load_kernel_sym(dso, map);
else if (dso->kernel == DSO_TYPE_GUEST_KERNEL) else if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
ret = dso__load_guest_kernel_sym(dso, map); ret = dso__load_guest_kernel_sym(dso, map);
machine = map__kmaps(map)->machine; machine = map__kmaps(map)->machine;
...@@ -1882,7 +1882,7 @@ int dso__load_vmlinux(struct dso *dso, struct map *map, ...@@ -1882,7 +1882,7 @@ int dso__load_vmlinux(struct dso *dso, struct map *map,
else else
symbol__join_symfs(symfs_vmlinux, vmlinux); symbol__join_symfs(symfs_vmlinux, vmlinux);
if (dso->kernel == DSO_TYPE_GUEST_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
symtab_type = DSO_BINARY_TYPE__GUEST_VMLINUX; symtab_type = DSO_BINARY_TYPE__GUEST_VMLINUX;
else else
symtab_type = DSO_BINARY_TYPE__VMLINUX; symtab_type = DSO_BINARY_TYPE__VMLINUX;
...@@ -1894,7 +1894,7 @@ int dso__load_vmlinux(struct dso *dso, struct map *map, ...@@ -1894,7 +1894,7 @@ int dso__load_vmlinux(struct dso *dso, struct map *map,
symsrc__destroy(&ss); symsrc__destroy(&ss);
if (err > 0) { if (err > 0) {
if (dso->kernel == DSO_TYPE_GUEST_KERNEL) if (dso->kernel == DSO_SPACE__KERNEL_GUEST)
dso->binary_type = DSO_BINARY_TYPE__GUEST_VMLINUX; dso->binary_type = DSO_BINARY_TYPE__GUEST_VMLINUX;
else else
dso->binary_type = DSO_BINARY_TYPE__VMLINUX; dso->binary_type = DSO_BINARY_TYPE__VMLINUX;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment