7b21fddd08
32bit and 64bit on x86 are tested and working. The rest I have looked at closely and I can't find any problems. setns is an easy system call to wire up. It just takes two ints so I don't expect any weird architecture porting problems. While doing this I have noticed that we have some architectures that are very slow to get new system calls. cris seems to be the slowest where the last system calls wired up were preadv and pwritev. avr32 is weird in that recvmmsg was wired up but never declared in unistd.h. frv is behind with perf_event_open being the last syscall wired up. On h8300 the last system call wired up was epoll_wait. On m32r the last system call wired up was fallocate. mn10300 has recvmmsg as the last system call wired up. The rest seem to at least have syncfs wired up which was new in the 2.6.39. v2: Most of the architecture support added by Daniel Lezcano <dlezcano@fr.ibm.com> v3: ported to v2.6.36-rc4 by: Eric W. Biederman <ebiederm@xmission.com> v4: Moved wiring up of the system call to another patch v5: ported to v2.6.39-rc6 v6: rebased onto parisc-next and net-next to avoid syscall conflicts. v7: ported to Linus's latest post 2.6.39 tree. > arch/blackfin/include/asm/unistd.h | 3 ++- > arch/blackfin/mach-common/entry.S | 1 + Acked-by: Mike Frysinger <vapier@gentoo.org> Oh - ia64 wiring looks good. Acked-by: Tony Luck <tony.luck@intel.com> Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
1913 lines
49 KiB
ArmAsm
1913 lines
49 KiB
ArmAsm
/*
|
|
* arch/s390/kernel/compat_wrapper.S
|
|
* wrapper for 31 bit compatible system calls.
|
|
*
|
|
* Copyright (C) IBM Corp. 2000,2006
|
|
* Author(s): Gerhard Tonn (ton@de.ibm.com),
|
|
* Thomas Spatzier (tspat@de.ibm.com)
|
|
*/
|
|
|
|
.globl sys32_exit_wrapper
|
|
sys32_exit_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_exit # branch to sys_exit
|
|
|
|
.globl sys32_read_wrapper
|
|
sys32_read_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
jg sys32_read # branch to sys_read
|
|
|
|
.globl sys32_write_wrapper
|
|
sys32_write_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # size_t
|
|
jg sys32_write # branch to system call
|
|
|
|
.globl sys32_open_wrapper
|
|
sys32_open_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
jg sys_open # branch to system call
|
|
|
|
.globl sys32_close_wrapper
|
|
sys32_close_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_close # branch to system call
|
|
|
|
.globl sys32_creat_wrapper
|
|
sys32_creat_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_creat # branch to system call
|
|
|
|
.globl sys32_link_wrapper
|
|
sys32_link_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
jg sys_link # branch to system call
|
|
|
|
.globl sys32_unlink_wrapper
|
|
sys32_unlink_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_unlink # branch to system call
|
|
|
|
.globl sys32_chdir_wrapper
|
|
sys32_chdir_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_chdir # branch to system call
|
|
|
|
.globl sys32_time_wrapper
|
|
sys32_time_wrapper:
|
|
llgtr %r2,%r2 # int *
|
|
jg compat_sys_time # branch to system call
|
|
|
|
.globl sys32_mknod_wrapper
|
|
sys32_mknod_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
llgfr %r4,%r4 # dev
|
|
jg sys_mknod # branch to system call
|
|
|
|
.globl sys32_chmod_wrapper
|
|
sys32_chmod_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # mode_t
|
|
jg sys_chmod # branch to system call
|
|
|
|
.globl sys32_lchown16_wrapper
|
|
sys32_lchown16_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # __kernel_old_uid_emu31_t
|
|
llgfr %r4,%r4 # __kernel_old_uid_emu31_t
|
|
jg sys32_lchown16 # branch to system call
|
|
|
|
.globl sys32_lseek_wrapper
|
|
sys32_lseek_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
lgfr %r3,%r3 # off_t
|
|
llgfr %r4,%r4 # unsigned int
|
|
jg sys_lseek # branch to system call
|
|
|
|
#sys32_getpid_wrapper # void
|
|
|
|
.globl sys32_mount_wrapper
|
|
sys32_mount_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # char *
|
|
llgfr %r5,%r5 # unsigned long
|
|
llgtr %r6,%r6 # void *
|
|
jg compat_sys_mount # branch to system call
|
|
|
|
.globl sys32_oldumount_wrapper
|
|
sys32_oldumount_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
jg sys_oldumount # branch to system call
|
|
|
|
.globl sys32_setuid16_wrapper
|
|
sys32_setuid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_uid_emu31_t
|
|
jg sys32_setuid16 # branch to system call
|
|
|
|
#sys32_getuid16_wrapper # void
|
|
|
|
.globl sys32_ptrace_wrapper
|
|
sys32_ptrace_wrapper:
|
|
lgfr %r2,%r2 # long
|
|
lgfr %r3,%r3 # long
|
|
llgtr %r4,%r4 # long
|
|
llgfr %r5,%r5 # long
|
|
jg compat_sys_ptrace # branch to system call
|
|
|
|
.globl sys32_alarm_wrapper
|
|
sys32_alarm_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_alarm # branch to system call
|
|
|
|
.globl compat_sys_utime_wrapper
|
|
compat_sys_utime_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct compat_utimbuf *
|
|
jg compat_sys_utime # branch to system call
|
|
|
|
.globl sys32_access_wrapper
|
|
sys32_access_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_access # branch to system call
|
|
|
|
.globl sys32_nice_wrapper
|
|
sys32_nice_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_nice # branch to system call
|
|
|
|
#sys32_sync_wrapper # void
|
|
|
|
.globl sys32_kill_wrapper
|
|
sys32_kill_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_kill # branch to system call
|
|
|
|
.globl sys32_rename_wrapper
|
|
sys32_rename_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
jg sys_rename # branch to system call
|
|
|
|
.globl sys32_mkdir_wrapper
|
|
sys32_mkdir_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_mkdir # branch to system call
|
|
|
|
.globl sys32_rmdir_wrapper
|
|
sys32_rmdir_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_rmdir # branch to system call
|
|
|
|
.globl sys32_dup_wrapper
|
|
sys32_dup_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_dup # branch to system call
|
|
|
|
.globl sys32_pipe_wrapper
|
|
sys32_pipe_wrapper:
|
|
llgtr %r2,%r2 # u32 *
|
|
jg sys_pipe # branch to system call
|
|
|
|
.globl compat_sys_times_wrapper
|
|
compat_sys_times_wrapper:
|
|
llgtr %r2,%r2 # struct compat_tms *
|
|
jg compat_sys_times # branch to system call
|
|
|
|
.globl sys32_brk_wrapper
|
|
sys32_brk_wrapper:
|
|
llgtr %r2,%r2 # unsigned long
|
|
jg sys_brk # branch to system call
|
|
|
|
.globl sys32_setgid16_wrapper
|
|
sys32_setgid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_gid_emu31_t
|
|
jg sys32_setgid16 # branch to system call
|
|
|
|
#sys32_getgid16_wrapper # void
|
|
|
|
.globl sys32_signal_wrapper
|
|
sys32_signal_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # __sighandler_t
|
|
jg sys_signal
|
|
|
|
#sys32_geteuid16_wrapper # void
|
|
|
|
#sys32_getegid16_wrapper # void
|
|
|
|
.globl sys32_acct_wrapper
|
|
sys32_acct_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
jg sys_acct # branch to system call
|
|
|
|
.globl sys32_umount_wrapper
|
|
sys32_umount_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_umount # branch to system call
|
|
|
|
.globl compat_sys_ioctl_wrapper
|
|
compat_sys_ioctl_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgfr %r4,%r4 # unsigned int
|
|
jg compat_sys_ioctl # branch to system call
|
|
|
|
.globl compat_sys_fcntl_wrapper
|
|
compat_sys_fcntl_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg compat_sys_fcntl # branch to system call
|
|
|
|
.globl sys32_setpgid_wrapper
|
|
sys32_setpgid_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
lgfr %r3,%r3 # pid_t
|
|
jg sys_setpgid # branch to system call
|
|
|
|
.globl sys32_umask_wrapper
|
|
sys32_umask_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_umask # branch to system call
|
|
|
|
.globl sys32_chroot_wrapper
|
|
sys32_chroot_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
jg sys_chroot # branch to system call
|
|
|
|
.globl sys32_ustat_wrapper
|
|
sys32_ustat_wrapper:
|
|
llgfr %r2,%r2 # dev_t
|
|
llgtr %r3,%r3 # struct ustat *
|
|
jg compat_sys_ustat
|
|
|
|
.globl sys32_dup2_wrapper
|
|
sys32_dup2_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
jg sys_dup2 # branch to system call
|
|
|
|
#sys32_getppid_wrapper # void
|
|
|
|
#sys32_getpgrp_wrapper # void
|
|
|
|
#sys32_setsid_wrapper # void
|
|
|
|
.globl sys32_sigaction_wrapper
|
|
sys32_sigaction_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const struct old_sigaction *
|
|
llgtr %r4,%r4 # struct old_sigaction32 *
|
|
jg sys32_sigaction # branch to system call
|
|
|
|
.globl sys32_setreuid16_wrapper
|
|
sys32_setreuid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_uid_emu31_t
|
|
llgfr %r3,%r3 # __kernel_old_uid_emu31_t
|
|
jg sys32_setreuid16 # branch to system call
|
|
|
|
.globl sys32_setregid16_wrapper
|
|
sys32_setregid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_gid_emu31_t
|
|
llgfr %r3,%r3 # __kernel_old_gid_emu31_t
|
|
jg sys32_setregid16 # branch to system call
|
|
|
|
.globl sys_sigsuspend_wrapper
|
|
sys_sigsuspend_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgfr %r4,%r4 # old_sigset_t
|
|
jg sys_sigsuspend
|
|
|
|
.globl compat_sys_sigpending_wrapper
|
|
compat_sys_sigpending_wrapper:
|
|
llgtr %r2,%r2 # compat_old_sigset_t *
|
|
jg compat_sys_sigpending # branch to system call
|
|
|
|
.globl sys32_sethostname_wrapper
|
|
sys32_sethostname_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_sethostname # branch to system call
|
|
|
|
.globl compat_sys_setrlimit_wrapper
|
|
compat_sys_setrlimit_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # struct rlimit_emu31 *
|
|
jg compat_sys_setrlimit # branch to system call
|
|
|
|
.globl compat_sys_old_getrlimit_wrapper
|
|
compat_sys_old_getrlimit_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # struct rlimit_emu31 *
|
|
jg compat_sys_old_getrlimit # branch to system call
|
|
|
|
.globl compat_sys_getrlimit_wrapper
|
|
compat_sys_getrlimit_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # struct rlimit_emu31 *
|
|
jg compat_sys_getrlimit # branch to system call
|
|
|
|
.globl sys32_mmap2_wrapper
|
|
sys32_mmap2_wrapper:
|
|
llgtr %r2,%r2 # struct mmap_arg_struct_emu31 *
|
|
jg sys32_mmap2 # branch to system call
|
|
|
|
.globl compat_sys_getrusage_wrapper
|
|
compat_sys_getrusage_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct rusage_emu31 *
|
|
jg compat_sys_getrusage # branch to system call
|
|
|
|
.globl compat_sys_gettimeofday_wrapper
|
|
compat_sys_gettimeofday_wrapper:
|
|
llgtr %r2,%r2 # struct timeval_emu31 *
|
|
llgtr %r3,%r3 # struct timezone *
|
|
jg compat_sys_gettimeofday # branch to system call
|
|
|
|
.globl compat_sys_settimeofday_wrapper
|
|
compat_sys_settimeofday_wrapper:
|
|
llgtr %r2,%r2 # struct timeval_emu31 *
|
|
llgtr %r3,%r3 # struct timezone *
|
|
jg compat_sys_settimeofday # branch to system call
|
|
|
|
.globl sys32_getgroups16_wrapper
|
|
sys32_getgroups16_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # __kernel_old_gid_emu31_t *
|
|
jg sys32_getgroups16 # branch to system call
|
|
|
|
.globl sys32_setgroups16_wrapper
|
|
sys32_setgroups16_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # __kernel_old_gid_emu31_t *
|
|
jg sys32_setgroups16 # branch to system call
|
|
|
|
.globl sys32_symlink_wrapper
|
|
sys32_symlink_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
jg sys_symlink # branch to system call
|
|
|
|
.globl sys32_readlink_wrapper
|
|
sys32_readlink_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # char *
|
|
lgfr %r4,%r4 # int
|
|
jg sys_readlink # branch to system call
|
|
|
|
.globl sys32_uselib_wrapper
|
|
sys32_uselib_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_uselib # branch to system call
|
|
|
|
.globl sys32_swapon_wrapper
|
|
sys32_swapon_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_swapon # branch to system call
|
|
|
|
.globl sys32_reboot_wrapper
|
|
sys32_reboot_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgfr %r4,%r4 # unsigned int
|
|
llgtr %r5,%r5 # void *
|
|
jg sys_reboot # branch to system call
|
|
|
|
.globl old32_readdir_wrapper
|
|
old32_readdir_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # void *
|
|
llgfr %r4,%r4 # unsigned int
|
|
jg compat_sys_old_readdir # branch to system call
|
|
|
|
.globl old32_mmap_wrapper
|
|
old32_mmap_wrapper:
|
|
llgtr %r2,%r2 # struct mmap_arg_struct_emu31 *
|
|
jg old32_mmap # branch to system call
|
|
|
|
.globl sys32_munmap_wrapper
|
|
sys32_munmap_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
jg sys_munmap # branch to system call
|
|
|
|
.globl sys32_truncate_wrapper
|
|
sys32_truncate_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # long
|
|
jg sys_truncate # branch to system call
|
|
|
|
.globl sys32_ftruncate_wrapper
|
|
sys32_ftruncate_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned long
|
|
jg sys_ftruncate # branch to system call
|
|
|
|
.globl sys32_fchmod_wrapper
|
|
sys32_fchmod_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # mode_t
|
|
jg sys_fchmod # branch to system call
|
|
|
|
.globl sys32_fchown16_wrapper
|
|
sys32_fchown16_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # compat_uid_t
|
|
llgfr %r4,%r4 # compat_uid_t
|
|
jg sys32_fchown16 # branch to system call
|
|
|
|
.globl sys32_getpriority_wrapper
|
|
sys32_getpriority_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_getpriority # branch to system call
|
|
|
|
.globl sys32_setpriority_wrapper
|
|
sys32_setpriority_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
jg sys_setpriority # branch to system call
|
|
|
|
.globl compat_sys_statfs_wrapper
|
|
compat_sys_statfs_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct compat_statfs *
|
|
jg compat_sys_statfs # branch to system call
|
|
|
|
.globl compat_sys_fstatfs_wrapper
|
|
compat_sys_fstatfs_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # struct compat_statfs *
|
|
jg compat_sys_fstatfs # branch to system call
|
|
|
|
.globl compat_sys_socketcall_wrapper
|
|
compat_sys_socketcall_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # u32 *
|
|
jg compat_sys_socketcall # branch to system call
|
|
|
|
.globl sys32_syslog_wrapper
|
|
sys32_syslog_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # char *
|
|
lgfr %r4,%r4 # int
|
|
jg sys_syslog # branch to system call
|
|
|
|
.globl compat_sys_setitimer_wrapper
|
|
compat_sys_setitimer_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct itimerval_emu31 *
|
|
llgtr %r4,%r4 # struct itimerval_emu31 *
|
|
jg compat_sys_setitimer # branch to system call
|
|
|
|
.globl compat_sys_getitimer_wrapper
|
|
compat_sys_getitimer_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct itimerval_emu31 *
|
|
jg compat_sys_getitimer # branch to system call
|
|
|
|
.globl compat_sys_newstat_wrapper
|
|
compat_sys_newstat_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct stat_emu31 *
|
|
jg compat_sys_newstat # branch to system call
|
|
|
|
.globl compat_sys_newlstat_wrapper
|
|
compat_sys_newlstat_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct stat_emu31 *
|
|
jg compat_sys_newlstat # branch to system call
|
|
|
|
.globl compat_sys_newfstat_wrapper
|
|
compat_sys_newfstat_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # struct stat_emu31 *
|
|
jg compat_sys_newfstat # branch to system call
|
|
|
|
#sys32_vhangup_wrapper # void
|
|
|
|
.globl compat_sys_wait4_wrapper
|
|
compat_sys_wait4_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
llgtr %r3,%r3 # unsigned int *
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # struct rusage *
|
|
jg compat_sys_wait4 # branch to system call
|
|
|
|
.globl sys32_swapoff_wrapper
|
|
sys32_swapoff_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_swapoff # branch to system call
|
|
|
|
.globl compat_sys_sysinfo_wrapper
|
|
compat_sys_sysinfo_wrapper:
|
|
llgtr %r2,%r2 # struct sysinfo_emu31 *
|
|
jg compat_sys_sysinfo # branch to system call
|
|
|
|
.globl sys32_ipc_wrapper
|
|
sys32_ipc_wrapper:
|
|
llgfr %r2,%r2 # uint
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
lgfr %r5,%r5 # int
|
|
llgfr %r6,%r6 # u32
|
|
jg sys32_ipc # branch to system call
|
|
|
|
.globl sys32_fsync_wrapper
|
|
sys32_fsync_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_fsync # branch to system call
|
|
|
|
#sys32_sigreturn_wrapper # done in sigreturn_glue
|
|
|
|
#sys32_clone_wrapper # done in clone_glue
|
|
|
|
.globl sys32_setdomainname_wrapper
|
|
sys32_setdomainname_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_setdomainname # branch to system call
|
|
|
|
.globl sys32_newuname_wrapper
|
|
sys32_newuname_wrapper:
|
|
llgtr %r2,%r2 # struct new_utsname *
|
|
jg sys_newuname # branch to system call
|
|
|
|
.globl compat_sys_adjtimex_wrapper
|
|
compat_sys_adjtimex_wrapper:
|
|
llgtr %r2,%r2 # struct compat_timex *
|
|
jg compat_sys_adjtimex # branch to system call
|
|
|
|
.globl sys32_mprotect_wrapper
|
|
sys32_mprotect_wrapper:
|
|
llgtr %r2,%r2 # unsigned long (actually pointer
|
|
llgfr %r3,%r3 # size_t
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg sys_mprotect # branch to system call
|
|
|
|
.globl compat_sys_sigprocmask_wrapper
|
|
compat_sys_sigprocmask_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_old_sigset_t *
|
|
llgtr %r4,%r4 # compat_old_sigset_t *
|
|
jg compat_sys_sigprocmask # branch to system call
|
|
|
|
.globl sys_init_module_wrapper
|
|
sys_init_module_wrapper:
|
|
llgtr %r2,%r2 # void *
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgtr %r4,%r4 # char *
|
|
jg sys_init_module # branch to system call
|
|
|
|
.globl sys_delete_module_wrapper
|
|
sys_delete_module_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # unsigned int
|
|
jg sys_delete_module # branch to system call
|
|
|
|
.globl sys32_quotactl_wrapper
|
|
sys32_quotactl_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # qid_t
|
|
llgtr %r5,%r5 # caddr_t
|
|
jg sys_quotactl # branch to system call
|
|
|
|
.globl sys32_getpgid_wrapper
|
|
sys32_getpgid_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
jg sys_getpgid # branch to system call
|
|
|
|
.globl sys32_fchdir_wrapper
|
|
sys32_fchdir_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_fchdir # branch to system call
|
|
|
|
.globl sys32_bdflush_wrapper
|
|
sys32_bdflush_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # long
|
|
jg sys_bdflush # branch to system call
|
|
|
|
.globl sys32_sysfs_wrapper
|
|
sys32_sysfs_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg sys_sysfs # branch to system call
|
|
|
|
.globl sys32_personality_wrapper
|
|
sys32_personality_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_s390_personality # branch to system call
|
|
|
|
.globl sys32_setfsuid16_wrapper
|
|
sys32_setfsuid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_uid_emu31_t
|
|
jg sys32_setfsuid16 # branch to system call
|
|
|
|
.globl sys32_setfsgid16_wrapper
|
|
sys32_setfsgid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_gid_emu31_t
|
|
jg sys32_setfsgid16 # branch to system call
|
|
|
|
.globl sys32_llseek_wrapper
|
|
sys32_llseek_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgtr %r5,%r5 # loff_t *
|
|
llgfr %r6,%r6 # unsigned int
|
|
jg sys_llseek # branch to system call
|
|
|
|
.globl sys32_getdents_wrapper
|
|
sys32_getdents_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # void *
|
|
llgfr %r4,%r4 # unsigned int
|
|
jg compat_sys_getdents # branch to system call
|
|
|
|
.globl compat_sys_select_wrapper
|
|
compat_sys_select_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_fd_set *
|
|
llgtr %r4,%r4 # compat_fd_set *
|
|
llgtr %r5,%r5 # compat_fd_set *
|
|
llgtr %r6,%r6 # struct compat_timeval *
|
|
jg compat_sys_select # branch to system call
|
|
|
|
.globl sys32_flock_wrapper
|
|
sys32_flock_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
jg sys_flock # branch to system call
|
|
|
|
.globl sys32_msync_wrapper
|
|
sys32_msync_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
lgfr %r4,%r4 # int
|
|
jg sys_msync # branch to system call
|
|
|
|
.globl compat_sys_readv_wrapper
|
|
compat_sys_readv_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const struct compat_iovec *
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg compat_sys_readv # branch to system call
|
|
|
|
.globl compat_sys_writev_wrapper
|
|
compat_sys_writev_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const struct compat_iovec *
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg compat_sys_writev # branch to system call
|
|
|
|
.globl sys32_getsid_wrapper
|
|
sys32_getsid_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
jg sys_getsid # branch to system call
|
|
|
|
.globl sys32_fdatasync_wrapper
|
|
sys32_fdatasync_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_fdatasync # branch to system call
|
|
|
|
.globl sys32_mlock_wrapper
|
|
sys32_mlock_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
jg sys_mlock # branch to system call
|
|
|
|
.globl sys32_munlock_wrapper
|
|
sys32_munlock_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
jg sys_munlock # branch to system call
|
|
|
|
.globl sys32_mlockall_wrapper
|
|
sys32_mlockall_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_mlockall # branch to system call
|
|
|
|
#sys32_munlockall_wrapper # void
|
|
|
|
.globl sys32_sched_setparam_wrapper
|
|
sys32_sched_setparam_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
llgtr %r3,%r3 # struct sched_param *
|
|
jg sys_sched_setparam # branch to system call
|
|
|
|
.globl sys32_sched_getparam_wrapper
|
|
sys32_sched_getparam_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
llgtr %r3,%r3 # struct sched_param *
|
|
jg sys_sched_getparam # branch to system call
|
|
|
|
.globl sys32_sched_setscheduler_wrapper
|
|
sys32_sched_setscheduler_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # struct sched_param *
|
|
jg sys_sched_setscheduler # branch to system call
|
|
|
|
.globl sys32_sched_getscheduler_wrapper
|
|
sys32_sched_getscheduler_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
jg sys_sched_getscheduler # branch to system call
|
|
|
|
#sys32_sched_yield_wrapper # void
|
|
|
|
.globl sys32_sched_get_priority_max_wrapper
|
|
sys32_sched_get_priority_max_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_sched_get_priority_max # branch to system call
|
|
|
|
.globl sys32_sched_get_priority_min_wrapper
|
|
sys32_sched_get_priority_min_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_sched_get_priority_min # branch to system call
|
|
|
|
.globl sys32_sched_rr_get_interval_wrapper
|
|
sys32_sched_rr_get_interval_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
llgtr %r3,%r3 # struct compat_timespec *
|
|
jg sys32_sched_rr_get_interval # branch to system call
|
|
|
|
.globl compat_sys_nanosleep_wrapper
|
|
compat_sys_nanosleep_wrapper:
|
|
llgtr %r2,%r2 # struct compat_timespec *
|
|
llgtr %r3,%r3 # struct compat_timespec *
|
|
jg compat_sys_nanosleep # branch to system call
|
|
|
|
.globl sys32_mremap_wrapper
|
|
sys32_mremap_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgfr %r5,%r5 # unsigned long
|
|
llgfr %r6,%r6 # unsigned long
|
|
jg sys_mremap # branch to system call
|
|
|
|
.globl sys32_setresuid16_wrapper
|
|
sys32_setresuid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_uid_emu31_t
|
|
llgfr %r3,%r3 # __kernel_old_uid_emu31_t
|
|
llgfr %r4,%r4 # __kernel_old_uid_emu31_t
|
|
jg sys32_setresuid16 # branch to system call
|
|
|
|
.globl sys32_getresuid16_wrapper
|
|
sys32_getresuid16_wrapper:
|
|
llgtr %r2,%r2 # __kernel_old_uid_emu31_t *
|
|
llgtr %r3,%r3 # __kernel_old_uid_emu31_t *
|
|
llgtr %r4,%r4 # __kernel_old_uid_emu31_t *
|
|
jg sys32_getresuid16 # branch to system call
|
|
|
|
.globl sys32_poll_wrapper
|
|
sys32_poll_wrapper:
|
|
llgtr %r2,%r2 # struct pollfd *
|
|
llgfr %r3,%r3 # unsigned int
|
|
lgfr %r4,%r4 # long
|
|
jg sys_poll # branch to system call
|
|
|
|
.globl compat_sys_nfsservctl_wrapper
|
|
compat_sys_nfsservctl_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct compat_nfsctl_arg*
|
|
llgtr %r4,%r4 # union compat_nfsctl_res*
|
|
jg compat_sys_nfsservctl # branch to system call
|
|
|
|
.globl sys32_setresgid16_wrapper
|
|
sys32_setresgid16_wrapper:
|
|
llgfr %r2,%r2 # __kernel_old_gid_emu31_t
|
|
llgfr %r3,%r3 # __kernel_old_gid_emu31_t
|
|
llgfr %r4,%r4 # __kernel_old_gid_emu31_t
|
|
jg sys32_setresgid16 # branch to system call
|
|
|
|
.globl sys32_getresgid16_wrapper
|
|
sys32_getresgid16_wrapper:
|
|
llgtr %r2,%r2 # __kernel_old_gid_emu31_t *
|
|
llgtr %r3,%r3 # __kernel_old_gid_emu31_t *
|
|
llgtr %r4,%r4 # __kernel_old_gid_emu31_t *
|
|
jg sys32_getresgid16 # branch to system call
|
|
|
|
.globl sys32_prctl_wrapper
|
|
sys32_prctl_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgfr %r5,%r5 # unsigned long
|
|
llgfr %r6,%r6 # unsigned long
|
|
jg sys_prctl # branch to system call
|
|
|
|
#sys32_rt_sigreturn_wrapper # done in rt_sigreturn_glue
|
|
|
|
.globl sys32_rt_sigaction_wrapper
|
|
sys32_rt_sigaction_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const struct sigaction_emu31 *
|
|
llgtr %r4,%r4 # const struct sigaction_emu31 *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys32_rt_sigaction # branch to system call
|
|
|
|
.globl sys32_rt_sigprocmask_wrapper
|
|
sys32_rt_sigprocmask_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # old_sigset_emu31 *
|
|
llgtr %r4,%r4 # old_sigset_emu31 *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys32_rt_sigprocmask # branch to system call
|
|
|
|
.globl sys32_rt_sigpending_wrapper
|
|
sys32_rt_sigpending_wrapper:
|
|
llgtr %r2,%r2 # sigset_emu31 *
|
|
llgfr %r3,%r3 # size_t
|
|
jg sys32_rt_sigpending # branch to system call
|
|
|
|
.globl compat_sys_rt_sigtimedwait_wrapper
|
|
compat_sys_rt_sigtimedwait_wrapper:
|
|
llgtr %r2,%r2 # const sigset_emu31_t *
|
|
llgtr %r3,%r3 # siginfo_emu31_t *
|
|
llgtr %r4,%r4 # const struct compat_timespec *
|
|
llgfr %r5,%r5 # size_t
|
|
jg compat_sys_rt_sigtimedwait # branch to system call
|
|
|
|
.globl sys32_rt_sigqueueinfo_wrapper
|
|
sys32_rt_sigqueueinfo_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # siginfo_emu31_t *
|
|
jg sys32_rt_sigqueueinfo # branch to system call
|
|
|
|
.globl compat_sys_rt_sigsuspend_wrapper
|
|
compat_sys_rt_sigsuspend_wrapper:
|
|
llgtr %r2,%r2 # compat_sigset_t *
|
|
llgfr %r3,%r3 # compat_size_t
|
|
jg compat_sys_rt_sigsuspend
|
|
|
|
.globl sys32_pread64_wrapper
|
|
sys32_pread64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
llgfr %r5,%r5 # u32
|
|
llgfr %r6,%r6 # u32
|
|
jg sys32_pread64 # branch to system call
|
|
|
|
.globl sys32_pwrite64_wrapper
|
|
sys32_pwrite64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # size_t
|
|
llgfr %r5,%r5 # u32
|
|
llgfr %r6,%r6 # u32
|
|
jg sys32_pwrite64 # branch to system call
|
|
|
|
.globl sys32_chown16_wrapper
|
|
sys32_chown16_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # __kernel_old_uid_emu31_t
|
|
llgfr %r4,%r4 # __kernel_old_gid_emu31_t
|
|
jg sys32_chown16 # branch to system call
|
|
|
|
.globl sys32_getcwd_wrapper
|
|
sys32_getcwd_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgfr %r3,%r3 # unsigned long
|
|
jg sys_getcwd # branch to system call
|
|
|
|
.globl sys32_capget_wrapper
|
|
sys32_capget_wrapper:
|
|
llgtr %r2,%r2 # cap_user_header_t
|
|
llgtr %r3,%r3 # cap_user_data_t
|
|
jg sys_capget # branch to system call
|
|
|
|
.globl sys32_capset_wrapper
|
|
sys32_capset_wrapper:
|
|
llgtr %r2,%r2 # cap_user_header_t
|
|
llgtr %r3,%r3 # const cap_user_data_t
|
|
jg sys_capset # branch to system call
|
|
|
|
.globl sys32_sigaltstack_wrapper
|
|
sys32_sigaltstack_wrapper:
|
|
llgtr %r2,%r2 # const stack_emu31_t *
|
|
llgtr %r3,%r3 # stack_emu31_t *
|
|
jg sys32_sigaltstack
|
|
|
|
.globl sys32_sendfile_wrapper
|
|
sys32_sendfile_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # __kernel_off_emu31_t *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys32_sendfile # branch to system call
|
|
|
|
#sys32_vfork_wrapper # done in vfork_glue
|
|
|
|
.globl sys32_truncate64_wrapper
|
|
sys32_truncate64_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg sys32_truncate64 # branch to system call
|
|
|
|
.globl sys32_ftruncate64_wrapper
|
|
sys32_ftruncate64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg sys32_ftruncate64 # branch to system call
|
|
|
|
.globl sys32_lchown_wrapper
|
|
sys32_lchown_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # uid_t
|
|
llgfr %r4,%r4 # gid_t
|
|
jg sys_lchown # branch to system call
|
|
|
|
#sys32_getuid_wrapper # void
|
|
#sys32_getgid_wrapper # void
|
|
#sys32_geteuid_wrapper # void
|
|
#sys32_getegid_wrapper # void
|
|
|
|
.globl sys32_setreuid_wrapper
|
|
sys32_setreuid_wrapper:
|
|
llgfr %r2,%r2 # uid_t
|
|
llgfr %r3,%r3 # uid_t
|
|
jg sys_setreuid # branch to system call
|
|
|
|
.globl sys32_setregid_wrapper
|
|
sys32_setregid_wrapper:
|
|
llgfr %r2,%r2 # gid_t
|
|
llgfr %r3,%r3 # gid_t
|
|
jg sys_setregid # branch to system call
|
|
|
|
.globl sys32_getgroups_wrapper
|
|
sys32_getgroups_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # gid_t *
|
|
jg sys_getgroups # branch to system call
|
|
|
|
.globl sys32_setgroups_wrapper
|
|
sys32_setgroups_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # gid_t *
|
|
jg sys_setgroups # branch to system call
|
|
|
|
.globl sys32_fchown_wrapper
|
|
sys32_fchown_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # uid_t
|
|
llgfr %r4,%r4 # gid_t
|
|
jg sys_fchown # branch to system call
|
|
|
|
.globl sys32_setresuid_wrapper
|
|
sys32_setresuid_wrapper:
|
|
llgfr %r2,%r2 # uid_t
|
|
llgfr %r3,%r3 # uid_t
|
|
llgfr %r4,%r4 # uid_t
|
|
jg sys_setresuid # branch to system call
|
|
|
|
.globl sys32_getresuid_wrapper
|
|
sys32_getresuid_wrapper:
|
|
llgtr %r2,%r2 # uid_t *
|
|
llgtr %r3,%r3 # uid_t *
|
|
llgtr %r4,%r4 # uid_t *
|
|
jg sys_getresuid # branch to system call
|
|
|
|
.globl sys32_setresgid_wrapper
|
|
sys32_setresgid_wrapper:
|
|
llgfr %r2,%r2 # gid_t
|
|
llgfr %r3,%r3 # gid_t
|
|
llgfr %r4,%r4 # gid_t
|
|
jg sys_setresgid # branch to system call
|
|
|
|
.globl sys32_getresgid_wrapper
|
|
sys32_getresgid_wrapper:
|
|
llgtr %r2,%r2 # gid_t *
|
|
llgtr %r3,%r3 # gid_t *
|
|
llgtr %r4,%r4 # gid_t *
|
|
jg sys_getresgid # branch to system call
|
|
|
|
.globl sys32_chown_wrapper
|
|
sys32_chown_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # uid_t
|
|
llgfr %r4,%r4 # gid_t
|
|
jg sys_chown # branch to system call
|
|
|
|
.globl sys32_setuid_wrapper
|
|
sys32_setuid_wrapper:
|
|
llgfr %r2,%r2 # uid_t
|
|
jg sys_setuid # branch to system call
|
|
|
|
.globl sys32_setgid_wrapper
|
|
sys32_setgid_wrapper:
|
|
llgfr %r2,%r2 # gid_t
|
|
jg sys_setgid # branch to system call
|
|
|
|
.globl sys32_setfsuid_wrapper
|
|
sys32_setfsuid_wrapper:
|
|
llgfr %r2,%r2 # uid_t
|
|
jg sys_setfsuid # branch to system call
|
|
|
|
.globl sys32_setfsgid_wrapper
|
|
sys32_setfsgid_wrapper:
|
|
llgfr %r2,%r2 # gid_t
|
|
jg sys_setfsgid # branch to system call
|
|
|
|
.globl sys32_pivot_root_wrapper
|
|
sys32_pivot_root_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
jg sys_pivot_root # branch to system call
|
|
|
|
.globl sys32_mincore_wrapper
|
|
sys32_mincore_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
llgtr %r4,%r4 # unsigned char *
|
|
jg sys_mincore # branch to system call
|
|
|
|
.globl sys32_madvise_wrapper
|
|
sys32_madvise_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # size_t
|
|
lgfr %r4,%r4 # int
|
|
jg sys_madvise # branch to system call
|
|
|
|
.globl sys32_getdents64_wrapper
|
|
sys32_getdents64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # void *
|
|
llgfr %r4,%r4 # unsigned int
|
|
jg sys_getdents64 # branch to system call
|
|
|
|
.globl compat_sys_fcntl64_wrapper
|
|
compat_sys_fcntl64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgfr %r4,%r4 # unsigned long
|
|
jg compat_sys_fcntl64 # branch to system call
|
|
|
|
.globl sys32_stat64_wrapper
|
|
sys32_stat64_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct stat64 *
|
|
jg sys32_stat64 # branch to system call
|
|
|
|
.globl sys32_lstat64_wrapper
|
|
sys32_lstat64_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct stat64 *
|
|
jg sys32_lstat64 # branch to system call
|
|
|
|
.globl sys32_stime_wrapper
|
|
sys32_stime_wrapper:
|
|
llgtr %r2,%r2 # long *
|
|
jg compat_sys_stime # branch to system call
|
|
|
|
.globl sys32_sysctl_wrapper
|
|
sys32_sysctl_wrapper:
|
|
llgtr %r2,%r2 # struct compat_sysctl_args *
|
|
jg compat_sys_sysctl
|
|
|
|
.globl sys32_fstat64_wrapper
|
|
sys32_fstat64_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgtr %r3,%r3 # struct stat64 *
|
|
jg sys32_fstat64 # branch to system call
|
|
|
|
.globl compat_sys_futex_wrapper
|
|
compat_sys_futex_wrapper:
|
|
llgtr %r2,%r2 # u32 *
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # struct compat_timespec *
|
|
llgtr %r6,%r6 # u32 *
|
|
lgf %r0,164(%r15) # int
|
|
stg %r0,160(%r15)
|
|
jg compat_sys_futex # branch to system call
|
|
|
|
.globl sys32_setxattr_wrapper
|
|
sys32_setxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
lgfr %r6,%r6 # int
|
|
jg sys_setxattr
|
|
|
|
.globl sys32_lsetxattr_wrapper
|
|
sys32_lsetxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
lgfr %r6,%r6 # int
|
|
jg sys_lsetxattr
|
|
|
|
.globl sys32_fsetxattr_wrapper
|
|
sys32_fsetxattr_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
lgfr %r6,%r6 # int
|
|
jg sys_fsetxattr
|
|
|
|
.globl sys32_getxattr_wrapper
|
|
sys32_getxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys_getxattr
|
|
|
|
.globl sys32_lgetxattr_wrapper
|
|
sys32_lgetxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys_lgetxattr
|
|
|
|
.globl sys32_fgetxattr_wrapper
|
|
sys32_fgetxattr_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # void *
|
|
llgfr %r5,%r5 # size_t
|
|
jg sys_fgetxattr
|
|
|
|
.globl sys32_listxattr_wrapper
|
|
sys32_listxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
jg sys_listxattr
|
|
|
|
.globl sys32_llistxattr_wrapper
|
|
sys32_llistxattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
jg sys_llistxattr
|
|
|
|
.globl sys32_flistxattr_wrapper
|
|
sys32_flistxattr_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
jg sys_flistxattr
|
|
|
|
.globl sys32_removexattr_wrapper
|
|
sys32_removexattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
jg sys_removexattr
|
|
|
|
.globl sys32_lremovexattr_wrapper
|
|
sys32_lremovexattr_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # char *
|
|
jg sys_lremovexattr
|
|
|
|
.globl sys32_fremovexattr_wrapper
|
|
sys32_fremovexattr_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # char *
|
|
jg sys_fremovexattr
|
|
|
|
.globl sys32_sched_setaffinity_wrapper
|
|
sys32_sched_setaffinity_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgtr %r4,%r4 # unsigned long *
|
|
jg compat_sys_sched_setaffinity
|
|
|
|
.globl sys32_sched_getaffinity_wrapper
|
|
sys32_sched_getaffinity_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgtr %r4,%r4 # unsigned long *
|
|
jg compat_sys_sched_getaffinity
|
|
|
|
.globl sys32_exit_group_wrapper
|
|
sys32_exit_group_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_exit_group # branch to system call
|
|
|
|
.globl sys32_set_tid_address_wrapper
|
|
sys32_set_tid_address_wrapper:
|
|
llgtr %r2,%r2 # int *
|
|
jg sys_set_tid_address # branch to system call
|
|
|
|
.globl sys_epoll_create_wrapper
|
|
sys_epoll_create_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_epoll_create # branch to system call
|
|
|
|
.globl sys_epoll_ctl_wrapper
|
|
sys_epoll_ctl_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # struct epoll_event *
|
|
jg sys_epoll_ctl # branch to system call
|
|
|
|
.globl sys_epoll_wait_wrapper
|
|
sys_epoll_wait_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct epoll_event *
|
|
lgfr %r4,%r4 # int
|
|
lgfr %r5,%r5 # int
|
|
jg sys_epoll_wait # branch to system call
|
|
|
|
.globl sys32_lookup_dcookie_wrapper
|
|
sys32_lookup_dcookie_wrapper:
|
|
sllg %r2,%r2,32 # get high word of 64bit dcookie
|
|
or %r2,%r3 # get low word of 64bit dcookie
|
|
llgtr %r3,%r4 # char *
|
|
llgfr %r4,%r5 # size_t
|
|
jg sys_lookup_dcookie
|
|
|
|
.globl sys32_fadvise64_wrapper
|
|
sys32_fadvise64_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
sllg %r3,%r3,32 # get high word of 64bit loff_t
|
|
or %r3,%r4 # get low word of 64bit loff_t
|
|
llgfr %r4,%r5 # size_t (unsigned long)
|
|
lgfr %r5,%r6 # int
|
|
jg sys32_fadvise64
|
|
|
|
.globl sys32_fadvise64_64_wrapper
|
|
sys32_fadvise64_64_wrapper:
|
|
llgtr %r2,%r2 # struct fadvise64_64_args *
|
|
jg sys32_fadvise64_64
|
|
|
|
.globl sys32_clock_settime_wrapper
|
|
sys32_clock_settime_wrapper:
|
|
lgfr %r2,%r2 # clockid_t (int)
|
|
llgtr %r3,%r3 # struct compat_timespec *
|
|
jg compat_sys_clock_settime
|
|
|
|
.globl sys32_clock_gettime_wrapper
|
|
sys32_clock_gettime_wrapper:
|
|
lgfr %r2,%r2 # clockid_t (int)
|
|
llgtr %r3,%r3 # struct compat_timespec *
|
|
jg compat_sys_clock_gettime
|
|
|
|
.globl sys32_clock_getres_wrapper
|
|
sys32_clock_getres_wrapper:
|
|
lgfr %r2,%r2 # clockid_t (int)
|
|
llgtr %r3,%r3 # struct compat_timespec *
|
|
jg compat_sys_clock_getres
|
|
|
|
.globl sys32_clock_nanosleep_wrapper
|
|
sys32_clock_nanosleep_wrapper:
|
|
lgfr %r2,%r2 # clockid_t (int)
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # struct compat_timespec *
|
|
llgtr %r5,%r5 # struct compat_timespec *
|
|
jg compat_sys_clock_nanosleep
|
|
|
|
.globl sys32_timer_create_wrapper
|
|
sys32_timer_create_wrapper:
|
|
lgfr %r2,%r2 # timer_t (int)
|
|
llgtr %r3,%r3 # struct compat_sigevent *
|
|
llgtr %r4,%r4 # timer_t *
|
|
jg compat_sys_timer_create
|
|
|
|
.globl sys32_timer_settime_wrapper
|
|
sys32_timer_settime_wrapper:
|
|
lgfr %r2,%r2 # timer_t (int)
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # struct compat_itimerspec *
|
|
llgtr %r5,%r5 # struct compat_itimerspec *
|
|
jg compat_sys_timer_settime
|
|
|
|
.globl sys32_timer_gettime_wrapper
|
|
sys32_timer_gettime_wrapper:
|
|
lgfr %r2,%r2 # timer_t (int)
|
|
llgtr %r3,%r3 # struct compat_itimerspec *
|
|
jg compat_sys_timer_gettime
|
|
|
|
.globl sys32_timer_getoverrun_wrapper
|
|
sys32_timer_getoverrun_wrapper:
|
|
lgfr %r2,%r2 # timer_t (int)
|
|
jg sys_timer_getoverrun
|
|
|
|
.globl sys32_timer_delete_wrapper
|
|
sys32_timer_delete_wrapper:
|
|
lgfr %r2,%r2 # timer_t (int)
|
|
jg sys_timer_delete
|
|
|
|
.globl sys32_io_setup_wrapper
|
|
sys32_io_setup_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # u32 *
|
|
jg compat_sys_io_setup
|
|
|
|
.globl sys32_io_destroy_wrapper
|
|
sys32_io_destroy_wrapper:
|
|
llgfr %r2,%r2 # (aio_context_t) u32
|
|
jg sys_io_destroy
|
|
|
|
.globl sys32_io_getevents_wrapper
|
|
sys32_io_getevents_wrapper:
|
|
llgfr %r2,%r2 # (aio_context_t) u32
|
|
lgfr %r3,%r3 # long
|
|
lgfr %r4,%r4 # long
|
|
llgtr %r5,%r5 # struct io_event *
|
|
llgtr %r6,%r6 # struct compat_timespec *
|
|
jg compat_sys_io_getevents
|
|
|
|
.globl sys32_io_submit_wrapper
|
|
sys32_io_submit_wrapper:
|
|
llgfr %r2,%r2 # (aio_context_t) u32
|
|
lgfr %r3,%r3 # long
|
|
llgtr %r4,%r4 # struct iocb **
|
|
jg compat_sys_io_submit
|
|
|
|
.globl sys32_io_cancel_wrapper
|
|
sys32_io_cancel_wrapper:
|
|
llgfr %r2,%r2 # (aio_context_t) u32
|
|
llgtr %r3,%r3 # struct iocb *
|
|
llgtr %r4,%r4 # struct io_event *
|
|
jg sys_io_cancel
|
|
|
|
.globl compat_sys_statfs64_wrapper
|
|
compat_sys_statfs64_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgfr %r3,%r3 # compat_size_t
|
|
llgtr %r4,%r4 # struct compat_statfs64 *
|
|
jg compat_sys_statfs64
|
|
|
|
.globl compat_sys_fstatfs64_wrapper
|
|
compat_sys_fstatfs64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int fd
|
|
llgfr %r3,%r3 # compat_size_t
|
|
llgtr %r4,%r4 # struct compat_statfs64 *
|
|
jg compat_sys_fstatfs64
|
|
|
|
.globl compat_sys_mq_open_wrapper
|
|
compat_sys_mq_open_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
llgfr %r4,%r4 # mode_t
|
|
llgtr %r5,%r5 # struct compat_mq_attr *
|
|
jg compat_sys_mq_open
|
|
|
|
.globl sys32_mq_unlink_wrapper
|
|
sys32_mq_unlink_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
jg sys_mq_unlink
|
|
|
|
.globl compat_sys_mq_timedsend_wrapper
|
|
compat_sys_mq_timedsend_wrapper:
|
|
lgfr %r2,%r2 # mqd_t
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # size_t
|
|
llgfr %r5,%r5 # unsigned int
|
|
llgtr %r6,%r6 # const struct compat_timespec *
|
|
jg compat_sys_mq_timedsend
|
|
|
|
.globl compat_sys_mq_timedreceive_wrapper
|
|
compat_sys_mq_timedreceive_wrapper:
|
|
lgfr %r2,%r2 # mqd_t
|
|
llgtr %r3,%r3 # char *
|
|
llgfr %r4,%r4 # size_t
|
|
llgtr %r5,%r5 # unsigned int *
|
|
llgtr %r6,%r6 # const struct compat_timespec *
|
|
jg compat_sys_mq_timedreceive
|
|
|
|
.globl compat_sys_mq_notify_wrapper
|
|
compat_sys_mq_notify_wrapper:
|
|
lgfr %r2,%r2 # mqd_t
|
|
llgtr %r3,%r3 # struct compat_sigevent *
|
|
jg compat_sys_mq_notify
|
|
|
|
.globl compat_sys_mq_getsetattr_wrapper
|
|
compat_sys_mq_getsetattr_wrapper:
|
|
lgfr %r2,%r2 # mqd_t
|
|
llgtr %r3,%r3 # struct compat_mq_attr *
|
|
llgtr %r4,%r4 # struct compat_mq_attr *
|
|
jg compat_sys_mq_getsetattr
|
|
|
|
.globl compat_sys_add_key_wrapper
|
|
compat_sys_add_key_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
llgtr %r4,%r4 # const void *
|
|
llgfr %r5,%r5 # size_t
|
|
llgfr %r6,%r6 # (key_serial_t) u32
|
|
jg sys_add_key
|
|
|
|
.globl compat_sys_request_key_wrapper
|
|
compat_sys_request_key_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
llgtr %r3,%r3 # const char *
|
|
llgtr %r4,%r4 # const void *
|
|
llgfr %r5,%r5 # (key_serial_t) u32
|
|
jg sys_request_key
|
|
|
|
.globl sys32_remap_file_pages_wrapper
|
|
sys32_remap_file_pages_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgfr %r5,%r5 # unsigned long
|
|
llgfr %r6,%r6 # unsigned long
|
|
jg sys_remap_file_pages
|
|
|
|
.globl compat_sys_waitid_wrapper
|
|
compat_sys_waitid_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # pid_t
|
|
llgtr %r4,%r4 # siginfo_emu31_t *
|
|
lgfr %r5,%r5 # int
|
|
llgtr %r6,%r6 # struct rusage_emu31 *
|
|
jg compat_sys_waitid
|
|
|
|
.globl compat_sys_kexec_load_wrapper
|
|
compat_sys_kexec_load_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgtr %r4,%r4 # struct kexec_segment *
|
|
llgfr %r5,%r5 # unsigned long
|
|
jg compat_sys_kexec_load
|
|
|
|
.globl sys_ioprio_set_wrapper
|
|
sys_ioprio_set_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
lgfr %r4,%r4 # int
|
|
jg sys_ioprio_set
|
|
|
|
.globl sys_ioprio_get_wrapper
|
|
sys_ioprio_get_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_ioprio_get
|
|
|
|
.globl sys_inotify_add_watch_wrapper
|
|
sys_inotify_add_watch_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # u32
|
|
jg sys_inotify_add_watch
|
|
|
|
.globl sys_inotify_rm_watch_wrapper
|
|
sys_inotify_rm_watch_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # u32
|
|
jg sys_inotify_rm_watch
|
|
|
|
.globl compat_sys_openat_wrapper
|
|
compat_sys_openat_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
lgfr %r5,%r5 # int
|
|
jg compat_sys_openat
|
|
|
|
.globl sys_mkdirat_wrapper
|
|
sys_mkdirat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
jg sys_mkdirat
|
|
|
|
.globl sys_mknodat_wrapper
|
|
sys_mknodat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
llgfr %r5,%r5 # unsigned int
|
|
jg sys_mknodat
|
|
|
|
.globl sys_fchownat_wrapper
|
|
sys_fchownat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # uid_t
|
|
llgfr %r5,%r5 # gid_t
|
|
lgfr %r6,%r6 # int
|
|
jg sys_fchownat
|
|
|
|
.globl compat_sys_futimesat_wrapper
|
|
compat_sys_futimesat_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # struct timeval *
|
|
jg compat_sys_futimesat
|
|
|
|
.globl sys32_fstatat64_wrapper
|
|
sys32_fstatat64_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # struct stat64 *
|
|
lgfr %r5,%r5 # int
|
|
jg sys32_fstatat64
|
|
|
|
.globl sys_unlinkat_wrapper
|
|
sys_unlinkat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
jg sys_unlinkat
|
|
|
|
.globl sys_renameat_wrapper
|
|
sys_renameat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # const char *
|
|
jg sys_renameat
|
|
|
|
.globl sys_linkat_wrapper
|
|
sys_linkat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # const char *
|
|
lgfr %r6,%r6 # int
|
|
jg sys_linkat
|
|
|
|
.globl sys_symlinkat_wrapper
|
|
sys_symlinkat_wrapper:
|
|
llgtr %r2,%r2 # const char *
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # const char *
|
|
jg sys_symlinkat
|
|
|
|
.globl sys_readlinkat_wrapper
|
|
sys_readlinkat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
llgtr %r4,%r4 # char *
|
|
lgfr %r5,%r5 # int
|
|
jg sys_readlinkat
|
|
|
|
.globl sys_fchmodat_wrapper
|
|
sys_fchmodat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
llgfr %r4,%r4 # mode_t
|
|
jg sys_fchmodat
|
|
|
|
.globl sys_faccessat_wrapper
|
|
sys_faccessat_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char *
|
|
lgfr %r4,%r4 # int
|
|
jg sys_faccessat
|
|
|
|
.globl compat_sys_pselect6_wrapper
|
|
compat_sys_pselect6_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # fd_set *
|
|
llgtr %r4,%r4 # fd_set *
|
|
llgtr %r5,%r5 # fd_set *
|
|
llgtr %r6,%r6 # struct timespec *
|
|
llgt %r0,164(%r15) # void *
|
|
stg %r0,160(%r15)
|
|
jg compat_sys_pselect6
|
|
|
|
.globl compat_sys_ppoll_wrapper
|
|
compat_sys_ppoll_wrapper:
|
|
llgtr %r2,%r2 # struct pollfd *
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgtr %r4,%r4 # struct timespec *
|
|
llgtr %r5,%r5 # const sigset_t *
|
|
llgfr %r6,%r6 # size_t
|
|
jg compat_sys_ppoll
|
|
|
|
.globl sys_unshare_wrapper
|
|
sys_unshare_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
jg sys_unshare
|
|
|
|
.globl compat_sys_set_robust_list_wrapper
|
|
compat_sys_set_robust_list_wrapper:
|
|
llgtr %r2,%r2 # struct compat_robust_list_head *
|
|
llgfr %r3,%r3 # size_t
|
|
jg compat_sys_set_robust_list
|
|
|
|
.globl compat_sys_get_robust_list_wrapper
|
|
compat_sys_get_robust_list_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_uptr_t_t *
|
|
llgtr %r4,%r4 # compat_size_t *
|
|
jg compat_sys_get_robust_list
|
|
|
|
.globl sys_splice_wrapper
|
|
sys_splice_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # loff_t *
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # loff_t *
|
|
llgfr %r6,%r6 # size_t
|
|
llgf %r0,164(%r15) # unsigned int
|
|
stg %r0,160(%r15)
|
|
jg sys_splice
|
|
|
|
.globl sys_sync_file_range_wrapper
|
|
sys_sync_file_range_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
sllg %r3,%r3,32 # get high word of 64bit loff_t
|
|
or %r3,%r4 # get low word of 64bit loff_t
|
|
sllg %r4,%r5,32 # get high word of 64bit loff_t
|
|
or %r4,%r6 # get low word of 64bit loff_t
|
|
llgf %r5,164(%r15) # unsigned int
|
|
jg sys_sync_file_range
|
|
|
|
.globl sys_tee_wrapper
|
|
sys_tee_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgfr %r4,%r4 # size_t
|
|
llgfr %r5,%r5 # unsigned int
|
|
jg sys_tee
|
|
|
|
.globl compat_sys_vmsplice_wrapper
|
|
compat_sys_vmsplice_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_iovec *
|
|
llgfr %r4,%r4 # unsigned int
|
|
llgfr %r5,%r5 # unsigned int
|
|
jg compat_sys_vmsplice
|
|
|
|
.globl sys_getcpu_wrapper
|
|
sys_getcpu_wrapper:
|
|
llgtr %r2,%r2 # unsigned *
|
|
llgtr %r3,%r3 # unsigned *
|
|
llgtr %r4,%r4 # struct getcpu_cache *
|
|
jg sys_getcpu
|
|
|
|
.globl compat_sys_epoll_pwait_wrapper
|
|
compat_sys_epoll_pwait_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct compat_epoll_event *
|
|
lgfr %r4,%r4 # int
|
|
lgfr %r5,%r5 # int
|
|
llgtr %r6,%r6 # compat_sigset_t *
|
|
llgf %r0,164(%r15) # compat_size_t
|
|
stg %r0,160(%r15)
|
|
jg compat_sys_epoll_pwait
|
|
|
|
.globl compat_sys_utimes_wrapper
|
|
compat_sys_utimes_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # struct compat_timeval *
|
|
jg compat_sys_utimes
|
|
|
|
.globl compat_sys_utimensat_wrapper
|
|
compat_sys_utimensat_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgtr %r3,%r3 # char *
|
|
llgtr %r4,%r4 # struct compat_timespec *
|
|
lgfr %r5,%r5 # int
|
|
jg compat_sys_utimensat
|
|
|
|
.globl compat_sys_signalfd_wrapper
|
|
compat_sys_signalfd_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_sigset_t *
|
|
llgfr %r4,%r4 # compat_size_t
|
|
jg compat_sys_signalfd
|
|
|
|
.globl sys_eventfd_wrapper
|
|
sys_eventfd_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
jg sys_eventfd
|
|
|
|
.globl sys_fallocate_wrapper
|
|
sys_fallocate_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
sllg %r4,%r4,32 # get high word of 64bit loff_t
|
|
lr %r4,%r5 # get low word of 64bit loff_t
|
|
sllg %r5,%r6,32 # get high word of 64bit loff_t
|
|
l %r5,164(%r15) # get low word of 64bit loff_t
|
|
jg sys_fallocate
|
|
|
|
.globl sys_timerfd_create_wrapper
|
|
sys_timerfd_create_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_timerfd_create
|
|
|
|
.globl compat_sys_timerfd_settime_wrapper
|
|
compat_sys_timerfd_settime_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # struct compat_itimerspec *
|
|
llgtr %r5,%r5 # struct compat_itimerspec *
|
|
jg compat_sys_timerfd_settime
|
|
|
|
.globl compat_sys_timerfd_gettime_wrapper
|
|
compat_sys_timerfd_gettime_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct compat_itimerspec *
|
|
jg compat_sys_timerfd_gettime
|
|
|
|
.globl compat_sys_signalfd4_wrapper
|
|
compat_sys_signalfd4_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # compat_sigset_t *
|
|
llgfr %r4,%r4 # compat_size_t
|
|
lgfr %r5,%r5 # int
|
|
jg compat_sys_signalfd4
|
|
|
|
.globl sys_eventfd2_wrapper
|
|
sys_eventfd2_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_eventfd2
|
|
|
|
.globl sys_inotify_init1_wrapper
|
|
sys_inotify_init1_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_inotify_init1
|
|
|
|
.globl sys_pipe2_wrapper
|
|
sys_pipe2_wrapper:
|
|
llgtr %r2,%r2 # u32 *
|
|
lgfr %r3,%r3 # int
|
|
jg sys_pipe2 # branch to system call
|
|
|
|
.globl sys_dup3_wrapper
|
|
sys_dup3_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
lgfr %r4,%r4 # int
|
|
jg sys_dup3 # branch to system call
|
|
|
|
.globl sys_epoll_create1_wrapper
|
|
sys_epoll_create1_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_epoll_create1 # branch to system call
|
|
|
|
.globl sys32_readahead_wrapper
|
|
sys32_readahead_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # u32
|
|
llgfr %r4,%r4 # u32
|
|
lgfr %r5,%r5 # s32
|
|
jg sys32_readahead # branch to system call
|
|
|
|
.globl sys32_sendfile64_wrapper
|
|
sys32_sendfile64_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
llgtr %r4,%r4 # compat_loff_t *
|
|
lgfr %r5,%r5 # s32
|
|
jg sys32_sendfile64 # branch to system call
|
|
|
|
.globl sys_tkill_wrapper
|
|
sys_tkill_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
lgfr %r3,%r3 # int
|
|
jg sys_tkill # branch to system call
|
|
|
|
.globl sys_tgkill_wrapper
|
|
sys_tgkill_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
lgfr %r3,%r3 # pid_t
|
|
lgfr %r4,%r4 # int
|
|
jg sys_tgkill # branch to system call
|
|
|
|
.globl compat_sys_keyctl_wrapper
|
|
compat_sys_keyctl_wrapper:
|
|
llgfr %r2,%r2 # u32
|
|
llgfr %r3,%r3 # u32
|
|
llgfr %r4,%r4 # u32
|
|
llgfr %r5,%r5 # u32
|
|
llgfr %r6,%r6 # u32
|
|
jg compat_sys_keyctl # branch to system call
|
|
|
|
.globl compat_sys_preadv_wrapper
|
|
compat_sys_preadv_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgtr %r3,%r3 # compat_iovec *
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgfr %r5,%r5 # u32
|
|
llgfr %r6,%r6 # u32
|
|
jg compat_sys_preadv # branch to system call
|
|
|
|
.globl compat_sys_pwritev_wrapper
|
|
compat_sys_pwritev_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgtr %r3,%r3 # compat_iovec *
|
|
llgfr %r4,%r4 # unsigned long
|
|
llgfr %r5,%r5 # u32
|
|
llgfr %r6,%r6 # u32
|
|
jg compat_sys_pwritev # branch to system call
|
|
|
|
.globl compat_sys_rt_tgsigqueueinfo_wrapper
|
|
compat_sys_rt_tgsigqueueinfo_wrapper:
|
|
lgfr %r2,%r2 # compat_pid_t
|
|
lgfr %r3,%r3 # compat_pid_t
|
|
lgfr %r4,%r4 # int
|
|
llgtr %r5,%r5 # struct compat_siginfo *
|
|
jg compat_sys_rt_tgsigqueueinfo_wrapper # branch to system call
|
|
|
|
.globl sys_perf_event_open_wrapper
|
|
sys_perf_event_open_wrapper:
|
|
llgtr %r2,%r2 # const struct perf_event_attr *
|
|
lgfr %r3,%r3 # pid_t
|
|
lgfr %r4,%r4 # int
|
|
lgfr %r5,%r5 # int
|
|
llgfr %r6,%r6 # unsigned long
|
|
jg sys_perf_event_open # branch to system call
|
|
|
|
.globl sys_clone_wrapper
|
|
sys_clone_wrapper:
|
|
llgfr %r2,%r2 # unsigned long
|
|
llgfr %r3,%r3 # unsigned long
|
|
llgtr %r4,%r4 # int *
|
|
llgtr %r5,%r5 # int *
|
|
jg sys_clone # branch to system call
|
|
|
|
.globl sys32_execve_wrapper
|
|
sys32_execve_wrapper:
|
|
llgtr %r2,%r2 # char *
|
|
llgtr %r3,%r3 # compat_uptr_t *
|
|
llgtr %r4,%r4 # compat_uptr_t *
|
|
jg sys32_execve # branch to system call
|
|
|
|
.globl sys_fanotify_init_wrapper
|
|
sys_fanotify_init_wrapper:
|
|
llgfr %r2,%r2 # unsigned int
|
|
llgfr %r3,%r3 # unsigned int
|
|
jg sys_fanotify_init # branch to system call
|
|
|
|
.globl sys_fanotify_mark_wrapper
|
|
sys_fanotify_mark_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgfr %r3,%r3 # unsigned int
|
|
sllg %r4,%r4,32 # get high word of 64bit mask
|
|
lr %r4,%r5 # get low word of 64bit mask
|
|
llgfr %r5,%r6 # unsigned int
|
|
llgt %r6,164(%r15) # char *
|
|
jg sys_fanotify_mark # branch to system call
|
|
|
|
.globl sys_prlimit64_wrapper
|
|
sys_prlimit64_wrapper:
|
|
lgfr %r2,%r2 # pid_t
|
|
llgfr %r3,%r3 # unsigned int
|
|
llgtr %r4,%r4 # const struct rlimit64 __user *
|
|
llgtr %r5,%r5 # struct rlimit64 __user *
|
|
jg sys_prlimit64 # branch to system call
|
|
|
|
.globl sys_name_to_handle_at_wrapper
|
|
sys_name_to_handle_at_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # const char __user *
|
|
llgtr %r4,%r4 # struct file_handle __user *
|
|
llgtr %r5,%r5 # int __user *
|
|
lgfr %r6,%r6 # int
|
|
jg sys_name_to_handle_at
|
|
|
|
.globl compat_sys_open_by_handle_at_wrapper
|
|
compat_sys_open_by_handle_at_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
llgtr %r3,%r3 # struct file_handle __user *
|
|
lgfr %r4,%r4 # int
|
|
jg compat_sys_open_by_handle_at
|
|
|
|
.globl compat_sys_clock_adjtime_wrapper
|
|
compat_sys_clock_adjtime_wrapper:
|
|
lgfr %r2,%r2 # clockid_t (int)
|
|
llgtr %r3,%r3 # struct compat_timex __user *
|
|
jg compat_sys_clock_adjtime
|
|
|
|
.globl sys_syncfs_wrapper
|
|
sys_syncfs_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
jg sys_syncfs
|
|
|
|
.globl sys_setns_wrapper
|
|
sys_setns_wrapper:
|
|
lgfr %r2,%r2 # int
|
|
lgfr %r3,%r3 # int
|
|
jg sys_setns
|