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
...
@@ -642,8 +642,7 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
SYNOPSIS
SYNOPSIS
prepare_resize_simple_key_cache()
prepare_resize_simple_key_cache()
keycache pointer to the control block of a simple key cache
keycache pointer to the control block of a simple key cache
with_resize_queue <=> resize queue is used
release_lock <=> release the key cache lock before return
release_lock <=> release the key cache lock before return
DESCRIPTION
DESCRIPTION
...
@@ -651,10 +650,8 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
...
@@ -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
this it destroys the key cache calling end_simple_key_cache. The function
takes the parameter keycache as a pointer to the control block
takes the parameter keycache as a pointer to the control block
structure of the type SIMPLE_KEY_CACHE_CB for this key cache.
structure of the type SIMPLE_KEY_CACHE_CB for this key cache.
The parameter with_resize_queue determines weather the resize queue is
The parameter release_lock says whether the key cache lock must be
involved (MySQL server never uses this queue). The parameter release_lock
released before return from the function.
says weather the key cache lock must be released before return from
the function.
RETURN VALUE
RETURN VALUE
0 - on success,
0 - on success,
...
@@ -668,7 +665,6 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
...
@@ -668,7 +665,6 @@ int init_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_si
static
static
int
prepare_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
int
prepare_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
my_bool
with_resize_queue
,
my_bool
release_lock
)
my_bool
release_lock
)
{
{
int
res
=
0
;
int
res
=
0
;
...
@@ -682,7 +678,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
...
@@ -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
one resizer only. In set_var.cc keycache->in_init is used to block
multiple attempts.
multiple attempts.
*/
*/
while
(
with_resize_queue
&&
keycache
->
in_resize
)
while
(
keycache
->
in_resize
)
{
{
/* purecov: begin inspected */
/* purecov: begin inspected */
wait_on_queue
(
&
keycache
->
resize_queue
,
&
keycache
->
cache_lock
);
wait_on_queue
(
&
keycache
->
resize_queue
,
&
keycache
->
cache_lock
);
...
@@ -744,8 +740,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
...
@@ -744,8 +740,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
SYNOPSIS
SYNOPSIS
finish_resize_simple_key_cache()
finish_resize_simple_key_cache()
keycache pointer to the control block of a simple key cache
keycache pointer to the control block of a simple key cache
with_resize_queue <=> resize queue is used
acquire_lock <=> acquire the key cache lock at start
acquire_lock <=> acquire the key cache lock at start
DESCRIPTION
DESCRIPTION
...
@@ -754,9 +749,7 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
...
@@ -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
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
SIMPLE_KEY_CACHE_CB for this key cache. The function sets the flag
in_resize in this structure to FALSE.
in_resize in this structure to FALSE.
The parameter with_resize_queue determines weather the resize queue
The parameter acquire_lock says whether the key cache lock must be
is involved (MySQL server never uses this queue).
The parameter acquire_lock says weather the key cache lock must be
acquired at the start of the function.
acquired at the start of the function.
RETURN VALUE
RETURN VALUE
...
@@ -770,7 +763,6 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
...
@@ -770,7 +763,6 @@ int prepare_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
static
static
void
finish_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
void
finish_resize_simple_key_cache
(
SIMPLE_KEY_CACHE_CB
*
keycache
,
my_bool
with_resize_queue
,
my_bool
acquire_lock
)
my_bool
acquire_lock
)
{
{
DBUG_ENTER
(
"finish_resize_simple_key_cache"
);
DBUG_ENTER
(
"finish_resize_simple_key_cache"
);
...
@@ -786,11 +778,10 @@ void finish_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
...
@@ -786,11 +778,10 @@ void finish_resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache,
*/
*/
keycache
->
in_resize
=
0
;
keycache
->
in_resize
=
0
;
if
(
with_resize_queue
)
{
/* Signal waiting threads. */
/* Signal waiting threads. */
release_whole_queue
(
&
keycache
->
resize_queue
);
release_whole_queue
(
&
keycache
->
resize_queue
);
}
keycache_pthread_mutex_unlock
(
&
keycache
->
cache_lock
);
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_
...
@@ -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
We do not lose the cache_lock and will release it only at the end of
this function.
this function.
*/
*/
if
(
prepare_resize_simple_key_cache
(
keycache
,
1
,
0
))
if
(
prepare_resize_simple_key_cache
(
keycache
,
0
))
goto
finish
;
goto
finish
;
/* The following will work even if use_mem is 0 */
/* 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_
...
@@ -865,7 +856,7 @@ int resize_simple_key_cache(SIMPLE_KEY_CACHE_CB *keycache, uint key_cache_block_
division_limit
,
age_threshold
);
division_limit
,
age_threshold
);
finish:
finish:
finish_resize_simple_key_cache
(
keycache
,
1
,
0
);
finish_resize_simple_key_cache
(
keycache
,
0
);
DBUG_RETURN
(
blocks
);
DBUG_RETURN
(
blocks
);
}
}
...
@@ -5247,7 +5238,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
...
@@ -5247,7 +5238,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
}
}
for
(
i
=
0
;
i
<
partitions
;
i
++
)
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
)
if
(
!
err
)
blocks
=
init_partitioned_key_cache
(
keycache
,
key_cache_block_size
,
blocks
=
init_partitioned_key_cache
(
keycache
,
key_cache_block_size
,
...
@@ -5256,7 +5247,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
...
@@ -5256,7 +5247,7 @@ int resize_partitioned_key_cache(PARTITIONED_KEY_CACHE_CB *keycache,
{
{
for
(
i
=
0
;
i
<
partitions
;
i
++
)
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
);
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