1.0.9.50: O(1) weak pointer scavenging
authorNikodemus Siivola <nikodemus@random-state.net>
Sun, 9 Sep 2007 12:39:16 +0000 (12:39 +0000)
committerNikodemus Siivola <nikodemus@random-state.net>
Sun, 9 Sep 2007 12:39:16 +0000 (12:39 +0000)
commit5fffbb72d9871ab7c4b46306dc52dae68fb375ab
tree78ffaaefdab992fe5fb0e8269b46a945bf7477a6
parentdedc93e4b7ed42ee697006b017e4a6095be3c5b7
1.0.9.50: O(1) weak pointer scavenging

* Use self-pointer instead of NULL to mark the end of scavenged weak
  pointer list in GC, which allows identifying unscavenged pointers
  by the NULL next pointers.

* Scavenging a single weak pointer in gencgc is now an O(1) operation
  instead of O(#scanned pointers so far).

Thanks to Paul Khuong.
NEWS
src/runtime/gc-common.c
src/runtime/gencgc.c
version.lisp-expr