Commit 432100ba authored by Ingo Molnar's avatar Ingo Molnar

Merge tag 'perf-core-for-mingo' of...

Merge tag 'perf-core-for-mingo' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/core

Pull perf/core improvements and fixes from Arnaldo Carvalho de Melo:

New features:

  * Add support for pagefault tracing in 'trace', please see multiple examples
    in the changeset messages (Stanislav Fomichev).

User visible changes:

  * Fallback to syscalls:* when raw_syscalls:* is not available in the perl and
    python perf scripts. (Daniel Bristot de Oliveira)
Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
parents 2172c1f5 e281a960
...@@ -107,6 +107,52 @@ the thread executes on the designated CPUs. Default is to monitor all CPUs. ...@@ -107,6 +107,52 @@ the thread executes on the designated CPUs. Default is to monitor all CPUs.
Show tool stats such as number of times fd->pathname was discovered thru Show tool stats such as number of times fd->pathname was discovered thru
hooking the open syscall return + vfs_getname or via reading /proc/pid/fd, etc. hooking the open syscall return + vfs_getname or via reading /proc/pid/fd, etc.
-F=[all|min|maj]::
--pf=[all|min|maj]::
Trace pagefaults. Optionally, you can specify whether you want minor,
major or all pagefaults. Default value is maj.
--syscalls::
Trace system calls. This options is enabled by default.
PAGEFAULTS
----------
When tracing pagefaults, the format of the trace is as follows:
<min|maj>fault [<ip.symbol>+<ip.offset>] => <addr.dso@addr.offset> (<map type><addr level>).
- min/maj indicates whether fault event is minor or major;
- ip.symbol shows symbol for instruction pointer (the code that generated the
fault); if no debug symbols available, perf trace will print raw IP;
- addr.dso shows DSO for the faulted address;
- map type is either 'd' for non-executable maps or 'x' for executable maps;
- addr level is either 'k' for kernel dso or '.' for user dso.
For symbols resolution you may need to install debugging symbols.
Please be aware that duration is currently always 0 and doesn't reflect actual
time it took for fault to be handled!
When --verbose specified, perf trace tries to print all available information
for both IP and fault address in the form of dso@symbol+offset.
EXAMPLES
--------
Trace only major pagefaults:
$ perf trace --no-syscalls -F
Trace syscalls, major and minor pagefaults:
$ perf trace -F all
1416.547 ( 0.000 ms): python/20235 majfault [CRYPTO_push_info_+0x0] => /lib/x86_64-linux-gnu/libcrypto.so.1.0.0@0x61be0 (x.)
As you can see, there was major pagefault in python process, from
CRYPTO_push_info_ routine which faulted somewhere in libcrypto.so.
SEE ALSO SEE ALSO
-------- --------
linkperf:perf-record[1], linkperf:perf-script[1] linkperf:perf-record[1], linkperf:perf-script[1]
This diff is collapsed.
#!/bin/bash #!/bin/bash
perf record -e raw_syscalls:sys_exit $@ (perf record -e raw_syscalls:sys_exit $@ || \
perf record -e syscalls:sys_exit $@) 2> /dev/null
...@@ -26,6 +26,11 @@ sub raw_syscalls::sys_exit ...@@ -26,6 +26,11 @@ sub raw_syscalls::sys_exit
} }
} }
sub syscalls::sys_exit
{
raw_syscalls::sys_exit(@_)
}
sub trace_end sub trace_end
{ {
printf("\nfailed syscalls by comm:\n\n"); printf("\nfailed syscalls by comm:\n\n");
......
#!/bin/bash #!/bin/bash
perf record -e raw_syscalls:sys_exit $@ (perf record -e raw_syscalls:sys_exit $@ || \
perf record -e syscalls:sys_exit $@) 2> /dev/null
#!/bin/bash #!/bin/bash
perf record -e raw_syscalls:sys_enter $@ (perf record -e raw_syscalls:sys_enter $@ || \
perf record -e syscalls:sys_enter $@) 2> /dev/null
#!/bin/bash #!/bin/bash
perf record -e raw_syscalls:sys_enter $@ (perf record -e raw_syscalls:sys_enter $@ || \
perf record -e syscalls:sys_enter $@) 2> /dev/null
#!/bin/bash #!/bin/bash
perf record -e raw_syscalls:sys_enter $@ (perf record -e raw_syscalls:sys_enter $@ || \
perf record -e syscalls:sys_enter $@) 2> /dev/null
...@@ -50,6 +50,11 @@ def raw_syscalls__sys_exit(event_name, context, common_cpu, ...@@ -50,6 +50,11 @@ def raw_syscalls__sys_exit(event_name, context, common_cpu,
except TypeError: except TypeError:
syscalls[common_comm][common_pid][id][ret] = 1 syscalls[common_comm][common_pid][id][ret] = 1
def syscalls__sys_exit(event_name, context, common_cpu,
common_secs, common_nsecs, common_pid, common_comm,
id, ret):
raw_syscalls__sys_exit(**locals())
def print_error_totals(): def print_error_totals():
if for_comm is not None: if for_comm is not None:
print "\nsyscall errors for %s:\n\n" % (for_comm), print "\nsyscall errors for %s:\n\n" % (for_comm),
......
...@@ -53,6 +53,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu, ...@@ -53,6 +53,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu,
except TypeError: except TypeError:
syscalls[id] = 1 syscalls[id] = 1
def syscalls__sys_enter(event_name, context, common_cpu,
common_secs, common_nsecs, common_pid, common_comm,
id, args):
raw_syscalls__sys_enter(**locals())
def print_syscall_totals(interval): def print_syscall_totals(interval):
while 1: while 1:
clear_term() clear_term()
......
...@@ -48,6 +48,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu, ...@@ -48,6 +48,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu,
except TypeError: except TypeError:
syscalls[common_comm][common_pid][id] = 1 syscalls[common_comm][common_pid][id] = 1
def syscalls__sys_enter(event_name, context, common_cpu,
common_secs, common_nsecs, common_pid, common_comm,
id, args):
raw_syscalls__sys_enter(**locals())
def print_syscall_totals(): def print_syscall_totals():
if for_comm is not None: if for_comm is not None:
print "\nsyscall events for %s:\n\n" % (for_comm), print "\nsyscall events for %s:\n\n" % (for_comm),
......
...@@ -44,6 +44,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu, ...@@ -44,6 +44,11 @@ def raw_syscalls__sys_enter(event_name, context, common_cpu,
except TypeError: except TypeError:
syscalls[id] = 1 syscalls[id] = 1
def syscalls__sys_enter(event_name, context, common_cpu,
common_secs, common_nsecs, common_pid, common_comm,
id, args):
raw_syscalls__sys_enter(**locals())
def print_syscall_totals(): def print_syscall_totals():
if for_comm is not None: if for_comm is not None:
print "\nsyscall events for %s:\n\n" % (for_comm), print "\nsyscall events for %s:\n\n" % (for_comm),
......
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