2005-05-03 20:26:27 +04:00
|
|
|
/* $NetBSD: exec_conf.c,v 1.90 2005/05/03 16:26:27 manu Exp $ */
|
1994-06-29 10:29:24 +04:00
|
|
|
|
1994-01-16 06:09:59 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 1993, 1994 Christopher G. Demetriou
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by Christopher G. Demetriou.
|
|
|
|
* 4. The name of the author may not be used to endorse or promote products
|
1994-01-29 02:43:26 +03:00
|
|
|
* derived from this software without specific prior written permission
|
1994-01-16 06:09:59 +03:00
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2001-11-12 18:25:01 +03:00
|
|
|
#include <sys/cdefs.h>
|
2005-05-03 20:26:27 +04:00
|
|
|
__KERNEL_RCSID(0, "$NetBSD: exec_conf.c,v 1.90 2005/05/03 16:26:27 manu Exp $");
|
2001-11-12 18:25:01 +03:00
|
|
|
|
1998-01-22 04:32:14 +03:00
|
|
|
#include "opt_execfmt.h"
|
1998-06-26 02:49:18 +04:00
|
|
|
#include "opt_compat_freebsd.h"
|
1998-06-26 03:18:23 +04:00
|
|
|
#include "opt_compat_linux.h"
|
1998-06-26 03:22:37 +04:00
|
|
|
#include "opt_compat_ibcs2.h"
|
2001-11-27 00:38:41 +03:00
|
|
|
#include "opt_compat_irix.h"
|
1998-06-26 03:40:33 +04:00
|
|
|
#include "opt_compat_sunos.h"
|
1998-06-26 03:56:39 +04:00
|
|
|
#include "opt_compat_hpux.h"
|
1999-03-10 00:02:38 +03:00
|
|
|
#include "opt_compat_m68k4k.h"
|
2001-07-14 06:06:34 +04:00
|
|
|
#include "opt_compat_mach.h"
|
2002-11-13 02:40:19 +03:00
|
|
|
#include "opt_compat_darwin.h"
|
1998-06-26 04:07:06 +04:00
|
|
|
#include "opt_compat_svr4.h"
|
1999-03-26 07:29:20 +03:00
|
|
|
#include "opt_compat_netbsd32.h"
|
2000-12-02 23:44:09 +03:00
|
|
|
#include "opt_compat_aout_m68k.h"
|
2000-01-17 05:59:25 +03:00
|
|
|
#include "opt_compat_vax1k.h"
|
2000-06-04 20:26:11 +04:00
|
|
|
#include "opt_compat_pecoff.h"
|
2000-11-21 03:37:49 +03:00
|
|
|
#include "opt_compat_osf1.h"
|
|
|
|
#include "opt_compat_ultrix.h"
|
2002-03-23 12:50:54 +03:00
|
|
|
#include "opt_compat_netbsd.h"
|
1998-01-22 04:32:14 +03:00
|
|
|
|
1994-01-16 06:09:59 +03:00
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/exec.h>
|
2001-12-08 03:35:25 +03:00
|
|
|
#include <sys/signalvar.h>
|
1994-01-16 06:09:59 +03:00
|
|
|
|
|
|
|
#ifdef EXEC_SCRIPT
|
|
|
|
#include <sys/exec_script.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef EXEC_AOUT
|
1994-07-01 06:57:52 +04:00
|
|
|
/*#include <sys/exec_aout.h> -- automatically pulled in */
|
1994-01-16 06:09:59 +03:00
|
|
|
#endif
|
|
|
|
|
1999-09-13 14:30:21 +04:00
|
|
|
#ifdef EXEC_COFF
|
2000-01-02 16:39:49 +03:00
|
|
|
#include <sys/exec_coff.h>
|
1999-09-13 14:30:21 +04:00
|
|
|
#endif
|
2000-01-02 16:39:49 +03:00
|
|
|
|
|
|
|
#ifdef EXEC_ECOFF
|
|
|
|
#include <sys/exec_ecoff.h>
|
1999-09-13 14:30:21 +04:00
|
|
|
#endif
|
|
|
|
|
1996-09-27 00:51:03 +04:00
|
|
|
#if defined(EXEC_ELF32) || defined(EXEC_ELF64)
|
1995-06-23 01:29:47 +04:00
|
|
|
#include <sys/exec_elf.h>
|
2000-11-21 03:37:49 +03:00
|
|
|
#define CONCAT(x,y) __CONCAT(x,y)
|
|
|
|
#define ELF32NAME(x) CONCAT(elf,CONCAT(32,CONCAT(_,x)))
|
|
|
|
#define ELF32NAME2(x,y) CONCAT(x,CONCAT(_elf32_,y))
|
|
|
|
#define ELF64NAME(x) CONCAT(elf,CONCAT(64,CONCAT(_,x)))
|
|
|
|
#define ELF64NAME2(x,y) CONCAT(x,CONCAT(_elf64_,y))
|
|
|
|
#ifdef EXEC_ELF32
|
2003-06-30 02:28:00 +04:00
|
|
|
int ELF32NAME2(netbsd,probe)(struct proc *, struct exec_package *,
|
2000-11-21 03:37:49 +03:00
|
|
|
void *, char *, vaddr_t *);
|
2000-11-27 21:04:32 +03:00
|
|
|
#endif
|
|
|
|
#ifdef EXEC_ELF64
|
2003-06-30 02:28:00 +04:00
|
|
|
int ELF64NAME2(netbsd,probe)(struct proc *, struct exec_package *,
|
2000-11-21 03:37:49 +03:00
|
|
|
void *, char *, vaddr_t *);
|
1995-06-23 01:29:47 +04:00
|
|
|
#endif
|
2002-03-23 12:50:54 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Compatibility with old ELF binaries without NetBSD note.
|
|
|
|
* Generic ELF executable kernel support was added in NetBSD 1.1.
|
|
|
|
* The NetBSD note was introduced in NetBSD 1.3 together with initial
|
|
|
|
* ELF shared library support.
|
|
|
|
*/
|
|
|
|
#ifndef EXEC_ELF_NOTELESS
|
|
|
|
# if defined(COMPAT_11) || defined(COMPAT_12)
|
|
|
|
# define EXEC_ELF_NOTELESS 1
|
|
|
|
# endif
|
|
|
|
#endif /* !EXEC_ELF_NOTELESS */
|
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif /* ELF32 || ELF64 */
|
1995-06-23 01:29:47 +04:00
|
|
|
|
2001-07-14 06:06:34 +04:00
|
|
|
#ifdef EXEC_MACHO
|
|
|
|
#include <sys/exec_macho.h>
|
|
|
|
#endif
|
|
|
|
|
1997-12-04 18:33:17 +03:00
|
|
|
#ifdef COMPAT_SUNOS
|
|
|
|
#include <compat/sunos/sunos_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2001-02-11 04:29:43 +03:00
|
|
|
#if defined(COMPAT_SVR4) || defined(COMPAT_SVR4_32)
|
1994-08-16 02:36:40 +04:00
|
|
|
#include <compat/svr4/svr4_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2001-02-11 04:29:43 +03:00
|
|
|
#ifdef COMPAT_SVR4_32
|
|
|
|
#include <compat/svr4_32/svr4_32_exec.h>
|
|
|
|
#endif
|
|
|
|
|
1994-08-16 02:17:16 +04:00
|
|
|
#ifdef COMPAT_IBCS2
|
2000-06-04 20:26:11 +04:00
|
|
|
#include <sys/exec_coff.h>
|
1994-08-16 02:17:16 +04:00
|
|
|
#include <compat/ibcs2/ibcs2_exec.h>
|
2000-11-21 03:37:49 +03:00
|
|
|
#include <machine/ibcs2_machdep.h>
|
1994-08-16 02:17:16 +04:00
|
|
|
#endif
|
|
|
|
|
1995-03-01 02:06:21 +03:00
|
|
|
#ifdef COMPAT_LINUX
|
1998-10-04 00:39:32 +04:00
|
|
|
#include <compat/linux/common/linux_exec.h>
|
1995-03-01 02:06:21 +03:00
|
|
|
#endif
|
|
|
|
|
2002-11-13 02:40:19 +03:00
|
|
|
#ifdef COMPAT_DARWIN
|
|
|
|
#include <compat/darwin/darwin_exec.h>
|
|
|
|
#endif
|
|
|
|
|
1995-10-10 04:26:36 +03:00
|
|
|
#ifdef COMPAT_FREEBSD
|
|
|
|
#include <compat/freebsd/freebsd_exec.h>
|
|
|
|
#endif
|
|
|
|
|
1995-11-28 11:07:25 +03:00
|
|
|
#ifdef COMPAT_HPUX
|
|
|
|
#include <compat/hpux/hpux_exec.h>
|
|
|
|
#endif
|
|
|
|
|
1996-09-11 02:05:03 +04:00
|
|
|
#ifdef COMPAT_M68K4K
|
|
|
|
#include <compat/m68k4k/m68k4k_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2001-07-14 06:06:34 +04:00
|
|
|
#ifdef COMPAT_MACH
|
|
|
|
#include <compat/mach/mach_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2001-11-27 00:38:41 +03:00
|
|
|
#ifdef COMPAT_IRIX
|
|
|
|
#include <compat/irix/irix_exec.h>
|
|
|
|
#endif
|
|
|
|
|
1999-03-26 07:29:20 +03:00
|
|
|
#ifdef COMPAT_NETBSD32
|
|
|
|
#include <compat/netbsd32/netbsd32_exec.h>
|
2001-02-02 10:30:22 +03:00
|
|
|
#ifdef COMPAT_SUNOS
|
|
|
|
#include <compat/sunos32/sunos32_exec.h>
|
|
|
|
#endif
|
1998-08-31 06:46:22 +04:00
|
|
|
#endif
|
|
|
|
|
1998-08-21 17:41:09 +04:00
|
|
|
#ifdef COMPAT_VAX1K
|
|
|
|
#include <compat/vax1k/vax1k_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2000-06-04 20:26:11 +04:00
|
|
|
#ifdef COMPAT_PECOFF
|
|
|
|
#include <sys/exec_coff.h>
|
|
|
|
#include <compat/pecoff/pecoff_exec.h>
|
|
|
|
#endif
|
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_OSF1
|
2000-11-22 06:48:33 +03:00
|
|
|
#include <compat/osf1/osf1.h>
|
2000-11-21 03:37:49 +03:00
|
|
|
#include <compat/osf1/osf1_exec.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef COMPAT_ULTRIX
|
|
|
|
#include <compat/ultrix/ultrix_exec.h>
|
1994-01-16 06:09:59 +03:00
|
|
|
#endif
|
2000-11-21 03:37:49 +03:00
|
|
|
|
|
|
|
extern const struct emul emul_netbsd;
|
2000-12-02 23:44:09 +03:00
|
|
|
#ifdef COMPAT_AOUT_M68K
|
|
|
|
extern const struct emul emul_netbsd_aoutm68k;
|
|
|
|
#endif
|
2000-11-21 03:37:49 +03:00
|
|
|
|
2000-12-08 22:42:11 +03:00
|
|
|
const struct execsw execsw_builtin[] = {
|
1994-01-16 06:09:59 +03:00
|
|
|
#ifdef EXEC_SCRIPT
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Shell scripts */
|
2003-04-02 04:58:56 +04:00
|
|
|
{ SCRIPT_HDR_SIZE,
|
2001-12-08 03:35:25 +03:00
|
|
|
exec_script_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif /* EXEC_SCRIPT */
|
|
|
|
|
1994-01-16 06:09:59 +03:00
|
|
|
#ifdef EXEC_AOUT
|
1999-12-30 18:57:31 +03:00
|
|
|
#ifdef COMPAT_NETBSD32
|
2001-12-08 03:35:25 +03:00
|
|
|
/* 32-bit NetBSD a.out on 64-bit */
|
|
|
|
{ sizeof(struct netbsd32_exec),
|
|
|
|
exec_netbsd32_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd32,
|
|
|
|
EXECSW_PRIO_FIRST,
|
|
|
|
0,
|
|
|
|
netbsd32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd32,
|
|
|
|
exec_setup_stack },
|
2002-05-31 04:52:20 +04:00
|
|
|
#else /* !COMPAT_NETBSD32 */
|
2001-12-08 03:35:25 +03:00
|
|
|
|
|
|
|
/* Native a.out */
|
|
|
|
{ sizeof(struct exec),
|
|
|
|
exec_aout_makecmds,
|
|
|
|
{ NULL },
|
2004-09-14 21:25:37 +04:00
|
|
|
#if defined(COMPAT_AOUT_M68K)
|
2000-12-02 23:44:09 +03:00
|
|
|
&emul_netbsd_aoutm68k,
|
2000-11-21 03:37:49 +03:00
|
|
|
#else
|
|
|
|
&emul_netbsd,
|
1994-01-16 06:09:59 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2002-05-31 04:52:20 +04:00
|
|
|
#endif /* !COMPAT_NETBSD32 */
|
2002-09-04 10:34:21 +04:00
|
|
|
#endif /* EXEC_AOUT */
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1999-09-13 14:30:21 +04:00
|
|
|
#ifdef EXEC_COFF
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Native COFF */
|
|
|
|
{ COFF_HDR_SIZE,
|
|
|
|
exec_coff_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif /* EXEC_COFF */
|
|
|
|
|
2000-01-02 16:39:49 +03:00
|
|
|
#ifdef EXEC_ECOFF
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_OSF1
|
2001-12-08 03:35:25 +03:00
|
|
|
/* OSF/1 (Digital Unix) ECOFF */
|
|
|
|
{ ECOFF_HDR_SIZE,
|
|
|
|
exec_ecoff_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ .ecoff_probe_func = osf1_exec_ecoff_probe },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_osf1,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(OSF1_MAX_AUX_ENTRIES * sizeof (struct osf1_auxv) +
|
|
|
|
2 * (MAXPATHLEN + 1), sizeof (char *)), /* exec & loader names */
|
2001-12-08 03:35:25 +03:00
|
|
|
osf1_copyargs,
|
|
|
|
cpu_exec_ecoff_setregs,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Native ECOFF */
|
|
|
|
{ ECOFF_HDR_SIZE,
|
|
|
|
exec_ecoff_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ .ecoff_probe_func = cpu_exec_ecoff_probe },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
cpu_exec_ecoff_setregs,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_ULTRIX
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Ultrix ECOFF */
|
|
|
|
{ ECOFF_HDR_SIZE,
|
|
|
|
exec_ecoff_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ .ecoff_probe_func = ultrix_exec_ecoff_probe },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_ultrix,
|
|
|
|
EXECSW_PRIO_LAST, /* XXX probe func alw. succeeds */
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
cpu_exec_ecoff_setregs,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif
|
|
|
|
#endif /* EXEC_ECOFF */
|
|
|
|
|
1996-09-27 00:51:03 +04:00
|
|
|
#ifdef EXEC_ELF32
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_NETBSD32
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Elf32 NetBSD on 64-bit */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(netbsd32,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_netbsd32,
|
|
|
|
EXECSW_PRIO_FIRST,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
netbsd32_elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack }, /* XXX XXX XXX */
|
2002-05-31 04:52:20 +04:00
|
|
|
/* This one should go first so it matches instead of native */
|
|
|
|
|
|
|
|
#ifdef COMPAT_SVR4_32
|
|
|
|
/* SVR4 Elf32 on 64-bit */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
|
|
|
{ ELF32NAME2(svr4_32,probe) },
|
|
|
|
&emul_svr4_32,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
SVR4_32_AUX_ARGSIZ,
|
|
|
|
svr4_32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack }, /* XXX XXX XXX */
|
2001-12-08 03:35:25 +03:00
|
|
|
/* This one should go first so it matches instead of native */
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2002-05-31 04:52:20 +04:00
|
|
|
#if 0
|
|
|
|
#if EXEC_ELF_NOTELESS
|
|
|
|
/* Generic compat Elf32 -- run as compat NetBSD Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
|
|
|
{ ELF32NAME2(netbsd32,probe_noteless) },
|
|
|
|
&emul_netbsd32,
|
|
|
|
EXECSW_PRIO_FIRST,
|
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
|
|
|
netbsd32_elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack }, /* XXX XXX XXX */
|
2002-05-31 04:52:20 +04:00
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#else /* !COMPAT_NETBSD32 */
|
|
|
|
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Native Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(netbsd,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_FREEBSD
|
2001-12-08 03:35:25 +03:00
|
|
|
/* FreeBSD Elf32 (probe not 64-bit safe) */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(freebsd,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_freebsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
2003-02-19 12:44:42 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof(Elf32_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
1996-09-27 00:51:03 +04:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_LINUX
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Linux Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(linux,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_linux,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
LINUX_ELF_AUX_ARGSIZ,
|
2002-11-13 18:16:27 +03:00
|
|
|
linux_elf32_copyargs,
|
2001-12-08 03:35:25 +03:00
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
linux_exec_setup_stack },
|
2001-07-14 06:06:34 +04:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2005-02-27 00:34:55 +03:00
|
|
|
#ifdef COMPAT_IRIX
|
2002-01-08 01:07:37 +03:00
|
|
|
/* IRIX Elf32 n32 ABI */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
|
|
|
{ ELF32NAME2(irix,probe_n32) },
|
2002-11-30 16:19:37 +03:00
|
|
|
&emul_irix,
|
2002-01-08 01:07:37 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
IRIX_AUX_ARGSIZ,
|
|
|
|
irix_elf32_copyargs,
|
2002-11-30 16:19:37 +03:00
|
|
|
irix_n32_setregs,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2002-01-08 01:07:37 +03:00
|
|
|
|
|
|
|
/* IRIX Elf32 o32 ABI */
|
2001-12-08 03:35:25 +03:00
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2002-01-08 01:07:37 +03:00
|
|
|
{ ELF32NAME2(irix,probe_o32) },
|
2002-11-30 16:19:37 +03:00
|
|
|
&emul_irix,
|
2001-12-08 03:35:25 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
2001-11-27 00:38:41 +03:00
|
|
|
IRIX_AUX_ARGSIZ,
|
2001-12-08 03:35:25 +03:00
|
|
|
irix_elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2001-11-27 00:38:41 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_SVR4
|
2001-12-08 03:35:25 +03:00
|
|
|
/* SVR4 Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(svr4,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_svr4,
|
|
|
|
EXECSW_PRIO_ANY,
|
2002-08-27 01:07:38 +04:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
|
|
|
elf32_copyargs,
|
2001-12-08 03:35:25 +03:00
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_IBCS2
|
2001-12-08 03:35:25 +03:00
|
|
|
/* SCO Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF32NAME2(ibcs2,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_ibcs2,
|
|
|
|
EXECSW_PRIO_ANY,
|
2003-02-19 12:44:42 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2002-03-23 12:50:54 +03:00
|
|
|
#if EXEC_ELF_NOTELESS
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Generic Elf32 -- run at NetBSD Elf32 */
|
|
|
|
{ sizeof (Elf32_Ehdr),
|
|
|
|
exec_elf32_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_LAST,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof (Elf32_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf32,
|
|
|
|
exec_setup_stack },
|
2001-06-19 21:58:41 +04:00
|
|
|
#endif
|
2002-05-31 04:52:20 +04:00
|
|
|
#endif /* !COMPAT_NETBSD32 */
|
2002-09-04 10:34:21 +04:00
|
|
|
#endif /* EXEC_ELF32 */
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef EXEC_ELF64
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Native Elf64 */
|
|
|
|
{ sizeof (Elf64_Ehdr),
|
|
|
|
exec_elf64_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF64NAME2(netbsd,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux64Info), sizeof (Elf64_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf64_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf64,
|
|
|
|
exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-11-21 03:37:49 +03:00
|
|
|
#ifdef COMPAT_LINUX
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Linux Elf64 */
|
|
|
|
{ sizeof (Elf64_Ehdr),
|
|
|
|
exec_elf64_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF64NAME2(linux,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_linux,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
LINUX_ELF_AUX_ARGSIZ,
|
2001-12-08 03:35:25 +03:00
|
|
|
linux_elf64_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf64,
|
2005-05-03 20:26:27 +04:00
|
|
|
linux_exec_setup_stack },
|
2001-03-03 04:46:04 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2001-03-03 04:46:04 +03:00
|
|
|
#ifdef COMPAT_SVR4
|
2001-12-08 03:35:25 +03:00
|
|
|
/* SVR4 Elf64 */
|
|
|
|
{ sizeof (Elf64_Ehdr),
|
|
|
|
exec_elf64_makecmds,
|
2001-05-15 06:00:12 +04:00
|
|
|
{ ELF64NAME2(svr4,probe) },
|
2001-12-08 03:35:25 +03:00
|
|
|
&emul_svr4,
|
|
|
|
EXECSW_PRIO_ANY,
|
2002-08-27 01:07:38 +04:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux64Info), sizeof (Elf64_Addr)),
|
|
|
|
elf64_copyargs,
|
2001-12-08 03:35:25 +03:00
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf64,
|
|
|
|
exec_setup_stack },
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2002-03-23 12:50:54 +03:00
|
|
|
#if EXEC_ELF_NOTELESS
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Generic Elf64 -- run at NetBSD Elf64 */
|
|
|
|
{ sizeof (Elf64_Ehdr),
|
|
|
|
exec_elf64_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(ELF_AUX_ENTRIES * sizeof(Aux64Info), sizeof (Elf64_Addr)),
|
2001-12-08 03:35:25 +03:00
|
|
|
elf64_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_elf64,
|
|
|
|
exec_setup_stack },
|
2001-06-19 21:58:41 +04:00
|
|
|
#endif
|
2000-11-21 03:37:49 +03:00
|
|
|
#endif /* EXEC_ELF64 */
|
2001-12-08 03:35:25 +03:00
|
|
|
|
|
|
|
#if defined(EXEC_MACHO)
|
2003-10-19 11:52:22 +04:00
|
|
|
#ifdef COMPAT_DARWIN
|
|
|
|
/* Darwin Mach-O (native word size) */
|
2001-12-08 03:35:25 +03:00
|
|
|
{ sizeof (struct exec_macho_fat_header),
|
|
|
|
exec_macho_makecmds,
|
2003-10-19 11:52:22 +04:00
|
|
|
{ .mach_probe_func = exec_darwin_probe },
|
|
|
|
&emul_darwin,
|
2001-12-08 03:35:25 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
MAXPATHLEN + 1,
|
2003-10-19 11:52:22 +04:00
|
|
|
exec_darwin_copyargs,
|
2001-12-08 03:35:25 +03:00
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
2004-07-03 04:14:30 +04:00
|
|
|
darwin_exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif
|
2002-11-13 02:40:19 +03:00
|
|
|
|
2003-10-19 11:52:22 +04:00
|
|
|
#ifdef COMPAT_MACH
|
|
|
|
/* Mach MACH-O (native word size) */
|
2002-11-13 02:40:19 +03:00
|
|
|
{ sizeof (struct exec_macho_fat_header),
|
|
|
|
exec_macho_makecmds,
|
2003-10-19 11:52:22 +04:00
|
|
|
{ .mach_probe_func = exec_mach_probe },
|
|
|
|
&emul_mach,
|
2002-11-13 02:40:19 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
MAXPATHLEN + 1,
|
2003-10-19 11:52:22 +04:00
|
|
|
exec_mach_copyargs,
|
2002-11-13 02:40:19 +03:00
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2002-11-13 02:40:19 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif /* EXEC_MACHO */
|
|
|
|
|
1997-12-04 18:33:17 +03:00
|
|
|
#ifdef COMPAT_SUNOS
|
2001-02-02 10:30:22 +03:00
|
|
|
#ifdef COMPAT_NETBSD32
|
2001-12-08 03:35:25 +03:00
|
|
|
/* 32-bit SunOS a.out on 64-bit */
|
|
|
|
{ SUNOS32_AOUT_HDR_SIZE,
|
|
|
|
exec_sunos32_aout_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_sunos,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
netbsd32_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-02-02 10:30:22 +03:00
|
|
|
#else
|
2001-12-08 03:35:25 +03:00
|
|
|
/* SunOS a.out (native word size) */
|
|
|
|
{ SUNOS_AOUT_HDR_SIZE,
|
|
|
|
exec_sunos_aout_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_sunos,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2001-02-02 10:30:22 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
#endif /* COMPAT_SUNOS */
|
|
|
|
|
1998-10-01 19:55:34 +04:00
|
|
|
#if defined(COMPAT_LINUX) && defined(EXEC_AOUT)
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Linux a.out (native word size) */
|
|
|
|
{ LINUX_AOUT_HDR_SIZE,
|
|
|
|
exec_linux_aout_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_linux,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
LINUX_AOUT_AUX_ARGSIZ,
|
|
|
|
linux_aout_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
linux_exec_setup_stack },
|
1995-03-01 02:06:21 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1994-08-16 02:17:16 +04:00
|
|
|
#ifdef COMPAT_IBCS2
|
2001-12-08 03:35:25 +03:00
|
|
|
/* iBCS2 COFF (native word size) */
|
|
|
|
{ COFF_HDR_SIZE,
|
|
|
|
exec_ibcs2_coff_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_ibcs2,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
2005-03-03 07:39:37 +03:00
|
|
|
ibcs2_exec_setup_stack },
|
2001-12-08 03:35:25 +03:00
|
|
|
|
|
|
|
/* iBCS2 x.out (native word size) */
|
|
|
|
{ XOUT_HDR_SIZE,
|
|
|
|
exec_ibcs2_xout_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_ibcs2,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
2005-03-03 07:39:37 +03:00
|
|
|
ibcs2_exec_setup_stack },
|
1994-08-16 02:17:16 +04:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1999-02-23 21:19:29 +03:00
|
|
|
#if defined(COMPAT_FREEBSD) && defined(EXEC_AOUT)
|
2001-12-08 03:35:25 +03:00
|
|
|
/* FreeBSD a.out (native word size) */
|
|
|
|
{ FREEBSD_AOUT_HDR_SIZE,
|
|
|
|
exec_freebsd_aout_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_freebsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
1995-10-10 04:26:36 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1995-11-28 11:07:25 +03:00
|
|
|
#ifdef COMPAT_HPUX
|
2001-12-08 03:35:25 +03:00
|
|
|
/* HP-UX a.out for m68k (native word size) */
|
|
|
|
{ HPUX_EXEC_HDR_SIZE,
|
|
|
|
exec_hpux_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_hpux,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
1995-11-28 11:07:25 +03:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1996-09-11 02:05:03 +04:00
|
|
|
#ifdef COMPAT_M68K4K
|
2001-12-08 03:35:25 +03:00
|
|
|
/* NetBSD a.out for m68k4k */
|
|
|
|
{ sizeof(struct exec),
|
|
|
|
exec_m68k4k_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
1996-09-11 02:05:03 +04:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
1998-08-21 17:41:09 +04:00
|
|
|
#ifdef COMPAT_VAX1K
|
2001-12-08 03:35:25 +03:00
|
|
|
/* NetBSD vax1k a.out */
|
|
|
|
{ sizeof(struct exec),
|
|
|
|
exec_vax1k_makecmds,
|
|
|
|
{ NULL },
|
|
|
|
&emul_netbsd,
|
|
|
|
EXECSW_PRIO_ANY,
|
|
|
|
0,
|
|
|
|
copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
1998-08-21 17:41:09 +04:00
|
|
|
#endif
|
2001-12-08 03:35:25 +03:00
|
|
|
|
2000-06-04 20:26:11 +04:00
|
|
|
#ifdef COMPAT_PECOFF
|
2001-12-08 03:35:25 +03:00
|
|
|
/* Win32/WinCE PE/COFF (native word size) */
|
2002-03-18 10:11:06 +03:00
|
|
|
{ PECOFF_HDR_SIZE,
|
2001-12-08 03:35:25 +03:00
|
|
|
exec_pecoff_makecmds,
|
|
|
|
{ NULL },
|
2002-03-18 10:11:06 +03:00
|
|
|
&emul_pecoff,
|
2001-12-08 03:35:25 +03:00
|
|
|
EXECSW_PRIO_ANY,
|
2000-11-21 03:37:49 +03:00
|
|
|
howmany(sizeof(struct pecoff_args), sizeof(char *)),
|
2001-12-08 03:35:25 +03:00
|
|
|
pecoff_copyargs,
|
|
|
|
NULL,
|
2003-08-08 22:53:13 +04:00
|
|
|
coredump_netbsd,
|
|
|
|
exec_setup_stack },
|
2000-06-04 20:26:11 +04:00
|
|
|
#endif
|
1994-01-16 06:09:59 +03:00
|
|
|
};
|
2000-12-08 22:42:11 +03:00
|
|
|
int nexecs_builtin = (sizeof(execsw_builtin) / sizeof(struct execsw));
|