C Standard Library Extensions
6.2.0
|
Functions | |
void * | qfits_memory_malloc (size_t size, const char *filename, int lineno) |
Allocate memory. | |
void * | qfits_memory_calloc (size_t nmemb, size_t size, const char *filename, int lineno) |
Allocate memory. | |
char * | qfits_memory_falloc (char *name, size_t offs, size_t *size, const char *srcname, int srclin) |
Map a file's contents to memory as a char pointer. | |
void | qfits_memory_fdealloc (void *ptr, size_t offs, size_t size, const char *filename, int lineno) |
Free memory that has been allocated with falloc. | |
void | qfits_memory_free (void *ptr, const char *filename, int lineno) |
Free memory. | |
void * | qfits_memory_realloc (void *ptr, size_t size, const char *filename, int lineno) |
Re-Allocate memory. | |
char * | qfits_memory_strdup (const char *s, const char *filename, int lineno) |
Duplicate a string using calloc. | |
void | qfits_memory_status (void) |
Display memory status information. | |
int | qfits_memory_is_empty (void) |
Tell if there is still some memory allocated. |
qfits_memory is a small and efficient module offering memory extension capabitilies to ANSI C programs running on POSIX-compliant systems. It offers several useful features such as memory leak detection, protection for free on NULL or unallocated pointers, and virtually unlimited memory space. qfits_memory requires the mmap()
system call to be implemented in the local C library to function. This module has been tested on a number of current Unix * flavours and is reported to work fine. The current limitation is the limited number of pointers it can handle at the same time.
void* qfits_memory_calloc | ( | size_t | nmemb, |
size_t | size, | ||
const char * | filename, | ||
int | lineno | ||
) |
Allocate memory.
nmemb | Number of elements to allocate. |
size | Size (in bytes) of each element. |
filename | Name of the file where the alloc took place. |
lineno | Line number in the file. |
This function is a replacement call for calloc. It should never be called directly but through a macro instead, as:
References qfits_memory_malloc().
char* qfits_memory_falloc | ( | char * | name, |
size_t | offs, | ||
size_t * | size, | ||
const char * | srcname, | ||
int | srclin | ||
) |
Map a file's contents to memory as a char pointer.
name | Name of the file to map |
offs | Offset to the first mapped byte in file. |
size | Returned size of the mapped file in bytes. |
srcname | Name of the source file making the call. |
srclin | Line # where the call was made. |
This function takes in input the name of a file. It tries to map the file into memory and if it succeeds, returns the file's contents as a char pointer. It also modifies the input size variable to be the size of the mapped file in bytes. This function is normally never directly called but through the falloc() macro.
The offset indicates the starting point for the mapping, i.e. if you are not interested in mapping the whole file but only from a given place.
The returned pointer ptr must be deallocated with qfits_memory_fdealloc(ptr)
void qfits_memory_fdealloc | ( | void * | ptr, |
size_t | offs, | ||
size_t | size, | ||
const char * | filename, | ||
int | lineno | ||
) |
Free memory that has been allocated with falloc.
ptr | Pointer to free. |
offs | Offset to the first mapped byte in file. |
size | size to unmap |
filename | Name of the file where the dealloc took place. |
lineno | Line number in the file. |
void qfits_memory_free | ( | void * | ptr, |
const char * | filename, | ||
int | lineno | ||
) |
Free memory.
ptr | Pointer to free. |
filename | Name of the file where the dealloc took place. |
lineno | Line number in the file. |
Free the memory associated to a given pointer. Prints out a warning on stderr if the requested pointer is NULL or cannot be found in the extended memory table.
Referenced by qfits_memory_realloc().
int qfits_memory_is_empty | ( | void | ) |
Tell if there is still some memory allocated.
void* qfits_memory_malloc | ( | size_t | size, |
const char * | filename, | ||
int | lineno | ||
) |
Allocate memory.
size | Size (in bytes) to allocate. |
filename | Name of the file where the alloc took place. |
lineno | Line number in the file. |
This function is a replacement call for malloc. It should never be called directly but through a macro instead, as:
Referenced by qfits_memory_calloc(), qfits_memory_realloc(), and qfits_memory_strdup().
void* qfits_memory_realloc | ( | void * | ptr, |
size_t | size, | ||
const char * | filename, | ||
int | lineno | ||
) |
Re-Allocate memory.
ptr | Pointer to free. |
size | Size (in bytes) to allocate. |
filename | Name of the file where the alloc took place. |
lineno | Line number in the file. |
This function is a replacement call for realloc. It should never be called directly but through a macro instead, as:
References qfits_memory_free(), and qfits_memory_malloc().
void qfits_memory_status | ( | void | ) |
Display memory status information.
This function is meant for debugging purposes, but it is recommended to call it at the end of every executable making use of the extended memory features.
char* qfits_memory_strdup | ( | const char * | s, |
const char * | filename, | ||
int | lineno | ||
) |
Duplicate a string using calloc.
s | String to duplicate. |
filename | Name of the file where the call took place. |
lineno | Line number in the file. |
This function calls in turn calloc to perform the allocation. It should never be called directly but only through a macro, like:
This function calls qfits_memory_malloc() to do the allocation.
References qfits_memory_malloc().