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
b9f220b4
Commit
b9f220b4
authored
Jul 16, 2013
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Plain Diff
5.3 merge
parents
67e5b794
8de120e2
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
23 deletions
+14
-23
mysys/mf_keycache.c
mysys/mf_keycache.c
+14
-23
No files found.
mysys/mf_keycache.c
View file @
b9f220b4
...
...
@@ -642,8 +642,7 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
SYNOPSIS
prepare_resize_simple_key_cache()
keycache pointer to the control block of a simple key cache
with_resize_queue <=> resize queue is used
keycache pointer to the control block of a simple key cache
release_lock <=> release the key cache lock before return
DESCRIPTION
...
...
@@ -651,10 +650,8 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
this it destroys the key cache calling end_simple_key_cache. The function
takes the parameter keycache as a pointer to the control block
structure of the type SIMPLE_KEY_CACHE_CB for this key cache.
The parameter with_resize_queue determines weather the resize queue is
involved (MySQL server never uses this queue). The parameter release_lock
says weather the key cache lock must be released before return from
the function.
The parameter release_lock says whether the key cache lock must be
released before return from the function.
RETURN VALUE
0 - on success,
...
...
@@ -668,7 +665,6 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
static
int
prepare_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
my_bool
with_resize_queue
,
my_bool
release_lock
)
{
int
res
=
0
;
...
...
@@ -682,7 +678,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
one resizer only. In set_var.cc keycache->in_init is used to block
multiple attempts.
*/
while
(
with_resize_queue
&&
keycache
->
in_resize
)
while
(
keycache
->
in_resize
)
{
/* purecov: begin inspected */
wait_on_queue
(
&
keycache
->
resize_queue
,
&
keycache
->
cache_lock
);
...
...
@@ -744,8 +740,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
SYNOPSIS
finish_resize_simple_key_cache()
keycache pointer to the control block of a simple key cache
with_resize_queue <=> resize queue is used
keycache pointer to the control block of a simple key cache
acquire_lock <=> acquire the key cache lock at start
DESCRIPTION
...
...
@@ -754,9 +749,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
keycache as a pointer to the control block structure of the type
SIMPLE_KEY_CACHE_CB for this key cache. The function sets the flag
in_resize in this structure to FALSE.
The parameter with_resize_queue determines weather the resize queue
is involved (MySQL server never uses this queue).
The parameter acquire_lock says weather the key cache lock must be
The parameter acquire_lock says whether the key cache lock must be
acquired at the start of the function.
RETURN VALUE
...
...
@@ -770,7 +763,6 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
static
void
finish_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
my_bool
with_resize_queue
,
my_bool
acquire_lock
)
{
DBUG_ENTER
(
"finish_resize_simple_key_cache"
);
...
...
@@ -786,11 +778,10 @@ void finish_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
*/
keycache
->
in_resize
=
0
;
if
(
with_resize_queue
)
{
/* Signal waiting threads. */
release_whole_queue
(
&
keycache
->
resize_queue
);
}
/* Signal waiting threads. */
release_whole_queue
(
&
keycache
->
resize_queue
);
keycache_pthread_mutex_unlock
(
&
keycache
->
cache_lock
);
...
...
@@ -857,7 +848,7 @@ int resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_
We do not lose the cache_lock and will release it only at the end of
this function.
*/
if
(
prepare_resize_simple_key_cache
(
keycache
,
1
,
0
))
if
(
prepare_resize_simple_key_cache
(
keycache
,
0
))
goto
finish
;
/* The following will work even if use_mem is 0 */
...
...
@@ -865,7 +856,7 @@ int resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_
division_limit
,
age_threshold
);
finish:
finish_resize_simple_key_cache
(
keycache
,
1
,
0
);
finish_resize_simple_key_cache
(
keycache
,
0
);
DBUG_RETURN
(
blocks
);
}
...
...
@@ -5247,7 +5238,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
}
for
(
i
=
0
;
i
<
partitions
;
i
++
)
{
err
|=
prepare_resize_simple_key_cache
(
keycache
->
partition_array
[
i
],
0
,
1
);
err
|=
prepare_resize_simple_key_cache
(
keycache
->
partition_array
[
i
],
1
);
}
if
(
!
err
)
blocks
=
init_partitioned_key_cache
(
keycache
,
key_cache_block_size
,
...
...
@@ -5256,7 +5247,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
{
for
(
i
=
0
;
i
<
partitions
;
i
++
)
{
finish_resize_simple_key_cache
(
keycache
->
partition_array
[
i
],
0
,
1
);
finish_resize_simple_key_cache
(
keycache
->
partition_array
[
i
],
1
);
}
}
DBUG_RETURN
(
blocks
);
...
...
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