X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fglobals.h;h=71f30850e79a10356fd637e541cf0a2989956505;hb=d4d6c4b16a3655ce99a87d43f411391363531260;hp=5b451818c984ffc8b75d9b97e009404b5dc48940;hpb=a4e7c6bc705d739360dfaa9c3c652fd4a05d6c06;p=sbcl.git diff --git a/src/runtime/globals.h b/src/runtime/globals.h index 5b45181..71f3085 100644 --- a/src/runtime/globals.h +++ b/src/runtime/globals.h @@ -9,76 +9,94 @@ * files for more information. */ -#if !defined(_INCLUDE_GLOBALS_H_) +#ifndef _INCLUDED_GLOBALS_H_ #define _INCLUDED_GLOBALS_H_ #ifndef LANGUAGE_ASSEMBLY +# include +# include +# include "runtime.h" +#endif -#include "runtime.h" +#include "sbcl.h" +#ifndef LANGUAGE_ASSEMBLY extern int foreign_function_call_active; +extern boolean stop_the_world; + +#if defined(LISP_FEATURE_SB_THREAD) +extern pthread_key_t specials; +#endif extern lispobj *current_control_stack_pointer; extern lispobj *current_control_frame_pointer; -#if !defined(ibmrt) && !defined(__i386__) +# if !defined(LISP_FEATURE_X86) && !defined(LISP_FEATURE_X86_64) extern lispobj *current_binding_stack_pointer; -#endif +# endif -#if !defined(ibmrt) && !defined(__i386__) -/* FIXME: Why doesn't the x86 need this? */ +# ifndef LISP_FEATURE_GENCGC +/* Beware! gencgc has also a (non-global) dynamic_space_free_pointer. */ extern lispobj *dynamic_space_free_pointer; extern lispobj *current_auto_gc_trigger; -#endif +# endif extern lispobj *current_dynamic_space; extern void globals_init(void); -#else LANGUAGE_ASSEMBLY +#else /* LANGUAGE_ASSEMBLY */ -#ifdef mips -#define EXTERN(name,bytes) .extern name bytes -#endif +# ifdef LISP_FEATURE_MIPS +# ifdef __linux__ +# define EXTERN(name,bytes) .globl name +# else +# define EXTERN(name,bytes) .extern name bytes +# endif +# endif /**/ -#ifdef sparc -#ifdef SVR4 -#define EXTERN(name,bytes) .global name -#else -#define EXTERN(name,bytes) .global _ ## name -#endif -#endif +# ifdef LISP_FEATURE_SPARC +# ifdef SVR4 +# define EXTERN(name,bytes) .global name +# else +# define EXTERN(name,bytes) .global _ ## name +# endif +# endif /**/ -#ifdef ibmrt -#define EXTERN(name,bytes) .globl _/**/name -#endif +# ifdef LISP_FEATURE_ALPHA +# ifdef __linux__ +# define EXTERN(name,bytes) .globl name +# endif +# endif /**/ -#ifdef alpha -#ifdef linux -#define EXTERN(name,bytes) .globl name -#endif -#endif -#ifdef __i386__ -#ifdef __linux__ -/* I'm very dubious about this. Linux hasn't used _ on external names - * since ELF became prevalent - i.e. about 1996, on x86 -dan 20010125 */ -#define EXTERN(name,bytes) .globl _/**/name -#else -#define EXTERN(name,bytes) .global _ ## name -#endif -#endif +# ifdef LISP_FEATURE_PPC +# ifdef LISP_FEATURE_DARWIN +# define EXTERN(name,bytes) .globl _/**/name +# else +# define EXTERN(name,bytes) .globl name +# endif +# endif +/**/ +# if defined(LISP_FEATURE_X86) || defined(LISP_FEATURE_X86_64) +# define EXTERN(name,bytes) .global name +# endif -EXTERN(foreign_function_call_active, 4) +# if defined(LISP_FEATURE_ALPHA) || defined(LISP_FEATURE_X86_64) +# define POINTERSIZE 8 +# else +# define POINTERSIZE 4 +# endif -EXTERN(current_control_stack_pointer, 4) -EXTERN(current_control_frame_pointer, 4) -EXTERN(current_binding_stack_pointer, 4) -EXTERN(dynamic_space_free_pointer, 4) -EXTERN(current_dynamic_space, 4) +EXTERN(foreign_function_call_active, 4) -#ifdef mips -EXTERN(current_flags_register, 4) -#endif +EXTERN(current_control_stack_pointer, POINTERSIZE) +EXTERN(current_control_frame_pointer, POINTERSIZE) +# if !defined(LISP_FEATURE_X86) && !defined(LISP_FEATURE_X86_64) +EXTERN(current_binding_stack_pointer, POINTERSIZE) +# endif +# ifndef LISP_FEATURE_GENCGC +EXTERN(dynamic_space_free_pointer, POINTERSIZE) +# endif -#endif LANGUAGE_ASSEMBLY +#endif /* LANGUAGE_ASSEMBLY */ -#endif _INCLUDED_GLOBALS_H_ +#endif /* _INCLUDED_GLOBALS_H_ */