
compiled in. It might make sense to #ifdef them in the future, though this impeeds readability.
179 lines
6.2 KiB
C
179 lines
6.2 KiB
C
/*
|
|
* Copyright (c) 2004 Todd C. Miller <Todd.Miller@courtesan.com>
|
|
*
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
void check_exec __P((int, struct str_msg_ask *,
|
|
struct systrace_answer *));
|
|
|
|
struct syscallaction {
|
|
int code;
|
|
int policy;
|
|
void (*handler) __P((int, struct str_msg_ask *, struct systrace_answer *));
|
|
};
|
|
|
|
struct syscallaction syscalls_openbsd[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* OPENBSD_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* OPENBSD_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* OPENBSD_SYS_setreuid */
|
|
{ 183, SYSTR_POLICY_ASK, NULL}, /* OPENBSD_SYS_seteuid */
|
|
{ 282, SYSTR_POLICY_ASK, NULL}, /* OPENBSD_SYS_setresuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_bsdos[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* BSDOS_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* BSDOS_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* BSDOS_SYS_setreuid */
|
|
{ 183, SYSTR_POLICY_ASK, NULL}, /* BSDOS_SYS_seteuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_freebsd[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* FREEBSD_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* FREEBSD_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* FREEBSD_SYS_setreuid */
|
|
{ 183, SYSTR_POLICY_ASK, NULL}, /* FREEBSD_SYS_seteuid */
|
|
{ 311, SYSTR_POLICY_ASK, NULL}, /* FREEBSD_SYS_setresuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_netbsd[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* NETBSD_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* NETBSD_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* NETBSD_SYS_setreuid */
|
|
{ 183, SYSTR_POLICY_ASK, NULL}, /* NETBSD_SYS_seteuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_hpux[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* HPUX_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* HPUX_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* HPUX_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* HPUX_SYS_setresuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_ibsc2[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* ISCS2_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* ISCS2_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* ISCS2_SYS_execve */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_linux[] = {
|
|
{ 11, SYSTR_POLICY_ASK, check_exec}, /* LINUX_SYS_execve */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setuid16 */
|
|
{ 70, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setreuid16 */
|
|
{ 138, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setfsuid16 */
|
|
{ 164, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setresuid16 */
|
|
{ 203, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setreuid */
|
|
{ 208, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setresuid */
|
|
{ 213, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setuid */
|
|
{ 215, SYSTR_POLICY_ASK, NULL}, /* LINUX_SYS_setfsuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_osf1[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* OSF1_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* OSF1_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* OSF1_SYS_setreuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_sunos[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* SUNOS_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* SUNOS_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* SUNOS_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* SUNOS_SYS_setreuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_svr4[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* SVR4_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* SVR4_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* SVR4_SYS_execve */
|
|
{ 141, SYSTR_POLICY_ASK, NULL}, /* SVR4_SYS_seteuid */
|
|
{ 202, SYSTR_POLICY_ASK, NULL}, /* SVR4_SYS_setreuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_ultrix[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* ULTRIX_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* ULTRIX_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* ULTRIX_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* ULTRIX_SYS_setreuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_irix[] = {
|
|
{ 11, SYSTR_POLICY_ASK, NULL}, /* IRIX_SYS_execv */
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* IRIX_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* IRIX_SYS_execve */
|
|
{ 124, SYSTR_POLICY_ASK, NULL}, /* IRIX_SYS_setreuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct syscallaction syscalls_darwin[] = {
|
|
{ 23, SYSTR_POLICY_ASK, NULL}, /* DARWIN_SYS_setuid */
|
|
{ 59, SYSTR_POLICY_ASK, check_exec}, /* DARWIN_SYS_execve */
|
|
{ 126, SYSTR_POLICY_ASK, NULL}, /* DARWIN_SYS_setreuid */
|
|
{ 183, SYSTR_POLICY_ASK, NULL}, /* DARWIN_SYS_seteuid */
|
|
{ -1, -1, NULL}
|
|
};
|
|
|
|
struct emulation {
|
|
const char *name;
|
|
struct syscallaction *action;
|
|
} emulations[] = {
|
|
{ "bsdos", syscalls_bsdos },
|
|
#if defined(__darwin__) || defined(__APPLE__)
|
|
{ "native", syscalls_darwin },
|
|
#else
|
|
{ "darwin", syscalls_darwin },
|
|
#endif
|
|
#ifdef __FreeBSD__
|
|
{ "native", syscalls_freebsd },
|
|
#else
|
|
{ "freebsd", syscalls_freebsd },
|
|
#endif
|
|
{ "hpux", syscalls_hpux },
|
|
{ "ibsc2", syscalls_ibsc2 },
|
|
{ "irix", syscalls_irix },
|
|
#if defined(__linux__)
|
|
{ "native", syscalls_linux },
|
|
#else
|
|
{ "linux", syscalls_linux },
|
|
#endif
|
|
#ifdef __NetBSD__
|
|
{ "native", syscalls_netbsd },
|
|
#else
|
|
{ "netbsd", syscalls_netbsd },
|
|
#endif
|
|
{ "netbsd32", syscalls_netbsd },
|
|
#ifdef __OpenBSD__
|
|
{ "native", syscalls_openbsd },
|
|
#else
|
|
{ "openbsd", syscalls_openbsd },
|
|
#endif
|
|
{ "osf1", syscalls_osf1 },
|
|
{ "pecoff", syscalls_netbsd },
|
|
{ "sunos", syscalls_sunos },
|
|
{ "sunos32", syscalls_sunos },
|
|
{ "svr4", syscalls_svr4 },
|
|
{ "svr4_32", syscalls_svr4 },
|
|
{ "ultrix", syscalls_ultrix },
|
|
{ NULL, NULL }
|
|
};
|