XenevaOS
Loading...
Searching...
No Matches
Macros | Functions | Variables
liballoc.cpp File Reference
#include <aurora.h>
#include <string.h>
#include <Mm\pmmngr.h>
#include <Mm\vmmngr.h>
#include <Mm\liballoc\liballoc.h>
#include <_null.h>
#include <Hal\serial.h>
Include dependency graph for liballoc.cpp:

Macros

#define LIBALLOC_MAGIC   0xc001c0de
 
#define MAXCOMPLETE   5
 
#define MAXEXP   32
 
#define MINEXP   8
 
#define MODE_BEST   0
 
#define MODE_INSTANT   1
 
#define MODE   MODE_BEST
 

Functions

void * port_malloc (unsigned int size)
 
void port_free (void *ptr)
 
void * port_calloc (unsigned long long nobj, unsigned long long size)
 
void * port_realloc (void *p, unsigned int size)
 
int liballoc_lock ()
 
int liballoc_unlock ()
 
void * liballoc_alloc (int pages)
 
int liballoc_free (void *ptr, int pages)
 

Variables

struct boundary_tagl_freePages [MAXEXP]
 
int l_completePages [MAXEXP]
 

Macro Definition Documentation

◆ LIBALLOC_MAGIC

#define LIBALLOC_MAGIC   0xc001c0de

BSD 2-Clause License

Copyright (c) 2022-2023, Manas Kamal Choudhury All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. Durand's Ridiculously Amazing Super Duper Memory functions.

◆ MAXCOMPLETE

#define MAXCOMPLETE   5

◆ MAXEXP

#define MAXEXP   32

◆ MINEXP

#define MINEXP   8

◆ MODE

#define MODE   MODE_BEST

◆ MODE_BEST

#define MODE_BEST   0

◆ MODE_INSTANT

#define MODE_INSTANT   1

Function Documentation

◆ 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.

Returns
NULL if the pages were not allocated.
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.

Returns
0 if the memory was successfully freed.

◆ 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.

Returns
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.

Returns
0 if the lock was successfully released.

◆ port_calloc()

void * port_calloc ( unsigned long long  nobj,
unsigned long long  size 
)

◆ port_free()

void port_free ( void *  ptr)

◆ port_malloc()

void * port_malloc ( unsigned int  size)

◆ port_realloc()

void * port_realloc ( void *  p,
unsigned int  size 
)

Variable Documentation

◆ l_completePages

int l_completePages[MAXEXP]

◆ l_freePages

struct boundary_tag* l_freePages[MAXEXP]