X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fsave.c;h=f4da52e9bf8086040d5dc9cd816d295fcbac8dfc;hb=35ab27e7aab71c94aa6be12da15603c7fd87fca8;hp=b7faa3771f6d0820bd9a8f098a76b2b46683b35e;hpb=9e58342e3ebb8bbaaa648cd345232b08279f3a0c;p=sbcl.git diff --git a/src/runtime/save.c b/src/runtime/save.c index b7faa37..f4da52e 100644 --- a/src/runtime/save.c +++ b/src/runtime/save.c @@ -16,10 +16,14 @@ #include #include #include -#include #include #include "sbcl.h" +#if defined(LISP_FEATURE_WIN32) && defined(LISP_FEATURE_SB_THREAD) +#include "pthreads_win32.h" +#else +#include +#endif #include "runtime.h" #include "os.h" #include "core.h" @@ -75,7 +79,7 @@ write_bytes_to_file(FILE * file, char *addr, long bytes, int compression) { if (compression == COMPRESSION_LEVEL_NONE) { while (bytes > 0) { - long count = fwrite(addr, 1, bytes, file); + sword_t count = fwrite(addr, 1, bytes, file); if (count > 0) { bytes -= count; addr += count; @@ -186,14 +190,14 @@ output_space(FILE *file, int id, lispobj *addr, lispobj *end, bytes = words * sizeof(lispobj); - printf("writing %lu bytes from the %s space at 0x%08lx\n", - (unsigned long)bytes, names[id], (unsigned long)addr); + printf("writing %lu bytes from the %s space at 0x%p\n", + bytes, names[id], addr); data = write_and_compress_bytes(file, (char *)addr, bytes, file_offset, core_compression_level); write_lispobj(data, file); - write_lispobj((long)addr / os_vm_page_size, file); + write_lispobj((uword_t)addr / os_vm_page_size, file); write_lispobj((bytes + os_vm_page_size - 1) / os_vm_page_size, file); } @@ -305,19 +309,19 @@ save_to_filehandle(FILE *file, char *filename, lispobj init_function, #ifdef LISP_FEATURE_GENCGC { - size_t size = (last_free_page*sizeof(long)+os_vm_page_size-1) + size_t size = (last_free_page*sizeof(sword_t)+os_vm_page_size-1) &~(os_vm_page_size-1); - unsigned long *data = calloc(size, 1); + uword_t *data = calloc(size, 1); if (data) { - unsigned long word; - long offset; + uword_t word; + sword_t offset; page_index_t i; for (i = 0; i < last_free_page; i++) { /* Thanks to alignment requirements, the two low bits * are always zero, so we can use them to store the * allocation type -- region is always closed, so only * the two low bits of allocation flags matter. */ - word = page_table[i].region_start_offset; + word = page_table[i].scan_start_offset; gc_assert((word & 0x03) == 0); data[i] = word | (0x03 & page_table[i].allocated); }