memory.c
Include dependency graph for memory.c:
Functions
-
static void memory_scan_and_copy(HeapFragment *old_fragment, term *mem_start, const term *mem_end, term **new_heap_pos, term *mso_list, bool move)
-
static term memory_shallow_copy_term(HeapFragment *old_fragment, term t, term **new_heap, bool move)
-
static enum MemoryGCResult memory_gc(Context *ctx, size_t new_size, size_t num_roots, term *roots)
-
enum MemoryGCResult memory_init_heap(Heap *heap, size_t size)
Initialize a root heap.
- Parameters:
heap – heap to initialize.
size – capacity of the heap to create, not including the mso_list.
- Returns:
MEMORY_GC_OK or MEMORY_GC_ERROR_FAILED_ALLOCATION depending on the outcome.
-
void memory_init_heap_root_fragment(Heap *heap, HeapFragment *root, size_t size)
Setup heap from its root. Set the
mso_list
to NIL and initializeheap_ptr
.- Parameters:
heap – heap to initialize.
root – fragment root.
size – capacity of the heap to create, not including the mso_list.
-
static inline enum MemoryGCResult memory_heap_alloc_new_fragment(Heap *heap, size_t size)
-
enum MemoryGCResult memory_erl_nif_env_ensure_free(ErlNifEnv *env, size_t size)
makes sure that the given nif environment has given free memory
this function makes sure that at least size terms are available. When not available, a new fragment will be allocated.
- Parameters:
env – the target environment.
size – needed available memory.
-
static size_t next_fibonacci_heap_size(size_t size)
-
enum MemoryGCResult memory_ensure_free_with_roots(Context *c, size_t size, size_t num_roots, term *roots, enum MemoryAllocMode alloc_mode)
makes sure that the given context has given free memory.
this function makes sure at least size terms are available. Optionally, it can allocate a fragment or shrink the heap to the specified size, depending on allocation strategy. The function can also be passed roots to update during any garbage collection.
- Parameters:
ctx – the target context.
size – needed available memory.
num_roots – number of roots
roots – roots to preserve
alloc_mode – constraint on allocation of additional memory
-
term memory_copy_term_tree(Heap *new_heap, term t)
copies a term to a destination heap
deep copies a term to a destination heap, once finished old memory can be freed.
- Parameters:
new_heap – the destination heap where terms will be copied.
t – term to copy
- Returns:
a new term that is stored on the new heap.
-
term memory_copy_term_tree_to_storage(term *storage, term **heap_end, term t)
copies a term to a storage, typically for mailbox messages
deep copies a term to a destination heap, once finished old memory can be freed.
- Parameters:
storage – storage for the copied data, should be large enough
heap_end – on output, pointer to the end of the term.
t – term to copy
- Returns:
a boxed term pointer to the new term content that is stored in the storage.
-
unsigned long memory_estimate_usage(term t)
calculates term memory usage
perform an used memory calculation using given term as root, shared memory (that is not part of the memory block) is not accounted.
- Parameters:
t – root term on which used memory calculation will be performed.
- Returns:
used memory terms count in term units output parameter.
- static inline HOT_FUNC bool memory_heap_fragment_contains_pointer (HeapFragment *old_fragment, term *ptr)
-
void memory_heap_append_fragment(Heap *heap, HeapFragment *fragment, term mso_list)
append a fragment to a heap. The MSO list is merged. The fragment will then be owned by the heap.
- Parameters:
heap – the heap to append the fragment to
fragment – the fragment to add
mso_list – associated mso list or nil
-
void memory_sweep_mso_list(term mso_list, GlobalContext *global)
Sweep any unreferenced binaries in the “Mark Sweep Object” (MSO) list.
The MSO list is a list of term (references) in a heap. Currently, the elements of this list are referenced to reference-counted binaries or match binaries that themselves reference reference counted binaries. This function will iterate over the binaries in this list, and decrement the reference count of any elements that have not been marked for move (e.g., into a new heap). If the reference count reaches 0, then memory associated with the referenced binary will be freed.In a typical GC event, the terms in this list are within in the old heap or potentially in a heap fragment. However, this function may be called in a copy even, such as in a process spawn, or in the copy of a term to or from a process mailbox.
- Parameters:
mso_list – the list of mark-sweep object in a heap “space”
global – the global context