mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-07 18:30:25 +02:00
Merged Whippet into libguile/whippet
This commit is contained in:
commit
db181e67ff
112 changed files with 18115 additions and 0 deletions
26
libguile/whippet/benchmarks/simple-roots-api.h
Normal file
26
libguile/whippet/benchmarks/simple-roots-api.h
Normal file
|
@ -0,0 +1,26 @@
|
|||
#ifndef SIMPLE_ROOTS_API_H
|
||||
#define SIMPLE_ROOTS_API_H
|
||||
|
||||
#include "gc-config.h"
|
||||
#include "simple-roots-types.h"
|
||||
|
||||
#define HANDLE_TO(T) union { T* v; struct handle handle; }
|
||||
#define HANDLE_LOC(h) &(h).v
|
||||
#define HANDLE_REF(h) (h).v
|
||||
#define HANDLE_SET(h,val) do { (h).v = val; } while (0)
|
||||
#define PUSH_HANDLE(cx, h) push_handle(&(cx)->roots.roots, &h.handle)
|
||||
#define POP_HANDLE(cx) pop_handle(&(cx)->roots.roots)
|
||||
|
||||
static inline void push_handle(struct handle **roots, struct handle *handle) {
|
||||
if (GC_PRECISE_ROOTS) {
|
||||
handle->next = *roots;
|
||||
*roots = handle;
|
||||
}
|
||||
}
|
||||
|
||||
static inline void pop_handle(struct handle **roots) {
|
||||
if (GC_PRECISE_ROOTS)
|
||||
*roots = (*roots)->next;
|
||||
}
|
||||
|
||||
#endif // SIMPLE_ROOTS_API_H
|
Loading…
Add table
Add a link
Reference in a new issue