mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	perf tools: Build syscall table .c header from kernel's syscall_64.tbl
We used libaudit to map ids to syscall names and vice-versa, but that
imposes a delay in supporting new syscalls, having to wait for libaudit
to get those new syscalls on its tables.
To remove that delay, for x86_64 initially, grab a copy of
arch/x86/entry/syscalls/syscall_64.tbl and use it to generate those
tables.
Syscalls currently not available in audit-libs:
  # trace -e copy_file_range,membarrier,mlock2,pread64,pwrite64,timerfd_create,userfaultfd
  Error:	Invalid syscall copy_file_range, membarrier, mlock2, pread64, pwrite64, timerfd_create, userfaultfd
  Hint:	try 'perf list syscalls:sys_enter_*'
  Hint:	and: 'man syscalls'
  #
With this patch:
  # trace -e copy_file_range,membarrier,mlock2,pread64,pwrite64,timerfd_create,userfaultfd
    8505.733 ( 0.010 ms): gnome-shell/2519 timerfd_create(flags: 524288) = 36
    8506.688 ( 0.005 ms): gnome-shell/2519 timerfd_create(flags: 524288) = 40
   30023.097 ( 0.025 ms): qemu-system-x8/24629 pwrite64(fd: 18, buf: 0x7f63ae382000, count: 4096, pos: 529592320) = 4096
   31268.712 ( 0.028 ms): qemu-system-x8/24629 pwrite64(fd: 18, buf: 0x7f63afd8b000, count: 4096, pos: 2314133504) = 4096
   31268.854 ( 0.016 ms): qemu-system-x8/24629 pwrite64(fd: 18, buf: 0x7f63afda2000, count: 4096, pos: 2314137600) = 4096
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Wang Nan <wangnan0@huawei.com>
Link: http://lkml.kernel.org/n/tip-51xfjbxevdsucmnbc4ka5r88@git.kernel.org
[ Added make dep for 'prepare' in 'LIBPERF_IN', fix by Wang Nan to fix parallell build ]
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
			
			
This commit is contained in:
		
							parent
							
								
									5af56fab2b
								
							
						
					
					
						commit
						1b700c9975
					
				
					 7 changed files with 456 additions and 5 deletions
				
			
		| 
						 | 
					@ -183,6 +183,11 @@ endif
 | 
				
			||||||
include config/Makefile
 | 
					include config/Makefile
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifeq ($(config),0)
 | 
				
			||||||
 | 
					include $(srctree)/tools/scripts/Makefile.arch
 | 
				
			||||||
 | 
					-include arch/$(ARCH)/Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# The FEATURE_DUMP_EXPORT holds location of the actual
 | 
					# The FEATURE_DUMP_EXPORT holds location of the actual
 | 
				
			||||||
# FEATURE_DUMP file to be used to bypass feature detection
 | 
					# FEATURE_DUMP file to be used to bypass feature detection
 | 
				
			||||||
# (for bpf or any other subproject)
 | 
					# (for bpf or any other subproject)
 | 
				
			||||||
| 
						 | 
					@ -388,7 +393,7 @@ endif
 | 
				
			||||||
__build-dir = $(subst $(OUTPUT),,$(dir $@))
 | 
					__build-dir = $(subst $(OUTPUT),,$(dir $@))
 | 
				
			||||||
