34b3b26b3b
23139 into trunk, with roughly the following changes (for details svn log the branch): * The int 99 syscall handler is now fully in assembly. * Added a sysenter/sysexit handler and use it on Pentiums that support it (via commpage). * Got rid of i386_handle_trap(). A bit of functionality was moved into the assembly handler which now uses a jump table to call C functions handling the respective interrupt. * Some optimizations to get user debugger support code out of the interrupt handling path. * Introduced a thread::flags fields which allows to skip handling of rare events (signals, user debug enabling/disabling) on the common interrupt handling path. * Got rid of the explicit iframe stack. The iframes can still be retrieved by iterating through the stack frames. * Made the commpage an architecture independent feature. It's used for the real time data stuff (instead of creating a separate area). * The x86 CPU modules can now provide processor optimized versions for common functions (currently memcpy() only). They are used in the kernel and are provided to the userland via commpage entries. * Introduced build system feature allowing easy use of C structure member offsets in assembly code. Changes after merging: * Fixed merge conflict in src/system/kernel/arch/x86/arch_debug.cpp (caused by refactoring and introduction of "call" debugger command). git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23370 a95241bf-73f2-0310-859d-f6bbb57e9c96
33 lines
1.1 KiB
C
33 lines
1.1 KiB
C
/*
|
|
** Copyright 2001-2002, Travis Geiselbrecht. All rights reserved.
|
|
** Distributed under the terms of the NewOS License.
|
|
*/
|
|
#ifndef _KERNEL_ARCH_x86_KERNEL_H
|
|
#define _KERNEL_ARCH_x86_KERNEL_H
|
|
|
|
#ifndef _ASSEMBLER
|
|
# include <arch/cpu.h>
|
|
#endif
|
|
|
|
// memory layout
|
|
#define KERNEL_BASE 0x80000000
|
|
#define KERNEL_SIZE 0x80000000
|
|
#define KERNEL_TOP (KERNEL_BASE + (KERNEL_SIZE - 1))
|
|
|
|
/*
|
|
** User space layout is a little special:
|
|
** The user space does not completely cover the space not covered by the kernel.
|
|
** This is accomplished by starting user space at 1Mb and running to 64kb short of kernel space.
|
|
** The lower 1Mb reserved spot makes it easy to find null pointer references and guarantees a
|
|
** region wont be placed there. The 64kb region assures a user space thread cannot pass
|
|
** a buffer into the kernel as part of a syscall that would cross into kernel space.
|
|
*/
|
|
#define USER_BASE 0x100000
|
|
#define USER_SIZE (0x80000000 - (0x10000 + 0x100000))
|
|
#define USER_TOP (USER_BASE + USER_SIZE)
|
|
|
|
#define USER_STACK_REGION 0x70000000
|
|
#define USER_STACK_REGION_SIZE (USER_TOP - USER_STACK_REGION)
|
|
|
|
#endif /* _KERNEL_ARCH_x86_KERNEL_H */
|