Skip to content

Index

Records

Functions

liballoc_lock

int liballoc_lock()

This function is supposed to lock the memory data structures. It could be as simple as disabling interrupts or acquiring a spinlock. It's up to you to decide.

return 0 if the lock was acquired successfully. Anything else is failure.

liballoc_unlock

int liballoc_unlock()

This function unlocks what was previously locked by the liballoc_lock function. If it disabled interrupts, it enables interrupts. If it had acquiried a spinlock, it releases the spinlock. etc.

return 0 if the lock was successfully released.

liballoc_alloc

void * liballoc_alloc(int pages)

This is the hook into the local system which allocates pages. It accepts an integer parameter which is the number of pages required. The page size was set up in the liballoc_init function.

return NULL if the pages were not allocated.

return A pointer to the allocated memory.

liballoc_free

int liballoc_free(void * ptr, int pages)

This frees previously allocated memory. The void* parameter passed to the function is the exact same value returned from a previous liballoc_alloc call.

The integer value is the number of pages to free.

return 0 if the memory was successfully freed.

malloc

void * malloc(size_t )

realloc

void * realloc(void * , size_t )

calloc

void * calloc(size_t , size_t )

free

void free(void * )

liballoc_init

void liballoc_init()

liballoc_deinit

void liballoc_deinit()