NetBSD/sys/compat/linux32/arch/amd64/linux32_exec.h
chs 33fa5ccbbf many changes for COMPAT_LINUX:
- update the linux syscall table for each platform.
 - support new-style (NPTL) linux pthreads on all platforms.
   clone() with CLONE_THREAD uses 1 process with many LWPs
   instead of separate processes.
 - move the contents of sys__lwp_setprivate() into a new
   lwp_setprivate() and use that everywhere.
 - update linux_release[] and linux32_release[] to "2.6.18".
 - adjust placement of emul fork/exec/exit hooks as needed
   and adjust other emul code to match.
 - convert all struct emul definitions to use named initializers.
 - change the pid allocator to allow multiple pids to refer to the same proc.
 - remove a few fields from struct proc that are no longer needed.
 - disable the non-functional "vdso" code in linux32/amd64,
   glibc works fine without it.
 - fix a race in the futex code where we could miss a wakeup after
   a requeue operation.
 - redo futex locking to be a little more efficient.
2010-07-07 01:30:32 +00:00

85 lines
3.1 KiB
C

/* $NetBSD: linux32_exec.h,v 1.4 2010/07/07 01:30:35 chs Exp $ */
/*-
* Copyright (c) 2006 Emmanuel Dreyfus, 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 Emmanuel Dreyfus
* 4. The name of the author may not be used to endorse or promote
* products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS
* 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.
*/
#ifndef _AMD64_LINUX32_EXEC_H
#define _AMD64_LINUX32_EXEC_H
#include <sys/exec_elf.h>
#define LINUX32_M_I386 100
#define LINUX32_MID_MACHINE LINUX_M_I386
#define LINUX32_USRSTACK 0xC0000000
#define LINUX32_DEBUGLINK_SIGNATURE 1
#define LINUX32_ELF_AUX_ENTRIES 14
#if 0
/* Hardware platform identifier string */
#define LINUX32_PLATFORM "i686"
#define LINUX32_CPUCAP (cpu_feature[0])
/* vsyscall assembly */
static char linux32_kernel_vsyscall[] = {
0x55, /* push %ebp */ \
0x89, 0xcd, /* mov %ecx,%ebp */ \
0x0f, 0x05, /* syscall */ \
0xb9, 0x7b, 0x00, 0x00, 0x00, /* mov $0x7b,%ecx */ \
0x8e, 0xd1, /* movl %ecx,%ss */ \
0x89, 0xe9, /* mov %ebp,%ecx */ \
0x5d, /* pop %ebp */ \
0xc3, /* ret */ \
};
/* The extra data (ELF auxiliary table and platform name) on stack */
struct linux32_extra_stack_data {
Aux32Info ai[LINUX32_ELF_AUX_ENTRIES];
char hw_platform[sizeof(LINUX32_PLATFORM)];
int pad;
Elf32_Ehdr elfhdr;
char kernel_vsyscall[sizeof(linux32_kernel_vsyscall)];
};
#define LINUX32_ELF_AUX_ARGSIZ sizeof(struct linux32_extra_stack_data)
#endif
#define LINUX32_ELF_AUX_ARGSIZ \
(howmany(LINUX32_ELF_AUX_ENTRIES * sizeof(Aux32Info), sizeof(Elf32_Addr)))
#ifdef _KERNEL
int linux32_exec_setup_stack(struct lwp *, struct exec_package *);
#endif
#endif /* !_AMD64_LINUX32_EXEC_H */