X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fsave.c;h=70b439c79d5952116bbe047bae49f83aab37e963;hb=dfa55a883f94470267b626dae77ce7e7dfac3df6;hp=3e379a5d0710c451ccda8373adf1095ea747a0a1;hpb=a530bbe337109d898d5b4a001fc8f1afa3b5dc39;p=sbcl.git diff --git a/src/runtime/save.c b/src/runtime/save.c index 3e379a5..70b439c 100644 --- a/src/runtime/save.c +++ b/src/runtime/save.c @@ -9,10 +9,6 @@ * files for more information. */ -/* - * $Header$ - */ - #include #include #include @@ -23,6 +19,7 @@ #include "core.h" #include "globals.h" #include "save.h" +#include "dynbind.h" #include "lispregs.h" #include "validate.h" @@ -35,12 +32,12 @@ write_bytes(FILE *file, char *addr, long bytes) { long count, here, data; - bytes = (bytes+CORE_PAGESIZE-1)&~(CORE_PAGESIZE-1); + bytes = (bytes+os_vm_page_size-1)&~(os_vm_page_size-1); fflush(file); here = ftell(file); fseek(file, 0, 2); - data = (ftell(file)+CORE_PAGESIZE-1)&~(CORE_PAGESIZE-1); + data = (ftell(file)+os_vm_page_size-1)&~(os_vm_page_size-1); fseek(file, data, 0); while (bytes > 0) { @@ -56,7 +53,7 @@ write_bytes(FILE *file, char *addr, long bytes) } fflush(file); fseek(file, here, 0); - return data/CORE_PAGESIZE - 1; + return data/os_vm_page_size - 1; } static void @@ -71,14 +68,14 @@ 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); putw(data, file); - putw((long)addr / CORE_PAGESIZE, file); - putw((bytes + CORE_PAGESIZE - 1) / CORE_PAGESIZE, file); + putw((long)addr / os_vm_page_size, file); + putw((bytes + os_vm_page_size - 1) / os_vm_page_size, file); } boolean @@ -90,20 +87,18 @@ save(char *filename, lispobj init_function) char sbuf[128]; strcpy(sbuf,filename); filename=sbuf; - /* Get rid of remnant stuff. This is a MUST so that - * the memory manager can get started correctly when - * we restart after this save. Purify is going to - * maybe move the args so we need to consider them volatile, - * especially if the gcc optimizer is working!! - */ + /* Get rid of remnant stuff. This is a MUST so that the memory + * manager can get started correctly when we restart after this + * save. Purify is going to maybe move the args so we need to + * consider them volatile, especially if the gcc optimizer is + * working!! */ purify(NIL,NIL); init_function = *func_ptr; /* Set dynamic space pointer to base value so we don't write out - * MBs of just cleared heap. - */ + * MBs of just cleared heap. */ if(SymbolValue(X86_CGC_ACTIVE_P) != NIL) - SetSymbolValue(ALLOCATION_POINTER,DYNAMIC_0_SPACE_START); + SetSymbolValue(ALLOCATION_POINTER, DYNAMIC_SPACE_START); #endif /* Open the file: */ unlink(filename); @@ -133,13 +128,13 @@ 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, current_dynamic_space, - current_dynamic_space_free_pointer); + output_space(file, DYNAMIC_SPACE_ID, (lispobj *)current_dynamic_space, + dynamic_space_free_pointer); #else #ifdef GENCGC /* Flush the current_region updating the tables. */ @@ -147,7 +142,7 @@ save(char *filename, lispobj init_function) gc_alloc_update_page_tables(1,&unboxed_region); update_x86_dynamic_space_free_pointer(); #endif - output_space(file, DYNAMIC_SPACE_ID, current_dynamic_space, + output_space(file, DYNAMIC_SPACE_ID, (lispobj *)DYNAMIC_SPACE_START, (lispobj *)SymbolValue(ALLOCATION_POINTER)); #endif