projects
/
sbcl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
1.0.30.14: some SB-CLTL2 docstrings
[sbcl.git]
/
src
/
runtime
/
purify.c
diff --git
a/src/runtime/purify.c
b/src/runtime/purify.c
index
a1f21b6
..
59acf19
100644
(file)
--- a/
src/runtime/purify.c
+++ b/
src/runtime/purify.c
@@
-27,13
+27,14
@@
#include "interrupt.h"
#include "purify.h"
#include "interr.h"
#include "interrupt.h"
#include "purify.h"
#include "interr.h"
-#include "fixnump.h"
#include "gc.h"
#include "gc-internal.h"
#include "thread.h"
#include "genesis/primitive-objects.h"
#include "genesis/static-symbols.h"
#include "genesis/layout.h"
#include "gc.h"
#include "gc-internal.h"
#include "thread.h"
#include "genesis/primitive-objects.h"
#include "genesis/static-symbols.h"
#include "genesis/layout.h"
+#include "genesis/hash-table.h"
+#include "gencgc.h"
/* We don't ever do purification with GENCGC as of 1.0.5.*. There was
* a lot of hairy and fragile ifdeffage in here to support purify on
/* We don't ever do purification with GENCGC as of 1.0.5.*. There was
* a lot of hairy and fragile ifdeffage in here to support purify on
@@
-497,7
+498,7
@@
ptrans_otherptr(lispobj thing, lispobj header, boolean constant)
return ptrans_unboxed(thing, header);
#ifdef LUTEX_WIDETAG
case LUTEX_WIDETAG:
return ptrans_unboxed(thing, header);
#ifdef LUTEX_WIDETAG
case LUTEX_WIDETAG:
- gencgc_unregister_lutex(native_pointer(thing));
+ gencgc_unregister_lutex((struct lutex *) native_pointer(thing));
return ptrans_unboxed(thing, header);
#endif
return ptrans_unboxed(thing, header);
#endif
@@
-716,8
+717,9
@@
pscav(lispobj *addr, long nwords, boolean constant)
case SIMPLE_VECTOR_WIDETAG:
if (HeaderValue(thing) == subtype_VectorValidHashing) {
case SIMPLE_VECTOR_WIDETAG:
if (HeaderValue(thing) == subtype_VectorValidHashing) {
- *addr = (subtype_VectorMustRehash << N_WIDETAG_BITS) |
- SIMPLE_VECTOR_WIDETAG;
+ struct hash_table *hash_table =
+ (struct hash_table *)native_pointer(addr[2]);
+ hash_table->needs_rehash_p = T;
}
count = 2;
break;
}
count = 2;
break;
@@
-1020,6
+1022,9
@@
purify(lispobj static_roots, lispobj read_only_roots)
printf(" cleanup");
fflush(stdout);
#endif
printf(" cleanup");
fflush(stdout);
#endif
+#ifdef LISP_FEATURE_HPUX
+ clear_auto_gc_trigger(); /* restore mmap as it was given by os */
+#endif
os_zero((os_vm_address_t) current_dynamic_space,
(os_vm_size_t) dynamic_space_size);
os_zero((os_vm_address_t) current_dynamic_space,
(os_vm_size_t) dynamic_space_size);