02e5d7d78e
This patch implements strace argument printing functionality for following syscalls: * mlock, munlock, mlockall, munlockall - lock and unlock memory int mlock(const void *addr, size_t len) int munlock(const void *addr, size_t len) int mlockall(int flags) int munlockall(void) man page: https://man7.org/linux/man-pages/man2/mlock.2.html Implementation notes: Syscall mlockall() takes an argument that is composed of predefined values which represent flags that determine the type of locking operation that is to be performed. For that reason, a printing function "print_mlockall" was stated in file "strace.list". This printing function uses an already existing function "print_flags()" to print the "flags" argument. These flags are stated inside an array "mlockall_flags" that contains values of type "struct flags". These values are instantiated using an existing macro "FLAG_TARGET()" that crates aproppriate target flag values based on those defined in files '/target_syscall.h'. These target flag values were changed from "TARGET_MLOCKALL_MCL*" to "TARGET_MCL_*" so that they can be aproppriately set and recognised in "strace.c" with "FLAG_TARGET()". Value for "MCL_ONFAULT" was added in this patch. This value was also added in "syscall.c" in function "target_to_host_mlockall_arg()". Because this flag value was added in kernel version 4.4, it is enwrapped in an #ifdef directive (both in "syscall.c" and in "strace.c") as to support older kernel versions. The other syscalls have only primitive argument types, so the rest of the implementation was handled by stating an appropriate printing format in file "strace.list". Syscall mlock2() is not implemented in "syscall.c" and thus it's argument printing is not implemented in this patch. Signed-off-by: Filip Bozuta <Filip.Bozuta@syrmia.com> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Message-Id: <20200811164553.27713-4-Filip.Bozuta@syrmia.com> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
266 lines
6.4 KiB
C
266 lines
6.4 KiB
C
#ifndef ALPHA_TARGET_SYSCALL_H
|
|
#define ALPHA_TARGET_SYSCALL_H
|
|
|
|
/* default linux values for the selectors */
|
|
#define __USER_DS (1)
|
|
|
|
struct target_pt_regs {
|
|
abi_ulong r0;
|
|
abi_ulong r1;
|
|
abi_ulong r2;
|
|
abi_ulong r3;
|
|
abi_ulong r4;
|
|
abi_ulong r5;
|
|
abi_ulong r6;
|
|
abi_ulong r7;
|
|
abi_ulong r8;
|
|
abi_ulong r19;
|
|
abi_ulong r20;
|
|
abi_ulong r21;
|
|
abi_ulong r22;
|
|
abi_ulong r23;
|
|
abi_ulong r24;
|
|
abi_ulong r25;
|
|
abi_ulong r26;
|
|
abi_ulong r27;
|
|
abi_ulong r28;
|
|
abi_ulong hae;
|
|
/* JRP - These are the values provided to a0-a2 by PALcode */
|
|
abi_ulong trap_a0;
|
|
abi_ulong trap_a1;
|
|
abi_ulong trap_a2;
|
|
/* These are saved by PAL-code: */
|
|
abi_ulong ps;
|
|
abi_ulong pc;
|
|
abi_ulong gp;
|
|
abi_ulong r16;
|
|
abi_ulong r17;
|
|
abi_ulong r18;
|
|
/* Those is needed by qemu to temporary store the user stack pointer */
|
|
abi_ulong usp;
|
|
abi_ulong unique;
|
|
};
|
|
|
|
#define UNAME_MACHINE "alpha"
|
|
#define UNAME_MINIMUM_RELEASE "2.6.32"
|
|
|
|
#undef TARGET_EDEADLK
|
|
#define TARGET_EDEADLK 11
|
|
#undef TARGET_EAGAIN
|
|
#define TARGET_EAGAIN 35
|
|
#undef TARGET_EINPROGRESS
|
|
#define TARGET_EINPROGRESS 36
|
|
#undef TARGET_EALREADY
|
|
#define TARGET_EALREADY 37
|
|
#undef TARGET_ENOTSOCK
|
|
#define TARGET_ENOTSOCK 38
|
|
#undef TARGET_EDESTADDRREQ
|
|
#define TARGET_EDESTADDRREQ 39
|
|
#undef TARGET_EMSGSIZE
|
|
#define TARGET_EMSGSIZE 40
|
|
#undef TARGET_EPROTOTYPE
|
|
#define TARGET_EPROTOTYPE 41
|
|
#undef TARGET_ENOPROTOOPT
|
|
#define TARGET_ENOPROTOOPT 42
|
|
#undef TARGET_EPROTONOSUPPORT
|
|
#define TARGET_EPROTONOSUPPORT 43
|
|
#undef TARGET_ESOCKTNOSUPPORT
|
|
#define TARGET_ESOCKTNOSUPPORT 44
|
|
#undef TARGET_EOPNOTSUPP
|
|
#define TARGET_EOPNOTSUPP 45
|
|
#undef TARGET_EPFNOSUPPORT
|
|
#define TARGET_EPFNOSUPPORT 46
|
|
#undef TARGET_EAFNOSUPPORT
|
|
#define TARGET_EAFNOSUPPORT 47
|
|
#undef TARGET_EADDRINUSE
|
|
#define TARGET_EADDRINUSE 48
|
|
#undef TARGET_EADDRNOTAVAIL
|
|
#define TARGET_EADDRNOTAVAIL 49
|
|
#undef TARGET_ENETDOWN
|
|
#define TARGET_ENETDOWN 50
|
|
#undef TARGET_ENETUNREACH
|
|
#define TARGET_ENETUNREACH 51
|
|
#undef TARGET_ENETRESET
|
|
#define TARGET_ENETRESET 52
|
|
#undef TARGET_ECONNABORTED
|
|
#define TARGET_ECONNABORTED 53
|
|
#undef TARGET_ECONNRESET
|
|
#define TARGET_ECONNRESET 54
|
|
#undef TARGET_ENOBUFS
|
|
#define TARGET_ENOBUFS 55
|
|
#undef TARGET_EISCONN
|
|
#define TARGET_EISCONN 56
|
|
#undef TARGET_ENOTCONN
|
|
#define TARGET_ENOTCONN 57
|
|
#undef TARGET_ESHUTDOWN
|
|
#define TARGET_ESHUTDOWN 58
|
|
#undef TARGET_ETOOMANYREFS
|
|
#define TARGET_ETOOMANYREFS 59
|
|
#undef TARGET_ETIMEDOUT
|
|
#define TARGET_ETIMEDOUT 60
|
|
#undef TARGET_ECONNREFUSED
|
|
#define TARGET_ECONNREFUSED 61
|
|
#undef TARGET_ELOOP
|
|
#define TARGET_ELOOP 62
|
|
#undef TARGET_ENAMETOOLONG
|
|
#define TARGET_ENAMETOOLONG 63
|
|
#undef TARGET_EHOSTDOWN
|
|
#define TARGET_EHOSTDOWN 64
|
|
#undef TARGET_EHOSTUNREACH
|
|
#define TARGET_EHOSTUNREACH 65
|
|
#undef TARGET_ENOTEMPTY
|
|
#define TARGET_ENOTEMPTY 66
|
|
// Unused 67
|
|
#undef TARGET_EUSERS
|
|
#define TARGET_EUSERS 68
|
|
#undef TARGET_EDQUOT
|
|
#define TARGET_EDQUOT 69
|
|
#undef TARGET_ESTALE
|
|
#define TARGET_ESTALE 70
|
|
#undef TARGET_EREMOTE
|
|
#define TARGET_EREMOTE 71
|
|
// Unused 72-76
|
|
#undef TARGET_ENOLCK
|
|
#define TARGET_ENOLCK 77
|
|
#undef TARGET_ENOSYS
|
|
#define TARGET_ENOSYS 78
|
|
// Unused 79
|
|
#undef TARGET_ENOMSG
|
|
#define TARGET_ENOMSG 80
|
|
#undef TARGET_EIDRM
|
|
#define TARGET_EIDRM 81
|
|
#undef TARGET_ENOSR
|
|
#define TARGET_ENOSR 82
|
|
#undef TARGET_ETIME
|
|
#define TARGET_ETIME 83
|
|
#undef TARGET_EBADMSG
|
|
#define TARGET_EBADMSG 84
|
|
#undef TARGET_EPROTO
|
|
#define TARGET_EPROTO 85
|
|
#undef TARGET_ENODATA
|
|
#define TARGET_ENODATA 86
|
|
#undef TARGET_ENOSTR
|
|
#define TARGET_ENOSTR 87
|
|
#undef TARGET_ECHRNG
|
|
#define TARGET_ECHRNG 88
|
|
#undef TARGET_EL2NSYNC
|
|
#define TARGET_EL2NSYNC 89
|
|
#undef TARGET_EL3HLT
|
|
#define TARGET_EL3HLT 90
|
|
#undef TARGET_EL3RST
|
|
#define TARGET_EL3RST 91
|
|
#undef TARGET_ENOPKG
|
|
#define TARGET_ENOPKG 92
|
|
#undef TARGET_ELNRNG
|
|
#define TARGET_ELNRNG 93
|
|
#undef TARGET_EUNATCH
|
|
#define TARGET_EUNATCH 94
|
|
#undef TARGET_ENOCSI
|
|
#define TARGET_ENOCSI 95
|
|
#undef TARGET_EL2HLT
|
|
#define TARGET_EL2HLT 96
|
|
#undef TARGET_EBADE
|
|
#define TARGET_EBADE 97
|
|
#undef TARGET_EBADR
|
|
#define TARGET_EBADR 98
|
|
#undef TARGET_EXFULL
|
|
#define TARGET_EXFULL 99
|
|
#undef TARGET_ENOANO
|
|
#define TARGET_ENOANO 100
|
|
#undef TARGET_EBADRQC
|
|
#define TARGET_EBADRQC 101
|
|
#undef TARGET_EBADSLT
|
|
#define TARGET_EBADSLT 102
|
|
// Unused 103
|
|
#undef TARGET_EBFONT
|
|
#define TARGET_EBFONT 104
|
|
#undef TARGET_ENONET
|
|
#define TARGET_ENONET 105
|
|
#undef TARGET_ENOLINK
|
|
#define TARGET_ENOLINK 106
|
|
#undef TARGET_EADV
|
|
#define TARGET_EADV 107
|
|
#undef TARGET_ESRMNT
|
|
#define TARGET_ESRMNT 108
|
|
#undef TARGET_ECOMM
|
|
#define TARGET_ECOMM 109
|
|
#undef TARGET_EMULTIHOP
|
|
#define TARGET_EMULTIHOP 110
|
|
#undef TARGET_EDOTDOT
|
|
#define TARGET_EDOTDOT 111
|
|
#undef TARGET_EOVERFLOW
|
|
#define TARGET_EOVERFLOW 112
|
|
#undef TARGET_ENOTUNIQ
|
|
#define TARGET_ENOTUNIQ 113
|
|
#undef TARGET_EBADFD
|
|
#define TARGET_EBADFD 114
|
|
#undef TARGET_EREMCHG
|
|
#define TARGET_EREMCHG 115
|
|
#undef TARGET_EILSEQ
|
|
#define TARGET_EILSEQ 116
|
|
|
|
// Same as default 117-121
|
|
|
|
#undef TARGET_ELIBACC
|
|
#define TARGET_ELIBACC 122
|
|
#undef TARGET_ELIBBAD
|
|
#define TARGET_ELIBBAD 123
|
|
#undef TARGET_ELIBSCN
|
|
#define TARGET_ELIBSCN 124
|
|
#undef TARGET_ELIBMAX
|
|
#define TARGET_ELIBMAX 125
|
|
#undef TARGET_ELIBEXEC
|
|
#define TARGET_ELIBEXEC 126
|
|
#undef TARGET_ERESTART
|
|
#define TARGET_ERESTART 127
|
|
#undef TARGET_ESTRPIPE
|
|
#define TARGET_ESTRPIPE 128
|
|
#undef TARGET_ENOMEDIUM
|
|
#define TARGET_ENOMEDIUM 129
|
|
#undef TARGET_EMEDIUMTYPE
|
|
#define TARGET_EMEDIUMTYPE 130
|
|
#undef TARGET_ECANCELED
|
|
#define TARGET_ECANCELED 131
|
|
#undef TARGET_ENOKEY
|
|
#define TARGET_ENOKEY 132
|
|
#undef TARGET_EKEYEXPIRED
|
|
#define TARGET_EKEYEXPIRED 133
|
|
#undef TARGET_EKEYREVOKED
|
|
#define TARGET_EKEYREVOKED 134
|
|
#undef TARGET_EKEYREJECTED
|
|
#define TARGET_EKEYREJECTED 135
|
|
#undef TARGET_EOWNERDEAD
|
|
#define TARGET_EOWNERDEAD 136
|
|
#undef TARGET_ENOTRECOVERABLE
|
|
#define TARGET_ENOTRECOVERABLE 137
|
|
#undef TARGET_ERFKILL
|
|
#define TARGET_ERFKILL 138
|
|
#undef TARGET_EHWPOISON
|
|
#define TARGET_EHWPOISON 139
|
|
|
|
// For sys_osf_getsysinfo
|
|
#define TARGET_GSI_UACPROC 8
|
|
#define TARGET_GSI_IEEE_FP_CONTROL 45
|
|
#define TARGET_GSI_IEEE_STATE_AT_SIGNAL 46
|
|
#define TARGET_GSI_PROC_TYPE 60
|
|
#define TARGET_GSI_GET_HWRPB 101
|
|
|
|
// For sys_ofs_setsysinfo
|
|
#define TARGET_SSI_NVPAIRS 1
|
|
#define TARGET_SSI_IEEE_FP_CONTROL 14
|
|
#define TARGET_SSI_IEEE_STATE_AT_SIGNAL 15
|
|
#define TARGET_SSI_IEEE_IGNORE_STATE_AT_SIGNAL 16
|
|
#define TARGET_SSI_IEEE_RAISE_EXCEPTION 1001
|
|
|
|
#define TARGET_SSIN_UACPROC 6
|
|
|
|
#define TARGET_UAC_NOPRINT 1
|
|
#define TARGET_UAC_NOFIX 2
|
|
#define TARGET_UAC_SIGBUS 4
|
|
#define TARGET_MINSIGSTKSZ 4096
|
|
#define TARGET_MCL_CURRENT 0x2000
|
|
#define TARGET_MCL_FUTURE 0x4000
|
|
#define TARGET_MCL_ONFAULT 0x8000
|
|
|
|
#endif /* ALPHA_TARGET_SYSCALL_H */
|