mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-27 21:40:34 +02:00
Rework pinning, prepare for conservative tracing
We don't need a pin bit: we just need to mark pinned objects before evacuation starts. This way we can remove the stopping / marking race so that we can always mark while stopping.
This commit is contained in:
parent
2199d5f48d
commit
8a51117763
4 changed files with 200 additions and 89 deletions
|
@ -4,6 +4,13 @@
|
|||
#include "gc-edge.h"
|
||||
#include "precise-roots-types.h"
|
||||
|
||||
static inline int gc_has_conservative_roots(void) {
|
||||
return 0;
|
||||
}
|
||||
static inline int gc_has_conservative_intraheap_edges(void) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline void visit_roots(struct handle *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
|
@ -12,18 +19,30 @@ static inline void visit_roots(struct handle *roots,
|
|||
trace_edge(gc_edge(&h->v), trace_data);
|
||||
}
|
||||
|
||||
static inline void gc_trace_mutator_roots(struct gc_mutator_roots *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data) {
|
||||
static 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) {
|
||||
}
|
||||
|
||||
static inline void gc_trace_precise_mutator_roots(struct gc_mutator_roots *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data) {
|
||||
if (roots)
|
||||
visit_roots(roots->roots, trace_edge, trace_data);
|
||||
}
|
||||
|
||||
static inline void gc_trace_heap_roots(struct gc_heap_roots *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data) {
|
||||
static 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) {
|
||||
}
|
||||
|
||||
static inline void gc_trace_precise_heap_roots(struct gc_heap_roots *roots,
|
||||
void (*trace_edge)(struct gc_edge edge,
|
||||
void *trace_data),
|
||||
void *trace_data) {
|
||||
if (roots)
|
||||
visit_roots(roots->roots, trace_edge, trace_data);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue