1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
/*
* Boehm-compatible GC API
*/
#ifndef _GC_H_INCLUDED
#define _GC_H_INCLUDED
#include <stdlib.h>
#ifdef __cplusplus
extern "C" {
#endif
static void __attribute__((used)) __GC_KEEPALIVE__() {
// Force inclusion of necessary dlmalloc functions
static int times = 1;
void *x = malloc(times);
free(x);
x = calloc(1, times);
free(x);
x = calloc(times, 1);
free(x);
times++;
}
/* Initialize. */
void GC_INIT();
/* Allocate memory. Cleared to 0 to erase all pointers. */
void *GC_MALLOC(int bytes);
/* Allocate memory for an object that the user promises will not contain pointers. */
void *GC_MALLOC_ATOMIC(int bytes);
/* Allocate memory that might container pointers but that can't be collected. */
void *GC_MALLOC_UNCOLLECTABLE(int bytes);
/* Reallocate a GC managed memory block to a new size. */
void *GC_REALLOC(void *ptr, int newBytes);
/* Explicitly deallocate an object. Dangerous as it forces a free and does not check if the object is reffed. */
void GC_FREE(void *ptr);
/* Register a finalizer. func(ptr, arg) will be called. The old values are saved in old_func, old_arg */
void GC_REGISTER_FINALIZER_NO_ORDER(void *ptr, void (*func)(void *, void *), void *arg,
void *(*old_func)(void *, void *), void *old_arg);
/* Gets the bytes allocated and managed by the GC */
int GC_get_heap_size();
/* Non-Boehm additions */
/* Call this once per frame or such, it will collect if necessary */
void GC_MAYBE_COLLECT();
/* Forces a GC. Mainly useful for testing, but call it if you know a good time to GC in your app. */
void GC_FORCE_COLLECT();
typedef void (*GC_finalization_proc)(void *func, void *arg);
extern void (*GC_finalizer_notifier)();
extern int GC_finalize_on_demand;
extern int GC_java_finalization;
void GC_enable_incremental();
#ifdef __cplusplus
}
#endif
#endif
|