mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-20 19:50:24 +02:00
gc_object_set_remembered returns nonzero on success
This commit is contained in:
parent
4aa5d04f08
commit
cc04761271
2 changed files with 12 additions and 5 deletions
|
@ -54,7 +54,7 @@ GC_EMBEDDER_API inline void gc_trace_heap_roots(struct gc_heap_roots *roots,
|
||||||
// are in the remembered set. Large or potentially large objects
|
// are in the remembered set. Large or potentially large objects
|
||||||
// (e.g. a vector whose size is a run-time property) must have a
|
// (e.g. a vector whose size is a run-time property) must have a
|
||||||
// remembered set bit. Small objects may or may not have such a bit.
|
// remembered set bit. Small objects may or may not have such a bit.
|
||||||
GC_EMBEDDER_API inline void gc_object_set_remembered(struct gc_ref ref);
|
GC_EMBEDDER_API inline int gc_object_set_remembered(struct gc_ref ref);
|
||||||
GC_EMBEDDER_API inline int gc_object_is_remembered_nonatomic(struct gc_ref ref);
|
GC_EMBEDDER_API inline int gc_object_is_remembered_nonatomic(struct gc_ref ref);
|
||||||
GC_EMBEDDER_API inline void gc_object_clear_remembered_nonatomic(struct gc_ref ref);
|
GC_EMBEDDER_API inline void gc_object_clear_remembered_nonatomic(struct gc_ref ref);
|
||||||
|
|
||||||
|
|
|
@ -102,11 +102,18 @@ static inline void gc_object_forward_nonatomic(struct gc_ref ref,
|
||||||
*tag_word(ref) = gc_ref_value(new_ref);
|
*tag_word(ref) = gc_ref_value(new_ref);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void gc_object_set_remembered(struct gc_ref ref) {
|
static inline int gc_object_set_remembered(struct gc_ref ref) {
|
||||||
uintptr_t *loc = tag_word(ref);
|
uintptr_t *loc = tag_word(ref);
|
||||||
uintptr_t tag = *loc;
|
uintptr_t tag = atomic_load_explicit(loc, memory_order_relaxed);
|
||||||
while (!(tag & gcobj_remembered_bit))
|
while (1) {
|
||||||
atomic_compare_exchange_weak(loc, &tag, tag | gcobj_remembered_bit);
|
if (tag & gcobj_remembered_bit)
|
||||||
|
return 0;
|
||||||
|
if (atomic_compare_exchange_weak_explicit(loc, &tag,
|
||||||
|
tag | gcobj_remembered_bit,
|
||||||
|
memory_order_acq_rel,
|
||||||
|
memory_order_acquire))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int gc_object_is_remembered_nonatomic(struct gc_ref ref) {
|
static inline int gc_object_is_remembered_nonatomic(struct gc_ref ref) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue