diff options
author | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-11-01 19:08:59 +0000 |
---|---|---|
committer | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-11-01 19:08:59 +0000 |
commit | 525694bea7724d612a8b742943a0ed2aed5822f8 (patch) | |
tree | 75e43be3a94772c9abd5944e93ce57ddb5ec0902 /lib/darr.c | |
parent | d648344c2c5827fe46ad3097c84aa9349954895d (diff) | |
download | ovm-525694bea7724d612a8b742943a0ed2aed5822f8.tar.gz ovm-525694bea7724d612a8b742943a0ed2aed5822f8.tar.bz2 ovm-525694bea7724d612a8b742943a0ed2aed5822f8.zip |
Added an arena allocator
A page is a flexibly allocated structure of bytes, with a count of the
number of bytes already allocated (used) and number of bytes available
overall (available), with a pointer to the next page, if any.
heap_t is a linked list of pages. One may allocate a requested size
off the heap which causes one of two things:
1) Either a page already exists with enough space for the requested
size, in which case that page's pointer is used as the base for the
requested pointer
2) No pages satisfy the requested size, so a new page is allocated
which is the new end of the heap.
Diffstat (limited to 'lib/darr.c')
0 files changed, 0 insertions, 0 deletions