build-dir   = $(if $(__build-dir),$(__build-dir),.)
 | 
					build-dir   = $(if $(__build-dir),$(__build-dir),.)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h fixdep
 | 
					prepare: $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)common-cmds.h fixdep archheaders
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(OUTPUT)%.o: %.c prepare FORCE
 | 
					$(OUTPUT)%.o: %.c prepare FORCE
 | 
				
			||||||
	$(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
 | 
						$(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=$(build-dir) $@
 | 
				
			||||||
| 
						 | 
					@ -428,7 +433,7 @@ $(patsubst perf-%,%.o,$(PROGRAMS)): $(wildcard */*.h)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
LIBPERF_IN := $(OUTPUT)libperf-in.o
 | 
					LIBPERF_IN := $(OUTPUT)libperf-in.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(LIBPERF_IN): fixdep FORCE
 | 
					$(LIBPERF_IN): prepare fixdep FORCE
 | 
				
			||||||
	$(Q)$(MAKE) $(build)=libperf
 | 
						$(Q)$(MAKE) $(build)=libperf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(LIB_FILE): $(LIBPERF_IN)
 | 
					$(LIB_FILE): $(LIBPERF_IN)
 | 
				
			||||||
| 
						 | 
					@ -623,7 +628,7 @@ config-clean:
 | 
				
			||||||
	$(call QUIET_CLEAN, config)
 | 
						$(call QUIET_CLEAN, config)
 | 
				
			||||||
	$(Q)$(MAKE) -C $(srctree)/tools/build/feature/ $(if $(OUTPUT),OUTPUT=$(OUTPUT)feature/,) clean >/dev/null
 | 
						$(Q)$(MAKE) -C $(srctree)/tools/build/feature/ $(if $(OUTPUT),OUTPUT=$(OUTPUT)feature/,) clean >/dev/null
 | 
				
			||||||
 | 
					
 | 
				
			||||||
clean: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean config-clean
 | 
					clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean config-clean
 | 
				
			||||||
	$(call QUIET_CLEAN, core-objs)  $(RM) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(LANG_BINDINGS)
 | 
						$(call QUIET_CLEAN, core-objs)  $(RM) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(LANG_BINDINGS)
 | 
				
			||||||
	$(Q)find $(if $(OUTPUT),$(OUTPUT),.) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete
 | 
						$(Q)find $(if $(OUTPUT),$(OUTPUT),.) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete
 | 
				
			||||||
	$(Q)$(RM) $(OUTPUT).config-detected
 | 
						$(Q)$(RM) $(OUTPUT).config-detected
 | 
				
			||||||
| 
						 | 
					@ -660,5 +665,5 @@ FORCE:
 | 
				
			||||||
.PHONY: all install clean config-clean strip install-gtk
 | 
					.PHONY: all install clean config-clean strip install-gtk
 | 
				
			||||||
.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
 | 
					.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
 | 
				
			||||||
.PHONY: $(GIT-HEAD-PHONY) TAGS tags cscope FORCE prepare
 | 
					.PHONY: $(GIT-HEAD-PHONY) TAGS tags cscope FORCE prepare
 | 
				
			||||||
.PHONY: libtraceevent_plugins
 | 
					.PHONY: libtraceevent_plugins archheaders
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,3 +4,26 @@ endif
 | 
				
			||||||
HAVE_KVM_STAT_SUPPORT := 1
 | 
					HAVE_KVM_STAT_SUPPORT := 1
 | 
				
			||||||
PERF_HAVE_ARCH_REGS_QUERY_REGISTER_OFFSET := 1
 | 
					PERF_HAVE_ARCH_REGS_QUERY_REGISTER_OFFSET := 1
 | 
				
			||||||
PERF_HAVE_JITDUMP := 1
 | 
					PERF_HAVE_JITDUMP := 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					###
 | 
				
			||||||
 | 
					# Syscall table generation
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					out    := $(OUTPUT)arch/x86/include/generated/asm
 | 
				
			||||||
 | 
					header := $(out)/syscalls_64.c
 | 
				
			||||||
 | 
					sys    := $(srctree)/tools/perf/arch/x86/entry/syscalls
 | 
				
			||||||
 | 
					systbl := $(sys)/syscalltbl.sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Create output directory if not already present
 | 
				
			||||||
 | 
					_dummy := $(shell [ -d '$(out)' ] || mkdir -p '$(out)')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(header): $(sys)/syscall_64.tbl $(systbl)
 | 
				
			||||||
 | 
						@(test -d ../../kernel -a -d ../../tools -a -d ../perf && ( \
 | 
				
			||||||
 | 
					        (diff -B arch/x86/entry/syscalls/syscall_64.tbl ../../arch/x86/entry/syscalls/syscall_64.tbl >/dev/null) \
 | 
				
			||||||
 | 
					        || echo "Warning: x86_64's syscall_64.tbl differs from kernel" >&2 )) || true
 | 
				
			||||||
 | 
						$(Q)$(SHELL) '$(systbl)' $(sys)/syscall_64.tbl 'x86_64' > $@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					clean::
 | 
				
			||||||
 | 
						rm -f $(header)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					archheaders: $(header)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										374
									
								
								tools/perf/arch/x86/entry/syscalls/syscall_64.tbl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										374
									
								
								tools/perf/arch/x86/entry/syscalls/syscall_64.tbl
									
									
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,374 @@
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 64-bit system call numbers and entry vectors
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# The format is:
 | 
				
			||||||
 | 
					# <number> <abi> <name> <entry point>
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# The abi is "common", "64" or "x32" for this file.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					0	common	read			sys_read
 | 
				
			||||||
 | 
					1	common	write			sys_write
 | 
				
			||||||
 | 
					2	common	open			sys_open
 | 
				
			||||||
 | 
					3	common	close			sys_close
 | 
				
			||||||
 | 
					4	common	stat			sys_newstat
 | 
				
			||||||
 | 
					5	common	fstat			sys_newfstat
 | 
				
			||||||
 | 
					6	common	lstat			sys_newlstat
 | 
				
			||||||
 | 
					7	common	poll			sys_poll
 | 
				
			||||||
 | 
					8	common	lseek			sys_lseek
 | 
				
			||||||
 | 
					9	common	mmap			sys_mmap
 | 
				
			||||||
 | 
					10	common	mprotect		sys_mprotect
 | 
				
			||||||
 | 
					11	common	munmap			sys_munmap
 | 
				
			||||||
 | 
					12	common	brk			sys_brk
 | 
				
			||||||
 | 
					13	64	rt_sigaction		sys_rt_sigaction
 | 
				
			||||||
 | 
					14	common	rt_sigprocmask		sys_rt_sigprocmask
 | 
				
			||||||
 | 
					15	64	rt_sigreturn		sys_rt_sigreturn/ptregs
 | 
				
			||||||
 | 
					16	64	ioctl			sys_ioctl
 | 
				
			||||||
 | 
					17	common	pread64			sys_pread64
 | 
				
			||||||
 | 
					18	common	pwrite64		sys_pwrite64
 | 
				
			||||||
 | 
					19	64	readv			sys_readv
 | 
				
			||||||
 | 
					20	64	writev			sys_writev
 | 
				
			||||||
 | 
					21	common	access			sys_access
 | 
				
			||||||
 | 
					22	common	pipe			sys_pipe
 | 
				
			||||||
 | 
					23	common	select			sys_select
 | 
				
			||||||
 | 
					24	common	sched_yield		sys_sched_yield
 | 
				
			||||||
 | 
					25	common	mremap			sys_mremap
 | 
				
			||||||
 | 
					26	common	msync			sys_msync
 | 
				
			||||||
 | 
					27	common	mincore			sys_mincore
 | 
				
			||||||
 | 
					28	common	madvise			sys_madvise
 | 
				
			||||||
 | 
					29	common	shmget			sys_shmget
 | 
				
			||||||
 | 
					30	common	shmat			sys_shmat
 | 
				
			||||||
 | 
					31	common	shmctl			sys_shmctl
 | 
				
			||||||
 | 
					32	common	dup			sys_dup
 | 
				
			||||||
 | 
					33	common	dup2			sys_dup2
 | 
				
			||||||
 | 
					34	common	pause			sys_pause
 | 
				
			||||||
 | 
					35	common	nanosleep		sys_nanosleep
 | 
				
			||||||
 | 
					36	common	getitimer		sys_getitimer
 | 
				
			||||||
 | 
					37	common	alarm			sys_alarm
 | 
				
			||||||
 | 
					38	common	setitimer		sys_setitimer
 | 
				
			||||||
 | 
					39	common	getpid			sys_getpid
 | 
				
			||||||
 | 
					40	common	sendfile		sys_sendfile64
 | 
				
			||||||
 | 
					41	common	socket			sys_socket
 | 
				
			||||||
 | 
					42	common	connect			sys_connect
 | 
				
			||||||
 | 
					43	common	accept			sys_accept
 | 
				
			||||||
 | 
					44	common	sendto			sys_sendto
 | 
				
			||||||
 | 
					45	64	recvfrom		sys_recvfrom
 | 
				
			||||||
 | 
					46	64	sendmsg			sys_sendmsg
 | 
				
			||||||
 | 
					47	64	recvmsg			sys_recvmsg
 | 
				
			||||||
 | 
					48	common	shutdown		sys_shutdown
 | 
				
			||||||
 | 
					49	common	bind			sys_bind
 | 
				
			||||||
 | 
					50	common	listen			sys_listen
 | 
				
			||||||
 | 
					51	common	getsockname		sys_getsockname
 | 
				
			||||||
 | 
					52	common	getpeername		sys_getpeername
 | 
				
			||||||
 | 
					53	common	socketpair		sys_socketpair
 | 
				
			||||||
 | 
					54	64	setsockopt		sys_setsockopt
 | 
				
			||||||
 | 
					55	64	getsockopt		sys_getsockopt
 | 
				
			||||||
 | 
					56	common	clone			sys_clone/ptregs
 | 
				
			||||||
 | 
					57	common	fork			sys_fork/ptregs
 | 
				
			||||||
 | 
					58	common	vfork			sys_vfork/ptregs
 | 
				
			||||||
 | 
					59	64	execve			sys_execve/ptregs
 | 
				
			||||||
 | 
					60	common	exit			sys_exit
 | 
				
			||||||
 | 
					61	common	wait4			sys_wait4
 | 
				
			||||||
 | 
					62	common	kill			sys_kill
 | 
				
			||||||
 | 
					63	common	uname			sys_newuname
 | 
				
			||||||
 | 
					64	common	semget			sys_semget
 | 
				
			||||||
 | 
					65	common	semop			sys_semop
 | 
				
			||||||
 | 
					66	common	semctl			sys_semctl
 | 
				
			||||||
 | 
					67	common	shmdt			sys_shmdt
 | 
				
			||||||
 | 
					68	common	msgget			sys_msgget
 | 
				
			||||||
 | 
					69	common	msgsnd			sys_msgsnd
 | 
				
			||||||
 | 
					70	common	msgrcv			sys_msgrcv
 | 
				
			||||||
 | 
					71	common	msgctl			sys_msgctl
 | 
				
			||||||
 | 
					72	common	fcntl			sys_fcntl
 | 
				
			||||||
 | 
					73	common	flock			sys_flock
 | 
				
			||||||
 | 
					74	common	fsync			sys_fsync
 | 
				
			||||||
 | 
					75	common	fdatasync		sys_fdatasync
 | 
				
			||||||
 | 
					76	common	truncate		sys_truncate
 | 
				
			||||||
 | 
					77	common	ftruncate		sys_ftruncate
 | 
				
			||||||
 | 
					78	common	getdents		sys_getdents
 | 
				
			||||||
 | 
					79	common	getcwd			sys_getcwd
 | 
				
			||||||
 | 
					80	common	chdir			sys_chdir
 | 
				
			||||||
 | 
					81	common	fchdir			sys_fchdir
 | 
				
			||||||
 | 
					82	common	rename			sys_rename
 | 
				
			||||||
 | 
					83	common	mkdir			sys_mkdir
 | 
				
			||||||
 | 
					84	common	rmdir			sys_rmdir
 | 
				
			||||||
 | 
					85	common	creat			sys_creat
 | 
				
			||||||
 | 
					86	common	link			sys_link
 | 
				
			||||||
 | 
					87	common	unlink			sys_unlink
 | 
				
			||||||
 | 
					88	common	symlink			sys_symlink
 | 
				
			||||||
 | 
					89	common	readlink		sys_readlink
 | 
				
			||||||
 | 
					90	common	chmod			sys_chmod
 | 
				
			||||||
 | 
					91	common	fchmod			sys_fchmod
 | 
				
			||||||
 | 
					92	common	chown			sys_chown
 | 
				
			||||||
 | 
					93	common	fchown			sys_fchown
 | 
				
			||||||
 | 
					94	common	lchown			sys_lchown
 | 
				
			||||||
 | 
					95	common	umask			sys_umask
 | 
				
			||||||
 | 
					96	common	gettimeofday		sys_gettimeofday
 | 
				
			||||||
 | 
					97	common	getrlimit		sys_getrlimit
 | 
				
			||||||
 | 
					98	common	getrusage		sys_getrusage
 | 
				
			||||||
 | 
					99	common	sysinfo			sys_sysinfo
 | 
				
			||||||
 | 
					100	common	times			sys_times
 | 
				
			||||||
 | 
					101	64	ptrace			sys_ptrace
 | 
				
			||||||
 | 
					102	common	getuid			sys_getuid
 | 
				
			||||||
 | 
					103	common	syslog			sys_syslog
 | 
				
			||||||
 | 
					104	common	getgid			sys_getgid
 | 
				
			||||||
 | 
					105	common	setuid			sys_setuid
 | 
				
			||||||
 | 
					106	common	setgid			sys_setgid
 | 
				
			||||||
 | 
					107	common	geteuid			sys_geteuid
 | 
				
			||||||
 | 
					108	common	getegid			sys_getegid
 | 
				
			||||||
 | 
					109	common	setpgid			sys_setpgid
 | 
				
			||||||
 | 
					110	common	getppid			sys_getppid
 | 
				
			||||||
 | 
					111	common	getpgrp			sys_getpgrp
 | 
				
			||||||
 | 
					112	common	setsid			sys_setsid
 | 
				
			||||||
 | 
					113	common	setreuid		sys_setreuid
 | 
				
			||||||
 | 
					114	common	setregid		sys_setregid
 | 
				
			||||||
 | 
					115	common	getgroups		sys_getgroups
 | 
				
			||||||
 | 
					116	common	setgroups		sys_setgroups
 | 
				
			||||||
 | 
					117	common	setresuid		sys_setresuid
 | 
				
			||||||
 | 
					118	common	getresuid		sys_getresuid
 | 
				
			||||||
 | 
					119	common	setresgid		sys_setresgid
 | 
				
			||||||
 | 
					120	common	getresgid		sys_getresgid
 | 
				
			||||||
 | 
					121	common	getpgid			sys_getpgid
 | 
				
			||||||
 | 
					122	common	setfsuid		sys_setfsuid
 | 
				
			||||||
 | 
					123	common	setfsgid		sys_setfsgid
 | 
				
			||||||
 | 
					124	common	getsid			sys_getsid
 | 
				
			||||||
 | 
					125	common	capget			sys_capget
 | 
				
			||||||
 | 
					126	common	capset			sys_capset
 | 
				
			||||||
 | 
					127	64	rt_sigpending		sys_rt_sigpending
 | 
				
			||||||
 | 
					128	64	rt_sigtimedwait		sys_rt_sigtimedwait
 | 
				
			||||||
 | 
					129	64	rt_sigqueueinfo		sys_rt_sigqueueinfo
 | 
				
			||||||
 | 
					130	common	rt_sigsuspend		sys_rt_sigsuspend
 | 
				
			||||||
 | 
					131	64	sigaltstack		sys_sigaltstack
 | 
				
			||||||
 | 
					132	common	utime			sys_utime
 | 
				
			||||||
 | 
					133	common	mknod			sys_mknod
 | 
				
			||||||
 | 
					134	64	uselib
 | 
				
			||||||
 | 
					135	common	personality		sys_personality
 | 
				
			||||||
 | 
					136	common	ustat			sys_ustat
 | 
				
			||||||
 | 
					137	common	statfs			sys_statfs
 | 
				
			||||||
 | 
					138	common	fstatfs			sys_fstatfs
 | 
				
			||||||
 | 
					139	common	sysfs			sys_sysfs
 | 
				
			||||||
 | 
					140	common	getpriority		sys_getpriority
 | 
				
			||||||
 | 
					141	common	setpriority		sys_setpriority
 | 
				
			||||||
 | 
					142	common	sched_setparam		sys_sched_setparam
 | 
				
			||||||
 | 
					143	common	sched_getparam		sys_sched_getparam
 | 
				
			||||||
 | 
					144	common	sched_setscheduler	sys_sched_setscheduler
 | 
				
			||||||
 | 
					145	common	sched_getscheduler	sys_sched_getscheduler
 | 
				
			||||||
 | 
					146	common	sched_get_priority_max	sys_sched_get_priority_max
 | 
				
			||||||
 | 
					147	common	sched_get_priority_min	sys_sched_get_priority_min
 | 
				
			||||||
 | 
					148	common	sched_rr_get_interval	sys_sched_rr_get_interval
 | 
				
			||||||
 | 
					149	common	mlock			sys_mlock
 | 
				
			||||||
 | 
					150	common	munlock			sys_munlock
 | 
				
			||||||
 | 
					151	common	mlockall		sys_mlockall
 | 
				
			||||||
 | 
					152	common	munlockall		sys_munlockall
 | 
				
			||||||
 | 
					153	common	vhangup			sys_vhangup
 | 
				
			||||||
 | 
					154	common	modify_ldt		sys_modify_ldt
 | 
				
			||||||
 | 
					155	common	pivot_root		sys_pivot_root
 | 
				
			||||||
 | 
					156	64	_sysctl			sys_sysctl
 | 
				
			||||||
 | 
					157	common	prctl			sys_prctl
 | 
				
			||||||
 | 
					158	common	arch_prctl		sys_arch_prctl
 | 
				
			||||||
 | 
					159	common	adjtimex		sys_adjtimex
 | 
				
			||||||
 | 
					160	common	setrlimit		sys_setrlimit
 | 
				
			||||||
 | 
					161	common	chroot			sys_chroot
 | 
				
			||||||
 | 
					162	common	sync			sys_sync
 | 
				
			||||||
 | 
					163	common	acct			sys_acct
 | 
				
			||||||
 | 
					164	common	settimeofday		sys_settimeofday
 | 
				
			||||||
 | 
					165	common	mount			sys_mount
 | 
				
			||||||
 | 
					166	common	umount2			sys_umount
 | 
				
			||||||
 | 
					167	common	swapon			sys_swapon
 | 
				
			||||||
 | 
					168	common	swapoff			sys_swapoff
 | 
				
			||||||
 | 
					169	common	reboot			sys_reboot
 | 
				
			||||||
 | 
					170	common	sethostname		sys_sethostname
 | 
				
			||||||
 | 
					171	common	setdomainname		sys_setdomainname
 | 
				
			||||||
 | 
					172	common	iopl			sys_iopl/ptregs
 | 
				
			||||||
 | 
					173	common	ioperm			sys_ioperm
 | 
				
			||||||
 | 
					174	64	create_module
 | 
				
			||||||
 | 
					175	common	init_module		sys_init_module
 | 
				
			||||||
 | 
					176	common	delete_module		sys_delete_module
 | 
				
			||||||
 | 
					177	64	get_kernel_syms
 | 
				
			||||||
 | 
					178	64	query_module
 | 
				
			||||||
 | 
					179	common	quotactl		sys_quotactl
 | 
				
			||||||
 | 
					180	64	nfsservctl
 | 
				
			||||||
 | 
					181	common	getpmsg
 | 
				
			||||||
 | 
					182	common	putpmsg
 | 
				
			||||||
 | 
					183	common	afs_syscall
 | 
				
			||||||
 | 
					184	common	tuxcall
 | 
				
			||||||
 | 
					185	common	security
 | 
				
			||||||
 | 
					186	common	gettid			sys_gettid
 | 
				
			||||||
 | 
					187	common	readahead		sys_readahead
 | 
				
			||||||
 | 
					188	common	setxattr		sys_setxattr
 | 
				
			||||||
 | 
					189	common	lsetxattr		sys_lsetxattr
 | 
				
			||||||
 | 
					190	common	fsetxattr		sys_fsetxattr
 | 
				
			||||||
 | 
					191	common	getxattr		sys_getxattr
 | 
				
			||||||
 | 
					192	common	lgetxattr		sys_lgetxattr
 | 
				
			||||||
 | 
					193	common	fgetxattr		sys_fgetxattr
 | 
				
			||||||
 | 
					194	common	listxattr		sys_listxattr
 | 
				
			||||||
 | 
					195	common	llistxattr		sys_llistxattr
 | 
				
			||||||
 | 
					196	common	flistxattr		sys_flistxattr
 | 
				
			||||||
 | 
					197	common	removexattr		sys_removexattr
 | 
				
			||||||
 | 
					198	common	lremovexattr		sys_lremovexattr
 | 
				
			||||||
 | 
					199	common	fremovexattr		sys_fremovexattr
 | 
				
			||||||
 | 
					200	common	tkill			sys_tkill
 | 
				
			||||||
 | 
					201	common	time			sys_time
 | 
				
			||||||
 | 
					202	common	futex			sys_futex
 | 
				
			||||||
 | 
					203	common	sched_setaffinity	sys_sched_setaffinity
 | 
				
			||||||
 | 
					204	common	sched_getaffinity	sys_sched_getaffinity
 | 
				
			||||||
 | 
					205	64	set_thread_area
 | 
				
			||||||
 | 
					206	64	io_setup		sys_io_setup
 | 
				
			||||||
 | 
					207	common	io_destroy		sys_io_destroy
 | 
				
			||||||
 | 
					208	common	io_getevents		sys_io_getevents
 | 
				
			||||||
 | 
					209	64	io_submit		sys_io_submit
 | 
				
			||||||
 | 
					210	common	io_cancel		sys_io_cancel
 | 
				
			||||||
 | 
					211	64	get_thread_area
 | 
				
			||||||
 | 
					212	common	lookup_dcookie		sys_lookup_dcookie
 | 
				
			||||||
 | 
					213	common	epoll_create		sys_epoll_create
 | 
				
			||||||
 | 
					214	64	epoll_ctl_old
 | 
				
			||||||
 | 
					215	64	epoll_wait_old
 | 
				
			||||||
 | 
					216	common	remap_file_pages	sys_remap_file_pages
 | 
				
			||||||
 | 
					217	common	getdents64		sys_getdents64
 | 
				
			||||||
 | 
					218	common	set_tid_address		sys_set_tid_address
 | 
				
			||||||
 | 
					219	common	restart_syscall		sys_restart_syscall
 | 
				
			||||||
 | 
					220	common	semtimedop		sys_semtimedop
 | 
				
			||||||
 | 
					221	common	fadvise64		sys_fadvise64
 | 
				
			||||||
 | 
					222	64	timer_create		sys_timer_create
 | 
				
			||||||
 | 
					223	common	timer_settime		sys_timer_settime
 | 
				
			||||||
 | 
					224	common	timer_gettime		sys_timer_gettime
 | 
				
			||||||
 | 
					225	common	timer_getoverrun	sys_timer_getoverrun
 | 
				
			||||||
 | 
					226	common	timer_delete		sys_timer_delete
 | 
				
			||||||
 | 
					227	common	clock_settime		sys_clock_settime
 | 
				
			||||||
 | 
					228	common	clock_gettime		sys_clock_gettime
 | 
				
			||||||
 | 
					229	common	clock_getres		sys_clock_getres
 | 
				
			||||||
 | 
					230	common	clock_nanosleep		sys_clock_nanosleep
 | 
				
			||||||
 | 
					231	common	exit_group		sys_exit_group
 | 
				
			||||||
 | 
					232	common	epoll_wait		sys_epoll_wait
 | 
				
			||||||
 | 
					233	common	epoll_ctl		sys_epoll_ctl
 | 
				
			||||||
 | 
					234	common	tgkill			sys_tgkill
 | 
				
			||||||
 | 
					235	common	utimes			sys_utimes
 | 
				
			||||||
 | 
					236	64	vserver
 | 
				
			||||||
 | 
					237	common	mbind			sys_mbind
 | 
				
			||||||
 | 
					238	common	set_mempolicy		sys_set_mempolicy
 | 
				
			||||||
 | 
					239	common	get_mempolicy		sys_get_mempolicy
 | 
				
			||||||
 | 
					240	common	mq_open			sys_mq_open
 | 
				
			||||||
 | 
					241	common	mq_unlink		sys_mq_unlink
 | 
				
			||||||
 | 
					242	common	mq_timedsend		sys_mq_timedsend
 | 
				
			||||||
 | 
					243	common	mq_timedreceive		sys_mq_timedreceive
 | 
				
			||||||
 | 
					244	64	mq_notify		sys_mq_notify
 | 
				
			||||||
 | 
					245	common	mq_getsetattr		sys_mq_getsetattr
 | 
				
			||||||
 | 
					246	64	kexec_load		sys_kexec_load
 | 
				
			||||||
 | 
					247	64	waitid			sys_waitid
 | 
				
			||||||
 | 
					248	common	add_key			sys_add_key
 | 
				
			||||||
 | 
					249	common	request_key		sys_request_key
 | 
				
			||||||
 | 
					250	common	keyctl			sys_keyctl
 | 
				
			||||||
 | 
					251	common	ioprio_set		sys_ioprio_set
 | 
				
			||||||
 | 
					252	common	ioprio_get		sys_ioprio_get
 | 
				
			||||||
 | 
					253	common	inotify_init		sys_inotify_init
 | 
				
			||||||
 | 
					254	common	inotify_add_watch	sys_inotify_add_watch
 | 
				
			||||||
 | 
					255	common	inotify_rm_watch	sys_inotify_rm_watch
 | 
				
			||||||
 | 
					256	common	migrate_pages		sys_migrate_pages
 | 
				
			||||||
 | 
					257	common	openat			sys_openat
 | 
				
			||||||
 | 
					258	common	mkdirat			sys_mkdirat
 | 
				
			||||||
 | 
					259	common	mknodat			sys_mknodat
 | 
				
			||||||
 | 
					260	common	fchownat		sys_fchownat
 | 
				
			||||||
 | 
					261	common	futimesat		sys_futimesat
 | 
				
			||||||
 | 
					262	common	newfstatat		sys_newfstatat
 | 
				
			||||||
 | 
					263	common	unlinkat		sys_unlinkat
 | 
				
			||||||
 | 
					264	common	renameat		sys_renameat
 | 
				
			||||||
 | 
					265	common	linkat			sys_linkat
 | 
				
			||||||
 | 
					266	common	symlinkat		sys_symlinkat
 | 
				
			||||||
 | 
					267	common	readlinkat		sys_readlinkat
 | 
				
			||||||
 | 
					268	common	fchmodat		sys_fchmodat
 | 
				
			||||||
 | 
					269	common	faccessat		sys_faccessat
 | 
				
			||||||
 | 
					270	common	pselect6		sys_pselect6
 | 
				
			||||||
 | 
					271	common	ppoll			sys_ppoll
 | 
				
			||||||
 | 
					272	common	unshare			sys_unshare
 | 
				
			||||||
 | 
					273	64	set_robust_list		sys_set_robust_list
 | 
				
			||||||
 | 
					274	64	get_robust_list		sys_get_robust_list
 | 
				
			||||||
 | 
					275	common	splice			sys_splice
 | 
				
			||||||
 | 
					276	common	tee			sys_tee
 | 
				
			||||||
 | 
					277	common	sync_file_range		sys_sync_file_range
 | 
				
			||||||
 | 
					278	64	vmsplice		sys_vmsplice
 | 
				
			||||||
 | 
					279	64	move_pages		sys_move_pages
 | 
				
			||||||
 | 
					280	common	utimensat		sys_utimensat
 | 
				
			||||||
 | 
					281	common	epoll_pwait		sys_epoll_pwait
 | 
				
			||||||
 | 
					282	common	signalfd		sys_signalfd
 | 
				
			||||||
 | 
					283	common	timerfd_create		sys_timerfd_create
 | 
				
			||||||
 | 
					284	common	eventfd			sys_eventfd
 | 
				
			||||||
 | 
					285	common	fallocate		sys_fallocate
 | 
				
			||||||
 | 
					286	common	timerfd_settime		sys_timerfd_settime
 | 
				
			||||||
 | 
					287	common	timerfd_gettime		sys_timerfd_gettime
 | 
				
			||||||
 | 
					288	common	accept4			sys_accept4
 | 
				
			||||||
 | 
					289	common	signalfd4		sys_signalfd4
 | 
				
			||||||
 | 
					290	common	eventfd2		sys_eventfd2
 | 
				
			||||||
 | 
					291	common	epoll_create1		sys_epoll_create1
 | 
				
			||||||
 | 
					292	common	dup3			sys_dup3
 | 
				
			||||||
 | 
					293	common	pipe2			sys_pipe2
 | 
				
			||||||
 | 
					294	common	inotify_init1		sys_inotify_init1
 | 
				
			||||||
 | 
					295	64	preadv			sys_preadv
 | 
				
			||||||
 | 
					296	64	pwritev			sys_pwritev
 | 
				
			||||||
 | 
					297	64	rt_tgsigqueueinfo	sys_rt_tgsigqueueinfo
 | 
				
			||||||
 | 
					298	common	perf_event_open		sys_perf_event_open
 | 
				
			||||||
 | 
					299	64	recvmmsg		sys_recvmmsg
 | 
				
			||||||
 | 
					300	common	fanotify_init		sys_fanotify_init
 | 
				
			||||||
 | 
					301	common	fanotify_mark		sys_fanotify_mark
 | 
				
			||||||
 | 
					302	common	prlimit64		sys_prlimit64
 | 
				
			||||||
 | 
					303	common	name_to_handle_at	sys_name_to_handle_at
 | 
				
			||||||
 | 
					304	common	open_by_handle_at	sys_open_by_handle_at
 | 
				
			||||||
 | 
					305	common	clock_adjtime		sys_clock_adjtime
 | 
				
			||||||
 | 
					306	common	syncfs			sys_syncfs
 | 
				
			||||||
 | 
					307	64	sendmmsg		sys_sendmmsg
 | 
				
			||||||
 | 
					308	common	setns			sys_setns
 | 
				
			||||||
 | 
					309	common	getcpu			sys_getcpu
 | 
				
			||||||
 | 
					310	64	process_vm_readv	sys_process_vm_readv
 | 
				
			||||||
 | 
					311	64	process_vm_writev	sys_process_vm_writev
 | 
				
			||||||
 | 
					312	common	kcmp			sys_kcmp
 | 
				
			||||||
 | 
					313	common	finit_module		sys_finit_module
 | 
				
			||||||
 | 
					314	common	sched_setattr		sys_sched_setattr
 | 
				
			||||||
 | 
					315	common	sched_getattr		sys_sched_getattr
 | 
				
			||||||
 | 
					316	common	renameat2		sys_renameat2
 | 
				
			||||||
 | 
					317	common	seccomp			sys_seccomp
 | 
				
			||||||
 | 
					318	common	getrandom		sys_getrandom
 | 
				
			||||||
 | 
					319	common	memfd_create		sys_memfd_create
 | 
				
			||||||
 | 
					320	common	kexec_file_load		sys_kexec_file_load
 | 
				
			||||||
 | 
					321	common	bpf			sys_bpf
 | 
				
			||||||
 | 
					322	64	execveat		sys_execveat/ptregs
 | 
				
			||||||
 | 
					323	common	userfaultfd		sys_userfaultfd
 | 
				
			||||||
 | 
					324	common	membarrier		sys_membarrier
 | 
				
			||||||
 | 
					325	common	mlock2			sys_mlock2
 | 
				
			||||||
 | 
					326	common	copy_file_range		sys_copy_file_range
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# x32-specific system call numbers start at 512 to avoid cache impact
 | 
				
			||||||
 | 
					# for native 64-bit operation.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					512	x32	rt_sigaction		compat_sys_rt_sigaction
 | 
				
			||||||
 | 
					513	x32	rt_sigreturn		sys32_x32_rt_sigreturn
 | 
				
			||||||
 | 
					514	x32	ioctl			compat_sys_ioctl
 | 
				
			||||||
 | 
					515	x32	readv			compat_sys_readv
 | 
				
			||||||
 | 
					516	x32	writev			compat_sys_writev
 | 
				
			||||||
 | 
					517	x32	recvfrom		compat_sys_recvfrom
 | 
				
			||||||
 | 
					518	x32	sendmsg			compat_sys_sendmsg
 | 
				
			||||||
 | 
					519	x32	recvmsg			compat_sys_recvmsg
 | 
				
			||||||
 | 
					520	x32	execve			compat_sys_execve/ptregs
 | 
				
			||||||
 | 
					521	x32	ptrace			compat_sys_ptrace
 | 
				
			||||||
 | 
					522	x32	rt_sigpending		compat_sys_rt_sigpending
 | 
				
			||||||
 | 
					523	x32	rt_sigtimedwait		compat_sys_rt_sigtimedwait
 | 
				
			||||||
 | 
					524	x32	rt_sigqueueinfo		compat_sys_rt_sigqueueinfo
 | 
				
			||||||
 | 
					525	x32	sigaltstack		compat_sys_sigaltstack
 | 
				
			||||||
 | 
					526	x32	timer_create		compat_sys_timer_create
 | 
				
			||||||
 | 
					527	x32	mq_notify		compat_sys_mq_notify
 | 
				
			||||||
 | 
					528	x32	kexec_load		compat_sys_kexec_load
 | 
				
			||||||
 | 
					529	x32	waitid			compat_sys_waitid
 | 
				
			||||||
 | 
					530	x32	set_robust_list		compat_sys_set_robust_list
 | 
				
			||||||
 | 
					531	x32	get_robust_list		compat_sys_get_robust_list
 | 
				
			||||||
 | 
					532	x32	vmsplice		compat_sys_vmsplice
 | 
				
			||||||
 | 
					533	x32	move_pages		compat_sys_move_pages
 | 
				
			||||||
 | 
					534	x32	preadv			compat_sys_preadv64
 | 
				
			||||||
 | 
					535	x32	pwritev			compat_sys_pwritev64
 | 
				
			||||||
 | 
					536	x32	rt_tgsigqueueinfo	compat_sys_rt_tgsigqueueinfo
 | 
				
			||||||
 | 
					537	x32	recvmmsg		compat_sys_recvmmsg
 | 
				
			||||||
 | 
					538	x32	sendmmsg		compat_sys_sendmmsg
 | 
				
			||||||
 | 
					539	x32	process_vm_readv	compat_sys_process_vm_readv
 | 
				
			||||||
 | 
					540	x32	process_vm_writev	compat_sys_process_vm_writev
 | 
				
			||||||
 | 
					541	x32	setsockopt		compat_sys_setsockopt
 | 
				
			||||||
 | 
					542	x32	getsockopt		compat_sys_getsockopt
 | 
				
			||||||
 | 
					543	x32	io_setup		compat_sys_io_setup
 | 
				
			||||||
 | 
					544	x32	io_submit		compat_sys_io_submit
 | 
				
			||||||
 | 
					545	x32	execveat		compat_sys_execveat/ptregs
 | 
				
			||||||
							
								
								
									
										39
									
								
								tools/perf/arch/x86/entry/syscalls/syscalltbl.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										39
									
								
								tools/perf/arch/x86/entry/syscalls/syscalltbl.sh
									
									
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,39 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					in="$1"
 | 
				
			||||||
 | 
					arch="$2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					syscall_macro() {
 | 
				
			||||||
 | 
					    nr="$1"
 | 
				
			||||||
 | 
					    name="$2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    echo "	[$nr] = \"$name\","
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					emit() {
 | 
				
			||||||
 | 
					    nr="$1"
 | 
				
			||||||
 | 
					    entry="$2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    syscall_macro "$nr" "$entry"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					echo "static const char *syscalltbl_${arch}[] = {"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sorted_table=$(mktemp /tmp/syscalltbl.XXXXXX)
 | 
				
			||||||
 | 
					grep '^[0-9]' "$in" | sort -n > $sorted_table
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					max_nr=0
 | 
				
			||||||
 | 
					while read nr abi name entry compat; do
 | 
				
			||||||
 | 
					    if [ $nr -ge 512 ] ; then # discard compat sycalls
 | 
				
			||||||
 | 
					        break
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    emit "$nr" "$name"
 | 
				
			||||||
 | 
					    max_nr=$nr
 | 
				
			||||||
 | 
					done < $sorted_table
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					rm -f $sorted_table
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					echo "};"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					echo "#define SYSCALLTBL_${arch}_MAX_ID ${max_nr}"
 | 
				
			||||||
| 
						 | 
					@ -27,7 +27,7 @@ NO_PERF_REGS := 1
 | 
				
			||||||
ifeq ($(ARCH),x86)
 | 
					ifeq ($(ARCH),x86)
 | 
				
			||||||
  $(call detected,CONFIG_X86)
 | 
					  $(call detected,CONFIG_X86)
 | 
				
			||||||
  ifeq (${IS_64_BIT}, 1)
 | 
					  ifeq (${IS_64_BIT}, 1)
 | 
				
			||||||
    CFLAGS += -DHAVE_ARCH_X86_64_SUPPORT
 | 
					    CFLAGS += -DHAVE_ARCH_X86_64_SUPPORT -DHAVE_SYSCALL_TABLE -I$(OUTPUT)arch/x86/include/generated
 | 
				
			||||||
    ARCH_INCLUDE = ../../arch/x86/lib/memcpy_64.S ../../arch/x86/lib/memset_64.S
 | 
					    ARCH_INCLUDE = ../../arch/x86/lib/memcpy_64.S ../../arch/x86/lib/memset_64.S
 | 
				
			||||||
    LIBUNWIND_LIBS = -lunwind -lunwind-x86_64
 | 
					    LIBUNWIND_LIBS = -lunwind -lunwind-x86_64
 | 
				
			||||||
    $(call detected,CONFIG_X86_64)
 | 
					    $(call detected,CONFIG_X86_64)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -148,6 +148,10 @@ CFLAGS_libstring.o     += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ET
 | 
				
			||||||
CFLAGS_hweight.o       += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
 | 
					CFLAGS_hweight.o       += -Wno-unused-parameter -DETC_PERFCONFIG="BUILD_STR($(ETC_PERFCONFIG_SQ))"
 | 
				
			||||||
CFLAGS_parse-events.o  += -Wno-redundant-decls
 | 
					CFLAGS_parse-events.o  += -Wno-redundant-decls
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(OUTPUT)util/syscalltbl.o: util/syscalltbl.c arch/x86/entry/syscalls/syscall_64.tbl $(OUTPUT)arch/x86/include/generated/asm/syscalls_64.c FORCE
 | 
				
			||||||
 | 
						$(call rule_mkdir)
 | 
				
			||||||
 | 
						$(call if_changed_dep,cc_o_c)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(OUTPUT)util/kallsyms.o: ../lib/symbol/kallsyms.c FORCE
 | 
					$(OUTPUT)util/kallsyms.o: ../lib/symbol/kallsyms.c FORCE
 | 
				
			||||||
	$(call rule_mkdir)
 | 
						$(call rule_mkdir)
 | 
				
			||||||
	$(call if_changed_dep,cc_o_c)
 | 
						$(call if_changed_dep,cc_o_c)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -21,6 +21,12 @@
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(__x86_64__)
 | 
				
			||||||
 | 
					#include <asm/syscalls_64.c>
 | 
				
			||||||
 | 
					const int syscalltbl_native_max_id = SYSCALLTBL_x86_64_MAX_ID;
 | 
				
			||||||
 | 
					static const char **syscalltbl_native = syscalltbl_x86_64;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct syscall {
 | 
					struct syscall {
 | 
				
			||||||
	int id;
 | 
						int id;
 | 
				
			||||||
	const char *name;
 | 
						const char *name;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue