mirror of
https://github.com/MariaDB/server.git
synced 2025-01-20 05:52:27 +01:00
59f9fc4fe2
ut0mem.h Changes to eliminate unnecessary Purify warnings ut0mem.ic Changes to eliminate unnecessary Purify warnings srv0start.c Changes to eliminate unnecessary Purify warnings mem0pool.c Changes to eliminate unnecessary Purify warnings ut0mem.c Changes to eliminate unnecessary Purify warnings
175 lines
4.3 KiB
C
175 lines
4.3 KiB
C
/************************************************************************
|
|
Memory primitives
|
|
|
|
(c) 1994, 1995 Innobase Oy
|
|
|
|
Created 5/11/1994 Heikki Tuuri
|
|
*************************************************************************/
|
|
|
|
#include "ut0mem.h"
|
|
|
|
#ifdef UNIV_NONINL
|
|
#include "ut0mem.ic"
|
|
#endif
|
|
|
|
#include "mem0mem.h"
|
|
|
|
|
|
/* This struct is placed first in every allocated memory block */
|
|
typedef struct ut_mem_block_struct ut_mem_block_t;
|
|
|
|
struct ut_mem_block_struct{
|
|
UT_LIST_NODE_T(ut_mem_block_t) mem_block_list;/* mem block list node */
|
|
};
|
|
|
|
|
|
/* List of all memory blocks allocated from the operating system
|
|
with malloc */
|
|
UT_LIST_BASE_NODE_T(ut_mem_block_t) ut_mem_block_list;
|
|
|
|
os_fast_mutex_t ut_list_mutex; /* this protects the list */
|
|
|
|
ibool ut_mem_block_list_inited = FALSE;
|
|
|
|
/**************************************************************************
|
|
Initializes the mem block list at database startup. */
|
|
static
|
|
void
|
|
ut_mem_block_list_init(void)
|
|
/*========================*/
|
|
{
|
|
os_fast_mutex_init(&ut_list_mutex);
|
|
UT_LIST_INIT(ut_mem_block_list);
|
|
ut_mem_block_list_inited = TRUE;
|
|
}
|
|
|
|
/**************************************************************************
|
|
Allocates memory. Sets it also to zero if UNIV_SET_MEM_TO_ZERO is
|
|
defined and set_to_zero is TRUE. */
|
|
|
|
void*
|
|
ut_malloc_low(
|
|
/*==========*/
|
|
/* out, own: allocated memory */
|
|
ulint n, /* in: number of bytes to allocate */
|
|
ibool set_to_zero) /* in: TRUE if allocated memory should be set
|
|
to zero if UNIV_SET_MEM_TO_ZERO is defined */
|
|
{
|
|
void* ret;
|
|
|
|
ut_ad((sizeof(ut_mem_block_t) % 8) == 0); /* check alignment ok */
|
|
|
|
if (!ut_mem_block_list_inited) {
|
|
ut_mem_block_list_init();
|
|
}
|
|
|
|
os_fast_mutex_lock(&ut_list_mutex);
|
|
|
|
ret = malloc(n + sizeof(ut_mem_block_t));
|
|
|
|
if (ret == NULL) {
|
|
fprintf(stderr,
|
|
"InnoDB: Fatal error: cannot allocate %lu bytes of\n"
|
|
"InnoDB: memory with malloc!\n"
|
|
"InnoDB: Operating system errno: %lu\n"
|
|
"InnoDB: Cannot continue operation!\n"
|
|
"InnoDB: Check if you should increase the swap file or\n"
|
|
"InnoDB: ulimits of your operating system.\n", n, errno);
|
|
|
|
os_fast_mutex_unlock(&ut_list_mutex);
|
|
|
|
exit(1);
|
|
}
|
|
|
|
if (set_to_zero) {
|
|
#ifdef UNIV_SET_MEM_TO_ZERO
|
|
memset(ret, '\0', n + sizeof(ut_mem_block_t));
|
|
#endif
|
|
}
|
|
|
|
UT_LIST_ADD_FIRST(mem_block_list, ut_mem_block_list,
|
|
((ut_mem_block_t*)ret));
|
|
os_fast_mutex_unlock(&ut_list_mutex);
|
|
|
|
return((void*)((byte*)ret + sizeof(ut_mem_block_t)));
|
|
}
|
|
|
|
/**************************************************************************
|
|
Allocates memory. Sets it also to zero if UNIV_SET_MEM_TO_ZERO is
|
|
defined. */
|
|
|
|
void*
|
|
ut_malloc(
|
|
/*======*/
|
|
/* out, own: allocated memory */
|
|
ulint n) /* in: number of bytes to allocate */
|
|
{
|
|
return(ut_malloc_low(n, TRUE));
|
|
}
|
|
/**************************************************************************
|
|
Frees a memory bloock allocated with ut_malloc. */
|
|
|
|
void
|
|
ut_free(
|
|
/*====*/
|
|
void* ptr) /* in, own: memory block */
|
|
{
|
|
ut_mem_block_t* block;
|
|
|
|
block = (ut_mem_block_t*)((byte*)ptr - sizeof(ut_mem_block_t));
|
|
|
|
os_fast_mutex_lock(&ut_list_mutex);
|
|
|
|
UT_LIST_REMOVE(mem_block_list, ut_mem_block_list, block);
|
|
free(block);
|
|
|
|
os_fast_mutex_unlock(&ut_list_mutex);
|
|
}
|
|
|
|
/**************************************************************************
|
|
Frees all allocated memory not freed yet. */
|
|
|
|
void
|
|
ut_free_all_mem(void)
|
|
/*=================*/
|
|
{
|
|
ut_mem_block_t* block;
|
|
|
|
os_fast_mutex_lock(&ut_list_mutex);
|
|
|
|
while (block = UT_LIST_GET_FIRST(ut_mem_block_list)) {
|
|
|
|
UT_LIST_REMOVE(mem_block_list, ut_mem_block_list, block);
|
|
free(block);
|
|
}
|
|
|
|
os_fast_mutex_unlock(&ut_list_mutex);
|
|
}
|
|
|
|
/**************************************************************************
|
|
Catenates two strings into newly allocated memory. The memory must be freed
|
|
using mem_free. */
|
|
|
|
char*
|
|
ut_str_catenate(
|
|
/*============*/
|
|
/* out, own: catenated null-terminated string */
|
|
char* str1, /* in: null-terminated string */
|
|
char* str2) /* in: null-terminated string */
|
|
{
|
|
ulint len1;
|
|
ulint len2;
|
|
char* str;
|
|
|
|
len1 = ut_strlen(str1);
|
|
len2 = ut_strlen(str2);
|
|
|
|
str = mem_alloc(len1 + len2 + 1);
|
|
|
|
ut_memcpy(str, str1, len1);
|
|
ut_memcpy(str + len1, str2, len2);
|
|
|
|
str[len1 + len2] = '\0';
|
|
|
|
return(str);
|
|
}
|