* files for more information.
*/
-/*
- * $Header$
- */
-
#include <stdio.h>
#include "runtime.h"
#include "sbcl.h"
#include "globals.h"
+#include "validate.h"
int foreign_function_call_active;
lispobj *current_binding_stack_pointer;
#endif
-lispobj *read_only_space;
-lispobj *static_space;
-lispobj *control_stack;
-#ifdef __i386__
-lispobj *control_stack_end;
-#endif
-lispobj *binding_stack;
+/* ALLOCATION_POINTER is more or less synonymous with RT, it seems.
+ * Anyone want to do an RT port of sbcl?
+ */
#ifndef ALLOCATION_POINTER
+/* The Object Formerly Known As current_dynamic_space_free_pointer */
lispobj *dynamic_space_free_pointer;
#endif
+
#ifndef INTERNAL_GC_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;
+
void globals_init(void)
{
/* Space, stack, and free pointer vars are initialized by
foreign_function_call_active = 1;
/* Initialize the current Lisp state. */
-#ifndef __i386__
- current_control_stack_pointer = control_stack;
+#ifndef __i386__ /* if stack grows upward */
+ current_control_stack_pointer = (lispobj *)CONTROL_STACK_START;
#else
- current_control_stack_pointer = control_stack_end;
+ current_control_stack_pointer = (lispobj *)CONTROL_STACK_END;
#endif
current_control_frame_pointer = (lispobj *)0;
#ifndef BINDING_STACK_POINTER
- current_binding_stack_pointer = binding_stack;
+ current_binding_stack_pointer = BINDING_STACK_START;
#endif
}