0.7.13.5
[sbcl.git] / src / runtime / globals.c
index 691bfb1..e266ba4 100644 (file)
  * files for more information.
  */
 
-/*
- * $Header$
- */
-
 #include <stdio.h>
+#include <sys/types.h>
+#include <unistd.h>
 
 #include "runtime.h"
 #include "sbcl.h"
 #include "globals.h"
+#include "validate.h"
 
 int foreign_function_call_active;
 
@@ -31,30 +30,32 @@ lispobj *current_control_frame_pointer;
 lispobj *current_binding_stack_pointer;
 #endif
 
-lispobj *read_only_space;
-lispobj *static_space;
-lispobj *dynamic_0_space;
-lispobj *dynamic_1_space;
-lispobj *control_stack;
-#ifdef __i386__
-lispobj *control_stack_end;
-#endif
-lispobj *binding_stack;
+/* ALLOCATION_POINTER is x86 or RT.  Anyone want to do an RT port?   */
 
-lispobj *current_dynamic_space;
 #ifndef ALLOCATION_POINTER
-lispobj *current_dynamic_space_free_pointer;
+/* The Object Formerly Known As current_dynamic_space_free_pointer */
+lispobj *dynamic_space_free_pointer;
 #endif
-#ifndef INTERNAL_GC_TRIGGER
+
+#ifndef LISP_FEATURE_GENCGC /* GENCGC has its own way to record trigger */
 lispobj *current_auto_gc_trigger;
 #endif
 
+/* For copying GCs, this points to the start of the dynamic space
+ * currently in use (that will become the from_space when the next GC
+ * is done).  For the GENCGC, it always points to DYNAMIC_SPACE_START. */
+lispobj *current_dynamic_space;
+
+boolean stop_the_world=0;
+pid_t parent_pid;
+
 void globals_init(void)
 {
     /* Space, stack, and free pointer vars are initialized by
      * validate() and coreparse(). */
+    current_control_frame_pointer = (lispobj *)0;
 
-#ifndef INTERNAL_GC_TRIGGER
+#ifndef LISP_FEATURE_GENCGC 
     /* no GC trigger yet */
     current_auto_gc_trigger = NULL;
 #endif
@@ -63,14 +64,14 @@ void globals_init(void)
     foreign_function_call_active = 1;
 
     /* Initialize the current Lisp state. */
-#ifndef __i386__
-    current_control_stack_pointer = control_stack;
+#ifdef LISP_FEATURE_STACK_GROWS_DOWNWARD_NOT_UPWARD
+    current_control_stack_pointer = (lispobj *)CONTROL_STACK_END;
 #else
-    current_control_stack_pointer = control_stack_end;
+    current_control_stack_pointer = (lispobj *)CONTROL_STACK_START;
 #endif
 
     current_control_frame_pointer = (lispobj *)0;
 #ifndef BINDING_STACK_POINTER
-    current_binding_stack_pointer = binding_stack;
+    current_binding_stack_pointer = native_pointer(BINDING_STACK_START);
 #endif
 }