From d0583fb59b0d5e243c9141d649b82bac577f5aa9 Mon Sep 17 00:00:00 2001 From: William Harold Newman Date: Wed, 18 Oct 2000 21:39:21 +0000 Subject: [PATCH] 0.6.7.14: Some constant C vars are now constants. --- src/code/debug-int.lisp | 2 +- src/code/gc.lisp | 1 - src/compiler/generic/genesis.lisp | 70 ++++++++++++++++++------- src/runtime/coreparse.c | 10 ++-- src/runtime/gencgc.c | 102 ++++++++++++++++++++++++------------- src/runtime/globals.c | 5 +- src/runtime/globals.h | 3 -- src/runtime/parse.c | 17 ++++--- src/runtime/purify.c | 16 ++++-- src/runtime/runtime.c | 3 +- src/runtime/save.c | 9 ++-- src/runtime/validate.c | 14 ++--- version.lisp-expr | 2 +- 13 files changed, 159 insertions(+), 95 deletions(-) diff --git a/src/code/debug-int.lisp b/src/code/debug-int.lisp index 0bead79..b729c2b 100644 --- a/src/code/debug-int.lisp +++ b/src/code/debug-int.lisp @@ -2480,7 +2480,7 @@ (< sb!vm:static-space-start val (* sb!vm:*static-space-free-pointer* sb!vm:word-bytes)) - (< (sb!vm:dynamic-space-start) val + (< sb!vm:dynamic-space-start val (sap-int (dynamic-space-free-pointer)))))) (make-lisp-obj val) :invalid-object)) diff --git a/src/code/gc.lisp b/src/code/gc.lisp index e0bc9de..c87ebed 100644 --- a/src/code/gc.lisp +++ b/src/code/gc.lisp @@ -28,7 +28,6 @@ (def-c-var-frob sb!vm:control-stack-start "control_stack") #!+x86 (def-c-var-frob control-stack-end "control_stack_end") -(def-c-var-frob sb!vm:binding-stack-start "binding_stack") #!-sb-fluid (declaim (inline dynamic-usage)) (def-c-var-frob dynamic-usage "bytes_allocated") diff --git a/src/compiler/generic/genesis.lisp b/src/compiler/generic/genesis.lisp index 3dd6e37..7087f6f 100644 --- a/src/compiler/generic/genesis.lisp +++ b/src/compiler/generic/genesis.lisp @@ -2500,6 +2500,7 @@ (defun write-c-header () + ;; writing beginning boilerplate (format t "/*~%") (dolist (line '("This is a machine-generated file. Do not edit it by hand." @@ -2514,17 +2515,16 @@ (format t " * ~A~%" line)) (format t " */~%") (terpri) - (format t "#ifndef _SBCL_H_~%#define _SBCL_H_~%") (terpri) + ;; writing miscellaneous constants (format t "#define SBCL_CORE_VERSION_INTEGER ~D~%" sbcl-core-version-integer) (format t "#define SBCL_VERSION_STRING ~S~%" (sb!xc:lisp-implementation-version)) (format t "#define CORE_MAGIC 0x~X~%" core-magic) (terpri) - ;; FIXME: Other things from core.h should be defined here too: ;; #define CORE_END 3840 ;; #define CORE_NDIRECTORY 3861 @@ -2537,6 +2537,7 @@ ;; #define STATIC_SPACE_ID (2) ;; #define READ_ONLY_SPACE_ID (3) + ;; writing entire families of named constants from SB!VM (let ((constants nil)) (do-external-symbols (symbol (find-package "SB!VM")) (when (constantp symbol) @@ -2579,7 +2580,7 @@ (test-tail "-SUBTYPE" "subtype_" 3) (test-head "TRACE-TABLE-" "tracetab_" 4) (test-tail "-SC-NUMBER" "sc_" 5) - ;; This simpler style of munging of names seems less + ;; This simpler style of translation of names seems less ;; confusing, and is used for newer code. (when (some (lambda (suffix) (tail-comp name suffix)) #("-START" "-END")) @@ -2592,23 +2593,50 @@ (< (second const1) (second const2)))))) (let ((prev-priority (second (car constants)))) (dolist (const constants) - (unless (= prev-priority (second const)) - (terpri) - (setf prev-priority (second const))) - (format t - "#define ~A ~D /* 0x~X */~@[ /* ~A */~]~%" - (first const) - (third const) - (third const) - (fourth const)))) - (terpri) - (format t "#define ERRORS { \\~%") - ;; FIXME: Is this just DO-VECTOR? - (let ((internal-errors sb!c:*backend-internal-errors*)) - (dotimes (i (length internal-errors)) - (format t " ~S, /*~D*/ \\~%" (cdr (aref internal-errors i)) i))) - (format t " NULL \\~%}~%") + (destructuring-bind (name priority value doc) const + (unless (= prev-priority priority) + (terpri) + (setf prev-priority priority)) + (format t "#define ~A " name) + (format t + ;; KLUDGE: As of sbcl-0.6.7.14, we're dumping two + ;; different kinds of values here, (1) small codes + ;; and (2) machine addresses. The small codes can be + ;; dumped as bare integer values. The large machine + ;; addresses might cause problems if they're large + ;; and represented as (signed) C integers, so we + ;; want to force them to be unsigned. We do that by + ;; wrapping them in the LISPOBJ macro. (We could do + ;; it with a bare "(unsigned)" cast, except that + ;; this header file is used not only in C files, but + ;; also in assembly files, which don't understand + ;; the cast syntax. The LISPOBJ macro goes away in + ;; assembly files, but that shouldn't matter because + ;; we don't do arithmetic on address constants in + ;; assembly files. See? It really is a kludge..) -- + ;; WHN 2000-10-18 + (let (;; cutoff for treatment as a small code + (cutoff (expt 2 16))) + (cond ((minusp value) + (error "stub: negative values unsupported")) + ((< value cutoff) + "~D") + (t + "LISPOBJ(~D)"))) + value) + (format t " /* 0x~X */~@[ /* ~A */~]~%" value doc)))) (terpri)) + + ;; writing codes/strings for internal errors + (format t "#define ERRORS { \\~%") + ;; FIXME: Is this just DO-VECTOR? + (let ((internal-errors sb!c:*backend-internal-errors*)) + (dotimes (i (length internal-errors)) + (format t " ~S, /*~D*/ \\~%" (cdr (aref internal-errors i)) i))) + (format t " NULL \\~%}~%") + (terpri) + + ;; writing primitive object layouts (let ((structs (sort (copy-list sb!vm:*primitive-objects*) #'string< :key #'(lambda (obj) (symbol-name @@ -2642,6 +2670,8 @@ (- (* (sb!vm:slot-offset slot) sb!vm:word-bytes) lowtag))) (terpri)))) (format t "#endif /* LANGUAGE_ASSEMBLY */~2%")) + + ;; writing static symbol offsets (dolist (symbol (cons nil sb!vm:*static-symbols*)) ;; FIXME: It would be nice to use longer names NIL and (particularly) T ;; in #define statements. @@ -2658,6 +2688,8 @@ sb!vm:word-bytes sb!vm:other-pointer-type (if symbol (sb!vm:static-symbol-offset symbol) 0))))) + + ;; Voila. (format t "~%#endif~%")) ;;;; writing map file diff --git a/src/runtime/coreparse.c b/src/runtime/coreparse.c index 9239489..b655601 100644 --- a/src/runtime/coreparse.c +++ b/src/runtime/coreparse.c @@ -66,7 +66,7 @@ static void process_directory(int fd, long *ptr, int count) switch (id) { case DYNAMIC_SPACE_ID: if (addr != (os_vm_address_t)DYNAMIC_SPACE_START) { - lose("incorrect dynamic space"); + lose("core/runtime address mismatch: DYNAMIC_SPACE_START"); } #if defined(ibmrt) || defined(__i386__) SetSymbolValue(ALLOCATION_POINTER, (lispobj)free_pointer); @@ -75,10 +75,14 @@ static void process_directory(int fd, long *ptr, int count) #endif break; case STATIC_SPACE_ID: - static_space = (lispobj *) addr; + if (addr != (os_vm_address_t)STATIC_SPACE_START) { + lose("core/runtime address mismatch: STATIC_SPACE_START"); + } break; case READ_ONLY_SPACE_ID: - /* We don't care about read-only space. */ + if (addr != (os_vm_address_t)READ_ONLY_SPACE_START) { + lose("core/runtime address mismatch: READ_ONLY_SPACE_START"); + } break; default: lose("unknown space ID %ld", id); diff --git a/src/runtime/gencgc.c b/src/runtime/gencgc.c index 65ddf79..045a722 100644 --- a/src/runtime/gencgc.c +++ b/src/runtime/gencgc.c @@ -40,10 +40,12 @@ #include "runtime.h" #include "sbcl.h" #include "os.h" +#include "interr.h" #include "globals.h" #include "interrupt.h" #include "validate.h" #include "lispregs.h" +#include "arch.h" #include "gc.h" #include "gencgc.h" @@ -365,21 +367,24 @@ print_generation_stats(int verbose) /* FIXME: should take FILE argument */ for (j = 0; j < last_free_page; j++) if (page_table[j].gen == i) { + /* Count the number of boxed pages within the given - * generation */ - if (page_table[j].allocated == BOXED_PAGE) + * generation. */ + if (page_table[j].allocated == BOXED_PAGE) { if (page_table[j].large_object) large_boxed_cnt++; else boxed_cnt++; - + } + /* Count the number of unboxed pages within the given - * generation */ - if (page_table[j].allocated == UNBOXED_PAGE) + * generation. */ + if (page_table[j].allocated == UNBOXED_PAGE) { if (page_table[j].large_object) large_unboxed_cnt++; else unboxed_cnt++; + } } gc_assert(generations[i].bytes_allocated @@ -1741,6 +1746,9 @@ copy_large_unboxed_object(lispobj object, int nwords) #define DIRECT_SCAV 0 +/* FIXME: Most calls end up going to a little trouble to compute an + * 'nwords' value. The system might be a little simpler if this + * function used an 'end' parameter instead. */ static void scavenge(lispobj *start, long nwords) { @@ -4050,7 +4058,7 @@ search_read_only_space(lispobj *pointer) static lispobj * search_static_space(lispobj *pointer) { - lispobj* start = (lispobj*)static_space; + lispobj* start = (lispobj*)STATIC_SPACE_START; lispobj* end = (lispobj*)SymbolValue(STATIC_SPACE_FREE_POINTER); if ((pointer < start) || (pointer >= end)) return NULL; @@ -4114,7 +4122,8 @@ valid_dynamic_space_pointer(lispobj *pointer) case type_FuncallableInstanceHeader: case type_ByteCodeFunction: case type_ByteCodeClosure: - if ((int)pointer != ((int)start_addr+type_FunctionPointer)) { + if ((unsigned)pointer != + ((unsigned)start_addr+type_FunctionPointer)) { if (gencgc_verbose) FSHOW((stderr, "/Wf2: %x %x %x\n", @@ -4131,7 +4140,8 @@ valid_dynamic_space_pointer(lispobj *pointer) } break; case type_ListPointer: - if ((int)pointer != ((int)start_addr+type_ListPointer)) { + if ((unsigned)pointer != + ((unsigned)start_addr+type_ListPointer)) { if (gencgc_verbose) FSHOW((stderr, "/Wl1: %x %x %x\n", @@ -4156,7 +4166,8 @@ valid_dynamic_space_pointer(lispobj *pointer) return 0; } case type_InstancePointer: - if ((int)pointer != ((int)start_addr+type_InstancePointer)) { + if ((unsigned)pointer != + ((unsigned)start_addr+type_InstancePointer)) { if (gencgc_verbose) FSHOW((stderr, "/Wi1: %x %x %x\n", @@ -4172,7 +4183,8 @@ valid_dynamic_space_pointer(lispobj *pointer) } break; case type_OtherPointer: - if ((int)pointer != ((int)start_addr+type_OtherPointer)) { + if ((unsigned)pointer != + ((int)start_addr+type_OtherPointer)) { if (gencgc_verbose) FSHOW((stderr, "/Wo1: %x %x %x\n", @@ -4481,8 +4493,12 @@ preserve_pointer(void *addr) region_allocation = page_table[addr_page_index].allocated; - /* Check the offset within the page */ - if (((int)addr & 0xfff) > page_table[addr_page_index].bytes_used) + /* Check the offset within the page. + * + * FIXME: The mask should have a symbolic name, and ideally should + * be derived from page size instead of hardwired to 0xfff. + * (Also fix other uses of 0xfff, elsewhere.) */ + if (((unsigned)addr & 0xfff) > page_table[addr_page_index].bytes_used) return; if (enable_pointer_filter && !valid_dynamic_space_pointer(addr)) @@ -4510,7 +4526,7 @@ preserve_pointer(void *addr) if ((page_table[addr_page_index].allocated == FREE_PAGE) || (page_table[addr_page_index].bytes_used == 0) /* Check the offset within the page. */ - || (((int)addr & 0xfff) + || (((unsigned)addr & 0xfff) > page_table[addr_page_index].bytes_used)) { FSHOW((stderr, "weird? ignore ptr 0x%x to freed area of large object\n", @@ -4594,8 +4610,14 @@ scavenge_thread_stacks(void) (unsigned)stack_pointer); if ((stack_pointer > control_stack) && (stack_pointer < control_stack_end)) { - unsigned int length = ((int)control_stack_end - - (int)stack_pointer) / 4; + /* FIXME: Ick! + * (1) hardwired word length = 4; and as usual, + * when fixing this, check for other places + * with the same problem + * (2) calling it 'length' suggests bytes; + * perhaps 'size' instead? */ + unsigned int length = ((unsigned)control_stack_end - + (unsigned)stack_pointer) / 4; int j; if (length >= vector_length) { lose("invalid stack size %d >= vector length %d", @@ -5243,12 +5265,12 @@ print_ptr(lispobj *addr) extern int undefined_tramp; static void -verify_space(lispobj*start, size_t words) +verify_space(lispobj *start, size_t words) { - int dynamic_space = (find_page_index((void*)start) != -1); - int readonly_space = - (READ_ONLY_SPACE_START <= (int)start && - (int)start < SymbolValue(READ_ONLY_SPACE_FREE_POINTER)); + int is_in_dynamic_space = (find_page_index((void*)start) != -1); + int is_in_readonly_space = + (READ_ONLY_SPACE_START <= (unsigned)start && + (unsigned)start < SymbolValue(READ_ONLY_SPACE_FREE_POINTER)); while (words > 0) { size_t count = 1; @@ -5260,7 +5282,7 @@ verify_space(lispobj*start, size_t words) (READ_ONLY_SPACE_START <= thing && thing < SymbolValue(READ_ONLY_SPACE_FREE_POINTER)); int to_static_space = - ((int)static_space <= thing && + (STATIC_SPACE_START <= thing && thing < SymbolValue(STATIC_SPACE_FREE_POINTER)); /* Does it point to the dynamic space? */ @@ -5276,7 +5298,7 @@ verify_space(lispobj*start, size_t words) } /* Check that its not in the RO space as it would then be a * pointer from the RO to the dynamic space. */ - if (readonly_space) { + if (is_in_readonly_space) { lose("ptr to dynamic space %x from RO space %x", thing, start); } @@ -5289,7 +5311,7 @@ verify_space(lispobj*start, size_t words) } else { /* Verify that it points to another valid space. */ if (!to_readonly_space && !to_static_space - && (thing != (int)&undefined_tramp)) { + && (thing != (unsigned)&undefined_tramp)) { lose("Ptr %x @ %x sees junk.", thing, start); } } @@ -5334,7 +5356,7 @@ verify_space(lispobj*start, size_t words) /* Check that it's not in the dynamic space. * FIXME: Isn't is supposed to be OK for code * objects to be in the dynamic space these days? */ - if (dynamic_space + if (is_in_dynamic_space /* It's ok if it's byte compiled code. The trace * table offset will be a fixnum if it's x86 * compiled code - check. */ @@ -5435,19 +5457,25 @@ verify_space(lispobj*start, size_t words) static void verify_gc(void) { + /* FIXME: It would be nice to make names consistent so that + * foo_size meant size *in* *bytes* instead of size in some + * arbitrary units. (Yes, this caused a bug, how did you guess?:-) + * Some counts of lispobjs are called foo_count; it might be good + * to grep for all foo_size and rename the appropriate ones to + * foo_count. */ int read_only_space_size = (lispobj*)SymbolValue(READ_ONLY_SPACE_FREE_POINTER) - (lispobj*)READ_ONLY_SPACE_START; int static_space_size = (lispobj*)SymbolValue(STATIC_SPACE_FREE_POINTER) - - (lispobj*)static_space; + - (lispobj*)STATIC_SPACE_START; int binding_stack_size = (lispobj*)SymbolValue(BINDING_STACK_POINTER) - (lispobj*)BINDING_STACK_START; verify_space((lispobj*)READ_ONLY_SPACE_START, read_only_space_size); - verify_space((lispobj*)static_space, static_space_size); - verify_space((lispobj*)BINDING_STACK_START, binding_stack_size); + verify_space((lispobj*)STATIC_SPACE_START , static_space_size); + verify_space((lispobj*)BINDING_STACK_START , binding_stack_size); } static void @@ -5508,7 +5536,7 @@ verify_zero_fill(void) } else { int free_bytes = 4096 - page_table[page].bytes_used; if (free_bytes > 0) { - int *start_addr = (int *)((int)page_address(page) + int *start_addr = (int *)((unsigned)page_address(page) + page_table[page].bytes_used); int size = free_bytes / 4; int i; @@ -5666,26 +5694,28 @@ garbage_collect_generation(int generation, int raise) } /* Scavenge the binding stack. */ - scavenge(binding_stack, - (lispobj *)SymbolValue(BINDING_STACK_POINTER) - binding_stack); + scavenge(BINDING_STACK_START, + (lispobj *)SymbolValue(BINDING_STACK_POINTER) - + (lispobj *)BINDING_STACK_START); if (SymbolValue(SCAVENGE_READ_ONLY_SPACE) != NIL) { read_only_space_size = - (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER) - - read_only_space; + (lispobj*)SymbolValue(READ_ONLY_SPACE_FREE_POINTER) - + (lispobj*)READ_ONLY_SPACE_START; FSHOW((stderr, "/scavenge read only space: %d bytes\n", read_only_space_size * sizeof(lispobj))); - scavenge(read_only_space, read_only_space_size); + scavenge(READ_ONLY_SPACE_START, read_only_space_size); } - static_space_size = (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER) - - static_space; + static_space_size = + (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER) - + (lispobj *)STATIC_SPACE_START; if (gencgc_verbose > 1) FSHOW((stderr, "/scavenge static space: %d bytes\n", static_space_size * sizeof(lispobj))); - scavenge(static_space, static_space_size); + scavenge(STATIC_SPACE_START, static_space_size); /* All generations but the generation being GCed need to be * scavenged. The new_space generation needs special handling as diff --git a/src/runtime/globals.c b/src/runtime/globals.c index 9129424..ae67e71 100644 --- a/src/runtime/globals.c +++ b/src/runtime/globals.c @@ -31,13 +31,10 @@ lispobj *current_control_frame_pointer; 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; #ifndef ALLOCATION_POINTER lispobj *dynamic_space_free_pointer; @@ -68,6 +65,6 @@ void globals_init(void) current_control_frame_pointer = (lispobj *)0; #ifndef BINDING_STACK_POINTER - current_binding_stack_pointer = binding_stack; + current_binding_stack_pointer = BINDING_STACK_START; #endif } diff --git a/src/runtime/globals.h b/src/runtime/globals.h index 3e8feca..695e644 100644 --- a/src/runtime/globals.h +++ b/src/runtime/globals.h @@ -28,10 +28,7 @@ extern lispobj *current_control_frame_pointer; extern lispobj *current_binding_stack_pointer; #endif -extern lispobj *read_only_space; -extern lispobj *static_space; extern lispobj *control_stack; -extern lispobj *binding_stack; #ifdef __i386__ extern lispobj *control_stack_end; #endif diff --git a/src/runtime/parse.c b/src/runtime/parse.c index 4538a1b..9dd8082 100644 --- a/src/runtime/parse.c +++ b/src/runtime/parse.c @@ -240,20 +240,25 @@ static boolean lookup_symbol(char *name, lispobj *result) lispobj *headerptr; /* Search static space. */ - headerptr = static_space; - count = ((lispobj *) SymbolValue(STATIC_SPACE_FREE_POINTER) - - static_space); + headerptr = (lispobj *)STATIC_SPACE_START; + count = + (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER) - + (lispobj *)STATIC_SPACE_START; if (search_for_symbol(name, &headerptr, &count)) { *result = (lispobj)headerptr | type_OtherPointer; return 1; } /* Search dynamic space. */ - headerptr = DYNAMIC_SPACE_START; + headerptr = (lispobj *)DYNAMIC_SPACE_START; #if !defined(ibmrt) && !defined(__i386__) - count = dynamic_space_free_pointer - DYNAMIC_SPACE_START; + count = + dynamic_space_free_pointer - + (lispobj *)DYNAMIC_SPACE_START; #else - count = (lispobj *)SymbolValue(ALLOCATION_POINTER) - DYNAMIC_SPACE_START; + count = + (lispobj *)SymbolValue(ALLOCATION_POINTER) - + (lispobj *)DYNAMIC_SPACE_START; #endif if (search_for_symbol(name, &headerptr, &count)) { *result = (lispobj)headerptr | type_OtherPointer; diff --git a/src/runtime/purify.c b/src/runtime/purify.c index c34eb01..a8e7f85 100644 --- a/src/runtime/purify.c +++ b/src/runtime/purify.c @@ -1437,20 +1437,26 @@ int purify(lispobj static_roots, lispobj read_only_roots) fflush(stdout); #endif #if !defined(ibmrt) && !defined(__i386__) - pscav(binding_stack, current_binding_stack_pointer - binding_stack, 0); + pscav(BINDING_STACK_START, + current_binding_stack_pointer - (lispobj *)BINDING_STACK_START, + 0); #else - pscav(binding_stack, (lispobj *)SymbolValue(BINDING_STACK_POINTER) - binding_stack, 0); + pscav(BINDING_STACK_START, + (lispobj *)SymbolValue(BINDING_STACK_POINTER) - + (lispobj *)BINDING_STACK_START, + 0); #endif #ifdef SCAVENGE_READ_ONLY_SPACE if (SymbolValue(SCAVENGE_READ_ONLY_SPACE) != type_UnboundMarker && SymbolValue(SCAVENGE_READ_ONLY_SPACE) != NIL) { unsigned read_only_space_size = - (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER) - read_only_space; + (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER) - + (lispobj *)READ_ONLY_SPACE_START; fprintf(stderr, "scavenging read only space: %d bytes\n", read_only_space_size * sizeof(lispobj)); - pscav(read_only_space, read_only_space_size, 0); + pscav(READ_ONLY_SPACE_START, read_only_space_size, 0); } #endif @@ -1458,7 +1464,7 @@ int purify(lispobj static_roots, lispobj read_only_roots) printf(" static"); fflush(stdout); #endif - clean = static_space; + clean = (lispobj *)STATIC_SPACE_START; do { while (clean != static_free) clean = pscav(clean, static_free - clean, 0); diff --git a/src/runtime/runtime.c b/src/runtime/runtime.c index b572391..43d98aa 100644 --- a/src/runtime/runtime.c +++ b/src/runtime/runtime.c @@ -36,6 +36,7 @@ #include "interrupt.h" #include "arch.h" #include "gc.h" +#include "interr.h" #include "monitor.h" #include "validate.h" #if defined GENCGC @@ -268,7 +269,7 @@ More information on SBCL is available at . #endif #ifdef BINDING_STACK_POINTER - SetSymbolValue(BINDING_STACK_POINTER, (lispobj)binding_stack); + SetSymbolValue(BINDING_STACK_POINTER, BINDING_STACK_START); #endif #if defined INTERNAL_GC_TRIGGER && !defined __i386__ SetSymbolValue(INTERNAL_GC_TRIGGER, make_fixnum(-1)); diff --git a/src/runtime/save.c b/src/runtime/save.c index aed18ec..d297eb9 100644 --- a/src/runtime/save.c +++ b/src/runtime/save.c @@ -23,6 +23,7 @@ #include "core.h" #include "globals.h" #include "save.h" +#include "dynbind.h" #include "lispregs.h" #include "validate.h" @@ -71,7 +72,7 @@ output_space(FILE *file, int id, lispobj *addr, lispobj *end) bytes = words * sizeof(lispobj); - printf("writing %d bytes from the %s space at 0x%08X\n", + printf("writing %d bytes from the %s space at 0x%08lx\n", bytes, names[id], (unsigned long)addr); data = write_bytes(file, (char *)addr, bytes); @@ -133,12 +134,12 @@ save(char *filename, lispobj init_function) putw(CORE_NDIRECTORY, file); putw((5*3)+2, file); - output_space(file, READ_ONLY_SPACE_ID, read_only_space, + output_space(file, READ_ONLY_SPACE_ID, (lispobj *)READ_ONLY_SPACE_START, (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER)); - output_space(file, STATIC_SPACE_ID, static_space, + output_space(file, STATIC_SPACE_ID, (lispobj *)STATIC_SPACE_START, (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER)); #ifdef reg_ALLOC - output_space(file, DYNAMIC_SPACE_ID, DYNAMIC_SPACE_START, + output_space(file, DYNAMIC_SPACE_ID, (lispobj *)DYNAMIC_SPACE_START, dynamic_space_free_pointer); #else #ifdef GENCGC diff --git a/src/runtime/validate.c b/src/runtime/validate.c index d3e6c7c..d008f8d 100644 --- a/src/runtime/validate.c +++ b/src/runtime/validate.c @@ -63,18 +63,12 @@ void validate(void) fflush(stdout); #endif - /* Read-Only Space */ - read_only_space = (lispobj *) READ_ONLY_SPACE_START; - ensure_space(read_only_space, READ_ONLY_SPACE_SIZE); + ensure_space(READ_ONLY_SPACE_START, READ_ONLY_SPACE_SIZE); - /* Static Space */ - static_space = (lispobj *) STATIC_SPACE_START; - ensure_space(static_space, STATIC_SPACE_SIZE); + ensure_space(STATIC_SPACE_START, STATIC_SPACE_SIZE); - /* Dynamic-0 Space */ ensure_space(DYNAMIC_SPACE_START, DYNAMIC_SPACE_SIZE); - /* Control Stack */ control_stack = (lispobj *) CONTROL_STACK_START; #ifdef __i386__ control_stack_end = (lispobj *) (CONTROL_STACK_START @@ -82,9 +76,7 @@ void validate(void) #endif ensure_space(control_stack, CONTROL_STACK_SIZE); - /* Binding Stack */ - binding_stack = (lispobj *) BINDING_STACK_START; - ensure_space(binding_stack, BINDING_STACK_SIZE); + ensure_space(BINDING_STACK_START, BINDING_STACK_SIZE); #ifdef HOLES make_holes(); diff --git a/version.lisp-expr b/version.lisp-expr index 5521f55..58ad964 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -15,4 +15,4 @@ ;;; versions, and a string a la "0.6.5.12" is used for versions which ;;; aren't released but correspond only to CVS tags or snapshots. -"0.6.7.13" +"0.6.7.14" -- 1.7.10.4