|
LibreOffice
LibreOffice 26.2 SDK C/C++ API Reference
|
Go to the source code of this file.
Macros | |
| #define | RTL_ARENA_NAME_LENGTH 31 |
| #define | RTL_CACHE_NAME_LENGTH 31 |
| #define | RTL_CACHE_FLAG_BULKDESTROY 1 /* obsolete */ |
Typedefs | |
| typedef struct rtl_arena_st | rtl_arena_type |
| typedef struct rtl_cache_st | rtl_cache_type |
| Opaque rtl_cache_type. | |
Functions | |
| SAL_DLLPUBLIC void * | rtl_allocateMemory (sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Allocate memory. | |
| SAL_DLLPUBLIC void * | rtl_reallocateMemory (void *Ptr, sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Reallocate memory. | |
| SAL_DLLPUBLIC void | rtl_freeMemory (void *Ptr) SAL_THROW_EXTERN_C() |
| Free memory. | |
| SAL_DLLPUBLIC void * | rtl_allocateZeroMemory (sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Allocate and zero memory. | |
| SAL_DLLPUBLIC void | rtl_secureZeroMemory (void *Ptr, sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Zero memory. | |
| SAL_DLLPUBLIC void | rtl_freeZeroMemory (void *Ptr, sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Zero and free memory. | |
| SAL_DLLPUBLIC void * | rtl_allocateAlignedMemory (sal_Size Alignment, sal_Size Bytes) SAL_THROW_EXTERN_C() |
| Allocate aligned memory. | |
| SAL_DLLPUBLIC void | rtl_freeAlignedMemory (void *Ptr) SAL_THROW_EXTERN_C() |
| Free memory allocated with rtl_allocateAlignedMemory(). | |
| SAL_DLLPUBLIC rtl_arena_type * | rtl_arena_create (const char *pName, sal_Size quantum, sal_Size quantum_cache_max, rtl_arena_type *source_arena, void *(*source_alloc)(rtl_arena_type *, sal_Size *), void(*source_free)(rtl_arena_type *, void *, sal_Size), int nFlags) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void | rtl_arena_destroy (rtl_arena_type *pArena) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void * | rtl_arena_alloc (rtl_arena_type *pArena, sal_Size *pBytes) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void | rtl_arena_free (rtl_arena_type *pArena, void *pAddr, sal_Size nBytes) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC rtl_cache_type * | rtl_cache_create (const char *pName, sal_Size nObjSize, sal_Size nObjAlign, int(*constructor)(void *pObj, void *pUserArg), void(*destructor)(void *pObj, void *pUserArg), void(*reclaim)(void *pUserArg), void *pUserArg, rtl_arena_type *pSource, int nFlags) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void | rtl_cache_destroy (rtl_cache_type *pCache) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void * | rtl_cache_alloc (rtl_cache_type *pCache) SAL_THROW_EXTERN_C() |
| SAL_DLLPUBLIC void | rtl_cache_free (rtl_cache_type *pCache, void *pObj) SAL_THROW_EXTERN_C() |
Variables | |
| struct SAL_DLLPUBLIC_RTTI | rtl_arena_st |
| Opaque rtl_arena_type. | |
| #define RTL_ARENA_NAME_LENGTH 31 |
| #define RTL_CACHE_FLAG_BULKDESTROY 1 /* obsolete */ |
| #define RTL_CACHE_NAME_LENGTH 31 |
| typedef struct rtl_arena_st rtl_arena_type |
| typedef struct rtl_cache_st rtl_cache_type |
Opaque rtl_cache_type.
| SAL_DLLPUBLIC void * rtl_allocateAlignedMemory | ( | sal_Size | Alignment, |
| sal_Size | Bytes ) |
Allocate aligned memory.
A call to this function will return NULL upon the requested memory size being either zero or larger than currently allocatable.
Memory obtained through this function must be freed with rtl_freeAlignedMemory().
| [in] | Alignment | alignment in bytes, must be a power of two multiple of sizeof(void*). |
| [in] | Bytes | memory size. |
| SAL_DLLPUBLIC void * rtl_allocateMemory | ( | sal_Size | Bytes | ) |
Allocate memory.
A call to this function will return NULL upon the requested memory size being either zero or larger than currently allocatable.
| [in] | Bytes | memory size. |
| SAL_DLLPUBLIC void * rtl_allocateZeroMemory | ( | sal_Size | Bytes | ) |
Allocate and zero memory.
A call to this function will return NULL upon the requested memory size being either zero or larger than currently allocatable.
| [in] | Bytes | memory size. |
| SAL_DLLPUBLIC void * rtl_arena_alloc | ( | rtl_arena_type * | pArena, |
| sal_Size * | pBytes ) |
| [in] | pArena | arena from which resource is allocated. |
| [in,out] | pBytes | size of resource to allocate. |
| SAL_DLLPUBLIC rtl_arena_type * rtl_arena_create | ( | const char * | pName, |
| sal_Size | quantum, | ||
| sal_Size | quantum_cache_max, | ||
| rtl_arena_type * | source_arena, | ||
| void *(* | source_alloc )(rtl_arena_type *, sal_Size *), | ||
| void(* | source_free )(rtl_arena_type *, void *, sal_Size), | ||
| int | nFlags ) |
| [in] | pName | descriptive name; for debugging purposes. |
| [in] | quantum | resource allocation unit / granularity; rounded up to next power of 2. |
| [in] | quantum_cache_max | no longer used, should be 0. |
| [in] | source_arena | passed as argument to source_alloc, source_free; usually NULL. |
| [in] | source_alloc | function to allocate resources; usually rtl_arena_alloc. |
| [in] | source_free | function to free resources; usually rtl_arena_free. |
| [in] | nFlags | flags; usually 0. |
| SAL_DLLPUBLIC void rtl_arena_destroy | ( | rtl_arena_type * | pArena | ) |
| [in] | pArena | the arena to destroy. |
| SAL_DLLPUBLIC void rtl_arena_free | ( | rtl_arena_type * | pArena, |
| void * | pAddr, | ||
| sal_Size | nBytes ) |
| [in] | pArena | arena from which resource was allocated. |
| [in] | pAddr | resource to free. |
| [in] | nBytes | size of resource. |
| SAL_DLLPUBLIC void * rtl_cache_alloc | ( | rtl_cache_type * | pCache | ) |
| [in] | pCache | cache from which object is allocated. |
| SAL_DLLPUBLIC rtl_cache_type * rtl_cache_create | ( | const char * | pName, |
| sal_Size | nObjSize, | ||
| sal_Size | nObjAlign, | ||
| int(* | constructor )(void *pObj, void *pUserArg), | ||
| void(* | destructor )(void *pObj, void *pUserArg), | ||
| void(* | reclaim )(void *pUserArg), | ||
| void * | pUserArg, | ||
| rtl_arena_type * | pSource, | ||
| int | nFlags ) |
| [in] | pName | descriptive name; for debugging purposes. |
| [in] | nObjSize | object size. |
| [in] | nObjAlign | object alignment; usually 0 for suitable default. |
| [in] | constructor | object constructor callback function; returning 1 for success or 0 for failure. |
| [in] | destructor | object destructor callback function. |
| [in] | reclaim | reclaim callback function. |
| [in] | pUserArg | opaque argument passed to callback functions. |
| [in] | pSource | unused argument (should be null). |
| [in] | nFlags | flags (unused). |
| SAL_DLLPUBLIC void rtl_cache_destroy | ( | rtl_cache_type * | pCache | ) |
| [in] | pCache | the cache to destroy. |
| SAL_DLLPUBLIC void rtl_cache_free | ( | rtl_cache_type * | pCache, |
| void * | pObj ) |
| [in] | pCache | cache from which object was allocated. |
| [in] | pObj | object to free. |
| SAL_DLLPUBLIC void rtl_freeAlignedMemory | ( | void * | Ptr | ) |
Free memory allocated with rtl_allocateAlignedMemory().
Memory is released, and the pointer invalidated.
| [in] | Ptr | pointer to the previously allocated memory. |
| SAL_DLLPUBLIC void rtl_freeMemory | ( | void * | Ptr | ) |
Free memory.
Memory is released, and the pointer is invalidated.
| [in] | Ptr | pointer to the previously allocated memory. |
| SAL_DLLPUBLIC void rtl_freeZeroMemory | ( | void * | Ptr, |
| sal_Size | Bytes ) |
Zero and free memory.
Memory is zero'ed with rtl_secureZeroMemory() and released. The original pointer is no longer valid.
| [in] | Ptr | pointer to the previously allocated memory. |
| [in] | Bytes | memory size. |
| SAL_DLLPUBLIC void * rtl_reallocateMemory | ( | void * | Ptr, |
| sal_Size | Bytes ) |
Reallocate memory.
A call to this function with parameter 'Ptr' being NULL is equivalent to a rtl_allocateMemory() call. A call to this function with parameter 'Bytes' being 0 is equivalent to a rtl_freeMemory() call.
| [in] | Ptr | pointer to the previously allocated memory. |
| [in] | Bytes | new memory size. |
| SAL_DLLPUBLIC void rtl_secureZeroMemory | ( | void * | Ptr, |
| sal_Size | Bytes ) |
Zero memory.
Fills a block of memory with zeros in a way that is guaranteed to be secure
| [in] | Ptr | pointer to the previously allocated memory. |
| [in] | Bytes | memory size. |
| struct SAL_DLLPUBLIC_RTTI rtl_arena_st |
Opaque rtl_arena_type.