mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-27 21:40:34 +02:00
Whippet captures stack when stopping mutators
This is part of work to enable conservative GC.
This commit is contained in:
parent
d2bde8319f
commit
deed415a06
4 changed files with 60 additions and 57 deletions
|
@ -12,18 +12,16 @@ struct gc_mutator_roots;
|
|||
struct gc_heap_roots;
|
||||
struct gc_atomic_forward;
|
||||
|
||||
GC_EMBEDDER_API inline int gc_has_conservative_roots(void);
|
||||
GC_EMBEDDER_API inline int gc_has_mutator_conservative_roots(void);
|
||||
GC_EMBEDDER_API inline int gc_has_global_conservative_roots(void);
|
||||
GC_EMBEDDER_API inline int gc_has_conservative_intraheap_edges(void);
|
||||
GC_EMBEDDER_API inline int gc_mutator_conservative_roots_may_be_interior(void);
|
||||
|
||||
GC_EMBEDDER_API inline void gc_trace_object(struct gc_ref ref,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data,
|
||||
size_t *size) GC_ALWAYS_INLINE;
|
||||
GC_EMBEDDER_API inline void gc_trace_conservative_mutator_roots(struct gc_mutator_roots *roots,
|
||||
void (*trace_ref)(struct gc_ref edge,
|
||||
void *trace_data),
|
||||
void *trace_data);
|
||||
GC_EMBEDDER_API inline void gc_trace_precise_mutator_roots(struct gc_mutator_roots *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
|
@ -32,10 +30,6 @@ GC_EMBEDDER_API inline void gc_trace_precise_heap_roots(struct gc_heap_roots *ro
|
|||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data);
|
||||
GC_EMBEDDER_API inline void gc_trace_conservative_heap_roots(struct gc_heap_roots *roots,
|
||||
void (*trace_ref)(struct gc_ref ref,
|
||||
void *trace_data),
|
||||
void *trace_data);
|
||||
|
||||
GC_EMBEDDER_API inline uintptr_t gc_object_forwarded_nonatomic(struct gc_ref ref);
|
||||
GC_EMBEDDER_API inline void gc_object_forward_nonatomic(struct gc_ref ref,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue