Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
a9223e94
Commit
a9223e94
authored
Sep 22, 2001
by
monty@hundin.mysql.fi
Browse files
Options
Browse Files
Download
Plain Diff
Merge work:/home/bk/mysql-4.0 into hundin.mysql.fi:/my/bk/mysql-4.0
parents
e390a995
fde15863
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
174 additions
and
32 deletions
+174
-32
innobase/include/mem0mem.ic
innobase/include/mem0mem.ic
+10
-2
innobase/include/os0sync.h
innobase/include/os0sync.h
+1
-1
innobase/include/os0sync.ic
innobase/include/os0sync.ic
+1
-1
innobase/include/univ.i
innobase/include/univ.i
+6
-2
innobase/include/ut0mem.h
innobase/include/ut0mem.h
+30
-3
innobase/include/ut0mem.ic
innobase/include/ut0mem.ic
+0
-7
innobase/mem/mem0pool.c
innobase/mem/mem0pool.c
+5
-1
innobase/os/os0sync.c
innobase/os/os0sync.c
+0
-2
innobase/srv/srv0start.c
innobase/srv/srv0start.c
+2
-0
innobase/ut/ut0mem.c
innobase/ut/ut0mem.c
+119
-13
No files found.
innobase/include/mem0mem.ic
View file @
a9223e94
...
@@ -170,7 +170,9 @@ mem_heap_alloc(
...
@@ -170,7 +170,9 @@ mem_heap_alloc(
buf = (byte*)buf + MEM_FIELD_HEADER_SIZE;
buf = (byte*)buf + MEM_FIELD_HEADER_SIZE;
#endif
#endif
#ifdef UNIV_SET_MEM_TO_ZERO
memset(buf, '\0', n);
#endif
return(buf);
return(buf);
}
}
...
@@ -494,8 +496,14 @@ mem_alloc_func(
...
@@ -494,8 +496,14 @@ mem_alloc_func(
)
)
{
{
#ifndef UNIV_MEM_DEBUG
#ifndef UNIV_MEM_DEBUG
void* buf;
return(mem_area_alloc(n, mem_comm_pool));
buf = mem_area_alloc(n, mem_comm_pool);
#ifdef UNIV_SET_MEM_TO_ZERO
memset(buf, '\0', n);
#endif
return(buf);
#else
#else
...
...
innobase/include/os0sync.h
View file @
a9223e94
...
@@ -160,6 +160,7 @@ os_fast_mutex_trylock(
...
@@ -160,6 +160,7 @@ os_fast_mutex_trylock(
was reserved by another
was reserved by another
thread */
thread */
os_fast_mutex_t
*
fast_mutex
);
/* in: mutex to acquire */
os_fast_mutex_t
*
fast_mutex
);
/* in: mutex to acquire */
#endif
/**************************************************************
/**************************************************************
Releases ownership of a fast mutex. */
Releases ownership of a fast mutex. */
UNIV_INLINE
UNIV_INLINE
...
@@ -188,7 +189,6 @@ void
...
@@ -188,7 +189,6 @@ void
os_fast_mutex_free
(
os_fast_mutex_free
(
/*===============*/
/*===============*/
os_fast_mutex_t
*
fast_mutex
);
/* in: mutex to free */
os_fast_mutex_t
*
fast_mutex
);
/* in: mutex to free */
#endif
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
#include "os0sync.ic"
#include "os0sync.ic"
...
...
innobase/include/os0sync.ic
View file @
a9223e94
...
@@ -38,6 +38,7 @@ os_fast_mutex_trylock(
...
@@ -38,6 +38,7 @@ os_fast_mutex_trylock(
return((ulint) pthread_mutex_trylock(fast_mutex));
return((ulint) pthread_mutex_trylock(fast_mutex));
#endif
#endif
}
}
#endif
/**************************************************************
/**************************************************************
Releases ownership of a fast mutex. */
Releases ownership of a fast mutex. */
...
@@ -53,4 +54,3 @@ os_fast_mutex_unlock(
...
@@ -53,4 +54,3 @@ os_fast_mutex_unlock(
pthread_mutex_unlock(fast_mutex);
pthread_mutex_unlock(fast_mutex);
#endif
#endif
}
}
#endif
innobase/include/univ.i
View file @
a9223e94
...
@@ -61,8 +61,12 @@ subdirectory of 'mysql'. */
...
@@ -61,8 +61,12 @@ subdirectory of 'mysql'. */
/* DEBUG VERSION CONTROL
/* DEBUG VERSION CONTROL
===================== */
===================== */
/* The following flag will make InnoDB to initialize
all memory it allocates to zero. It hides Purify
warnings about reading unallocated memory unless
memory is read outside the allocated blocks. */
/*
/*
#define UNIV_
SYNC_DEBUG
#define UNIV_
INIT_MEM_TO_ZERO
*/
*/
/* Make a non-inline debug version */
/* Make a non-inline debug version */
...
@@ -72,7 +76,7 @@ subdirectory of 'mysql'. */
...
@@ -72,7 +76,7 @@ subdirectory of 'mysql'. */
#define UNIV_SEARCH_DEBUG
#define UNIV_SEARCH_DEBUG
#define UNIV_IBUF_DEBUG
#define UNIV_IBUF_DEBUG
#define UNIV_SYNC_DEBUG
#define UNIV_SYNC_PERF_STAT
#define UNIV_SYNC_PERF_STAT
#define UNIV_SEARCH_PERF_STAT
#define UNIV_SEARCH_PERF_STAT
*/
*/
...
...
innobase/include/ut0mem.h
View file @
a9223e94
...
@@ -26,12 +26,39 @@ int
...
@@ -26,12 +26,39 @@ int
ut_memcmp
(
void
*
str1
,
void
*
str2
,
ulint
n
);
ut_memcmp
(
void
*
str1
,
void
*
str2
,
ulint
n
);
/**************************************************************************
Allocates memory. Sets it also to zero if UNIV_SET_MEM_TO_ZERO is
defined and set_to_zero is TRUE. */
void
*
void
*
ut_malloc
(
ulint
n
);
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 */
/**************************************************************************
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 */
/**************************************************************************
Frees a memory bloock allocated with ut_malloc. */
void
ut_free
(
/*====*/
void
*
ptr
);
/* in, own: memory block */
/**************************************************************************
Frees all allocated memory not freed yet. */
UNIV_INLINE
void
void
ut_free
(
void
*
ptr
);
ut_free_all_mem
(
void
);
/*=================*/
UNIV_INLINE
UNIV_INLINE
char
*
char
*
...
...
innobase/include/ut0mem.ic
View file @
a9223e94
...
@@ -27,13 +27,6 @@ ut_memcmp(void* str1, void* str2, ulint n)
...
@@ -27,13 +27,6 @@ ut_memcmp(void* str1, void* str2, ulint n)
return(memcmp(str1, str2, n));
return(memcmp(str1, str2, n));
}
}
UNIV_INLINE
void
ut_free(void* ptr)
{
free(ptr);
}
UNIV_INLINE
UNIV_INLINE
char*
char*
ut_strcpy(char* dest, char* sour)
ut_strcpy(char* dest, char* sour)
...
...
innobase/mem/mem0pool.c
View file @
a9223e94
...
@@ -170,7 +170,11 @@ mem_pool_create(
...
@@ -170,7 +170,11 @@ mem_pool_create(
pool
=
ut_malloc
(
sizeof
(
mem_pool_t
));
pool
=
ut_malloc
(
sizeof
(
mem_pool_t
));
pool
->
buf
=
ut_malloc
(
size
);
/* We do not set the memory to zero (FALSE) in the pool,
but only when allocated at a higher level in mem0mem.c.
This is to avoid masking useful Purify warnings. */
pool
->
buf
=
ut_malloc_low
(
size
,
FALSE
);
pool
->
size
=
size
;
pool
->
size
=
size
;
mutex_create
(
&
(
pool
->
mutex
));
mutex_create
(
&
(
pool
->
mutex
));
...
...
innobase/os/os0sync.c
View file @
a9223e94
...
@@ -422,7 +422,6 @@ os_mutex_free(
...
@@ -422,7 +422,6 @@ os_mutex_free(
#endif
#endif
}
}
#ifndef _WIN32
/*************************************************************
/*************************************************************
Initializes an operating system fast mutex semaphore. */
Initializes an operating system fast mutex semaphore. */
...
@@ -472,4 +471,3 @@ os_fast_mutex_free(
...
@@ -472,4 +471,3 @@ os_fast_mutex_free(
#endif
#endif
}
}
#endif
innobase/srv/srv0start.c
View file @
a9223e94
...
@@ -916,5 +916,7 @@ innobase_shutdown_for_mysql(void)
...
@@ -916,5 +916,7 @@ innobase_shutdown_for_mysql(void)
logs_empty_and_mark_files_at_shutdown
();
logs_empty_and_mark_files_at_shutdown
();
ut_free_all_mem
();
return
((
int
)
DB_SUCCESS
);
return
((
int
)
DB_SUCCESS
);
}
}
innobase/ut/ut0mem.c
View file @
a9223e94
...
@@ -14,30 +14,136 @@ Created 5/11/1994 Heikki Tuuri
...
@@ -14,30 +14,136 @@ Created 5/11/1994 Heikki Tuuri
#include "mem0mem.h"
#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
*
void
*
ut_malloc
(
ulint
n
)
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
;
void
*
ret
;
/*
ret = VirtualAlloc(NULL, n, MEM_COMMIT, PAGE_READWRITE);
*/
ret
=
malloc
(
n
);
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
)
{
if
(
ret
==
NULL
)
{
fprintf
(
stderr
,
fprintf
(
stderr
,
"Innobase: Fatal error: cannot allocate memory!
\n
"
);
"InnoDB: Fatal error: cannot allocate %lu bytes of
\n
"
fprintf
(
stderr
,
"InnoDB: memory with malloc!
\n
"
"Innobase: Cannot continue operation!
\n
"
);
"InnoDB: Operating system errno: %lu
\n
"
fprintf
(
stderr
,
"InnoDB: Cannot continue operation!
\n
"
"Innobase: Check if you can increase the swap file of your
\n
"
);
"InnoDB: Check if you should increase the swap file or
\n
"
fprintf
(
stderr
,
"InnoDB: ulimits of your operating system.
\n
"
,
n
,
errno
);
"Innobase: operating system.
\n
"
);
os_fast_mutex_unlock
(
&
ut_list_mutex
);
exit
(
1
);
exit
(
1
);
}
}
return
(
ret
);
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
);
}
}
/**************************************************************************
/**************************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment