mirror of https://gitee.com/openkylin/linux.git
b92675f4a9
While tracing a program that calls isatty(3), I noticed that strace
reported TCGETS for the request argument of the underlying ioctl(2)
syscall while perf trace reported TCSETS. strace is corrrect. The bug in
perf was due to the tty ioctl beauty table starting at 0x5400 rather
than 0x5401.
Committer testing:
Using augmented_raw_syscalls.o and settings to make 'perf trace'
use strace formatting, i.e. with this in ~/.perfconfig
# cat ~/.perfconfig
[trace]
add_events = /home/acme/git/linux/tools/perf/examples/bpf/augmented_raw_syscalls.c
show_zeros = yes
show_duration = no
no_inherit = yes
show_timestamp = no
show_arg_names = no
args_alignment = 40
show_prefix = yes
# strace -e ioctl stty > /dev/null
ioctl(0, TCGETS, {B38400 opost isig icanon echo ...}) = 0
ioctl(1, TIOCGWINSZ, 0x7fff8a9b0860) = -1 ENOTTY (Inappropriate ioctl for device)
ioctl(1, TCGETS, 0x7fff8a9b0540) = -1 ENOTTY (Inappropriate ioctl for device)
+++ exited with 0 +++
#
Before:
# perf trace -e ioctl stty > /dev/null
ioctl(0, TCSETS, 0x7fff2cf79f20) = 0
ioctl(1, TIOCSWINSZ, 0x7fff2cf79f40) = -1 ENOTTY (Inappropriate ioctl for device)
ioctl(1, TCSETS, 0x7fff2cf79c20) = -1 ENOTTY (Inappropriate ioctl for device)
#
After:
# perf trace -e ioctl stty > /dev/null
ioctl(0, TCGETS, 0x7ffed0763920) = 0
ioctl(1, TIOCGWINSZ, 0x7ffed0763940) = -1 ENOTTY (Inappropriate ioctl for device)
ioctl(1, TCGETS, 0x7ffed0763620) = -1 ENOTTY (Inappropriate ioctl for device)
#
Signed-off-by: Benjamin Peterson <benjamin@python.org>
Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Fixes:
|
||
---|---|---|
.. | ||
Build | ||
arch_errno_names.c | ||
arch_errno_names.sh | ||
arch_prctl.c | ||
beauty.h | ||
clone.c | ||
drm_ioctl.sh | ||
eventfd.c | ||
fadvise.sh | ||
fcntl.c | ||
flock.c | ||
fsconfig.sh | ||
fsmount.c | ||
fsmount.sh | ||
fspick.c | ||
fspick.sh | ||
futex_op.c | ||
futex_val3.c | ||
ioctl.c | ||
kcmp.c | ||
kcmp_type.sh | ||
kvm_ioctl.sh | ||
madvise_behavior.sh | ||
mmap.c | ||
mmap_flags.sh | ||
mode_t.c | ||
mount_flags.c | ||
mount_flags.sh | ||
move_mount.c | ||
move_mount_flags.sh | ||
msg_flags.c | ||
open_flags.c | ||
perf_event_open.c | ||
perf_ioctl.sh | ||
pid.c | ||
pkey_alloc.c | ||
pkey_alloc_access_rights.sh | ||
prctl.c | ||
prctl_option.sh | ||
rename_flags.sh | ||
renameat.c | ||
sched_policy.c | ||
seccomp.c | ||
signum.c | ||
sndrv_ctl_ioctl.sh | ||
sndrv_pcm_ioctl.sh | ||
sockaddr.c | ||
socket.c | ||
socket_ipproto.sh | ||
socket_type.c | ||
statx.c | ||
sync_file_range.c | ||
sync_file_range.sh | ||
usbdevfs_ioctl.sh | ||
vhost_virtio_ioctl.sh | ||
waitid_options.c | ||
x86_arch_prctl.sh |