X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fsave.c;h=c8c152f09dac92c1ce2e8ea3fe4a292207ef28e0;hb=0051cc0532da9f68a0ba5db5c07ebee1c91ee4d8;hp=5783c4398e05119abeef78e634ab2942665fc8a9;hpb=686043635c45a16b418d2cc96a7f704fdab182c2;p=sbcl.git diff --git a/src/runtime/save.c b/src/runtime/save.c index 5783c43..c8c152f 100644 --- a/src/runtime/save.c +++ b/src/runtime/save.c @@ -23,10 +23,11 @@ #include "dynbind.h" #include "lispregs.h" #include "validate.h" +#include "gc-internal.h" +#include "thread.h" -#ifdef GENCGC -#include "gencgc.h" -#endif +#include "genesis/static-symbols.h" +#include "genesis/symbol.h" static long write_bytes(FILE *file, char *addr, long bytes) @@ -83,6 +84,7 @@ boolean save(char *filename, lispobj init_function) { FILE *file; + struct thread *th; /* Open the output file. We don't actually need the file yet, but * the fopen() might fail for some reason, and we want to detect @@ -99,58 +101,71 @@ save(char *filename, lispobj init_function) * being SAVE-LISP-AND-DIE instead of SAVE-LISP-AND-GO-ON). */ printf("[undoing binding stack and other enclosing state... "); fflush(stdout); - unbind_to_here((lispobj *)BINDING_STACK_START); - SetSymbolValue(CURRENT_CATCH_BLOCK, 0); - SetSymbolValue(CURRENT_UNWIND_PROTECT_BLOCK, 0); + for_each_thread(th) { /* XXX really? */ + unbind_to_here((lispobj *)th->binding_stack_start,th); + SetSymbolValue(CURRENT_CATCH_BLOCK, 0,th); + SetSymbolValue(CURRENT_UNWIND_PROTECT_BLOCK, 0,th); + } printf("done]\n"); fflush(stdout); - /* (Now we can actually start copying ourselves into the - * output file.) */ + /* (Now we can actually start copying ourselves into the output file.) */ printf("[saving current Lisp image into %s:\n", filename); fflush(stdout); putw(CORE_MAGIC, file); - putw(CORE_VERSION, file); + putw(VERSION_CORE_ENTRY_TYPE_CODE, file); putw(3, file); putw(SBCL_CORE_VERSION_INTEGER, file); - putw(CORE_NDIRECTORY, file); - putw((5*3)+2, file); + putw(BUILD_ID_CORE_ENTRY_TYPE_CODE, file); + putw(/* (We're writing the word count of the entry here, and the 2 + * term is one word for the leading BUILD_ID_CORE_ENTRY_TYPE_CODE + * word and one word where we store the count itself.) */ + 2 + strlen(build_id), + file); + { + char *p; + for (p = build_id; *p; ++p) + putw(*p, file); + } + putw(NEW_DIRECTORY_CORE_ENTRY_TYPE_CODE, file); + putw(/* (word count = 3 spaces described by 5 words each, plus the + * entry type code, plus this count itself) */ + (5*3)+2, file); output_space(file, - READ_ONLY_SPACE_ID, + READ_ONLY_CORE_SPACE_ID, (lispobj *)READ_ONLY_SPACE_START, - (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER)); + (lispobj *)SymbolValue(READ_ONLY_SPACE_FREE_POINTER,0)); output_space(file, - STATIC_SPACE_ID, + STATIC_CORE_SPACE_ID, (lispobj *)STATIC_SPACE_START, - (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER)); + (lispobj *)SymbolValue(STATIC_SPACE_FREE_POINTER,0)); #ifdef reg_ALLOC output_space(file, - DYNAMIC_SPACE_ID, + DYNAMIC_CORE_SPACE_ID, (lispobj *)current_dynamic_space, dynamic_space_free_pointer); #else -#ifdef GENCGC +#ifdef LISP_FEATURE_GENCGC /* Flush the current_region, updating the tables. */ - gc_alloc_update_page_tables(0,&boxed_region); - gc_alloc_update_page_tables(1,&unboxed_region); + gc_alloc_update_all_page_tables(); update_x86_dynamic_space_free_pointer(); #endif output_space(file, - DYNAMIC_SPACE_ID, + DYNAMIC_CORE_SPACE_ID, (lispobj *)DYNAMIC_SPACE_START, - (lispobj *)SymbolValue(ALLOCATION_POINTER)); + (lispobj *)SymbolValue(ALLOCATION_POINTER,0)); #endif - putw(CORE_INITIAL_FUNCTION, file); + putw(INITIAL_FUN_CORE_ENTRY_TYPE_CODE, file); putw(3, file); putw(init_function, file); - putw(CORE_END, file); + putw(END_CORE_ENTRY_TYPE_CODE, file); fclose(file); printf("done]\n");