Commit 208421f1 authored by marko's avatar marko

branches/zip: lock0lock.c: Add UNIV_UNLIKELY hints to LOCK_WAIT checks.

Declare some local variables in narrower scope.

lock_move_rec_list_start(): Check for orphan locks #ifdef UNIV_DEBUG
parent 4b43c896
...@@ -645,7 +645,7 @@ lock_get_wait( ...@@ -645,7 +645,7 @@ lock_get_wait(
{ {
ut_ad(lock); ut_ad(lock);
if (lock->type_mode & LOCK_WAIT) { if (UNIV_UNLIKELY(lock->type_mode & LOCK_WAIT)) {
return(TRUE); return(TRUE);
} }
...@@ -1782,7 +1782,7 @@ lock_rec_create( ...@@ -1782,7 +1782,7 @@ lock_rec_create(
HASH_INSERT(lock_t, hash, lock_sys->rec_hash, HASH_INSERT(lock_t, hash, lock_sys->rec_hash,
lock_rec_fold(space, page_no), lock); lock_rec_fold(space, page_no), lock);
if (type_mode & LOCK_WAIT) { if (UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
lock_set_lock_and_trx_wait(lock, trx); lock_set_lock_and_trx_wait(lock, trx);
} }
...@@ -1954,7 +1954,7 @@ lock_rec_add_to_queue( ...@@ -1954,7 +1954,7 @@ lock_rec_add_to_queue(
lock = lock_rec_get_next_on_page(lock); lock = lock_rec_get_next_on_page(lock);
} }
if (!(type_mode & LOCK_WAIT)) { if (!UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
/* Look for a similar record lock on the same page: /* Look for a similar record lock on the same page:
if one is found and there are no waiting lock requests, if one is found and there are no waiting lock requests,
...@@ -2542,7 +2542,6 @@ lock_rec_move( ...@@ -2542,7 +2542,6 @@ lock_rec_move(
which gives the locks */ which gives the locks */
{ {
lock_t* lock; lock_t* lock;
ulint type_mode;
ut_ad(mutex_own(&kernel_mutex)); ut_ad(mutex_own(&kernel_mutex));
...@@ -2551,11 +2550,11 @@ lock_rec_move( ...@@ -2551,11 +2550,11 @@ lock_rec_move(
ut_ad(lock_rec_get_first(receiver, receiver_heap_no) == NULL); ut_ad(lock_rec_get_first(receiver, receiver_heap_no) == NULL);
while (lock != NULL) { while (lock != NULL) {
type_mode = lock->type_mode; const ulint type_mode = lock->type_mode;
lock_rec_reset_nth_bit(lock, donator_heap_no); lock_rec_reset_nth_bit(lock, donator_heap_no);
if (UNIV_UNLIKELY(lock_get_wait(lock))) { if (UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
lock_reset_lock_and_trx_wait(lock); lock_reset_lock_and_trx_wait(lock);
} }
...@@ -2731,10 +2730,6 @@ lock_move_rec_list_end( ...@@ -2731,10 +2730,6 @@ lock_move_rec_list_end(
is the first record moved */ is the first record moved */
{ {
lock_t* lock; lock_t* lock;
page_cur_t cur1;
page_cur_t cur2;
ulint heap_no;
ulint type_mode;
const ulint comp = page_rec_is_comp(rec); const ulint comp = page_rec_is_comp(rec);
lock_mutex_enter_kernel(); lock_mutex_enter_kernel();
...@@ -2748,6 +2743,9 @@ lock_move_rec_list_end( ...@@ -2748,6 +2743,9 @@ lock_move_rec_list_end(
lock = lock_rec_get_first_on_page(block); lock = lock_rec_get_first_on_page(block);
while (lock != NULL) { while (lock != NULL) {
page_cur_t cur1;
page_cur_t cur2;
const ulint type_mode = lock->type_mode;
page_cur_position((rec_t*) rec, (buf_block_t*) block, &cur1); page_cur_position((rec_t*) rec, (buf_block_t*) block, &cur1);
...@@ -2762,6 +2760,8 @@ lock_move_rec_list_end( ...@@ -2762,6 +2760,8 @@ lock_move_rec_list_end(
reset the lock bits on the old */ reset the lock bits on the old */
while (!page_cur_is_after_last(&cur1)) { while (!page_cur_is_after_last(&cur1)) {
ulint heap_no;
ut_ad(comp ut_ad(comp
|| !memcmp(page_cur_get_rec(&cur1), || !memcmp(page_cur_get_rec(&cur1),
page_cur_get_rec(&cur2), page_cur_get_rec(&cur2),
...@@ -2776,11 +2776,9 @@ lock_move_rec_list_end( ...@@ -2776,11 +2776,9 @@ lock_move_rec_list_end(
} }
if (lock_rec_get_nth_bit(lock, heap_no)) { if (lock_rec_get_nth_bit(lock, heap_no)) {
type_mode = lock->type_mode;
lock_rec_reset_nth_bit(lock, heap_no); lock_rec_reset_nth_bit(lock, heap_no);
if (lock_get_wait(lock)) { if (UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
lock_reset_lock_and_trx_wait(lock); lock_reset_lock_and_trx_wait(lock);
} }
...@@ -2833,10 +2831,6 @@ lock_move_rec_list_start( ...@@ -2833,10 +2831,6 @@ lock_move_rec_list_start(
were copied */ were copied */
{ {
lock_t* lock; lock_t* lock;
page_cur_t cur1;
page_cur_t cur2;
ulint heap_no;
ulint type_mode;
const ulint comp = page_rec_is_comp(rec); const ulint comp = page_rec_is_comp(rec);
ut_ad(block->frame == page_align((rec_t*) rec)); ut_ad(block->frame == page_align((rec_t*) rec));
...@@ -2847,6 +2841,9 @@ lock_move_rec_list_start( ...@@ -2847,6 +2841,9 @@ lock_move_rec_list_start(
lock = lock_rec_get_first_on_page(block); lock = lock_rec_get_first_on_page(block);
while (lock != NULL) { while (lock != NULL) {
page_cur_t cur1;
page_cur_t cur2;
const ulint type_mode = lock->type_mode;
page_cur_set_before_first((buf_block_t*) block, &cur1); page_cur_set_before_first((buf_block_t*) block, &cur1);
page_cur_move_to_next(&cur1); page_cur_move_to_next(&cur1);
...@@ -2859,6 +2856,8 @@ lock_move_rec_list_start( ...@@ -2859,6 +2856,8 @@ lock_move_rec_list_start(
reset the lock bits on the old */ reset the lock bits on the old */
while (page_cur_get_rec(&cur1) != rec) { while (page_cur_get_rec(&cur1) != rec) {
ulint heap_no;
ut_ad(comp ut_ad(comp
|| !memcmp(page_cur_get_rec(&cur1), || !memcmp(page_cur_get_rec(&cur1),
page_cur_get_rec(&cur2), page_cur_get_rec(&cur2),
...@@ -2873,11 +2872,9 @@ lock_move_rec_list_start( ...@@ -2873,11 +2872,9 @@ lock_move_rec_list_start(
} }
if (lock_rec_get_nth_bit(lock, heap_no)) { if (lock_rec_get_nth_bit(lock, heap_no)) {
type_mode = lock->type_mode;
lock_rec_reset_nth_bit(lock, heap_no); lock_rec_reset_nth_bit(lock, heap_no);
if (lock_get_wait(lock)) { if (UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
lock_reset_lock_and_trx_wait(lock); lock_reset_lock_and_trx_wait(lock);
} }
...@@ -2898,6 +2895,24 @@ lock_move_rec_list_start( ...@@ -2898,6 +2895,24 @@ lock_move_rec_list_start(
page_cur_move_to_next(&cur2); page_cur_move_to_next(&cur2);
} }
#ifdef UNIV_DEBUG
if (page_rec_is_supremum(rec)) {
ulint i;
for (i = 2; i < lock_rec_get_n_bits(lock); i++) {
if (UNIV_UNLIKELY
(lock_rec_get_nth_bit(lock, i))) {
fprintf(stderr,
"lock_move_rec_list_start():"
" %lu not moved in %p\n",
(ulong) i, (void*) lock);
ut_error;
}
}
}
#endif /* UNIV_DEBUG */
lock = lock_rec_get_next_on_page(lock); lock = lock_rec_get_next_on_page(lock);
} }
...@@ -3597,7 +3612,7 @@ lock_table_create( ...@@ -3597,7 +3612,7 @@ lock_table_create(
UT_LIST_ADD_LAST(un_member.tab_lock.locks, table->locks, lock); UT_LIST_ADD_LAST(un_member.tab_lock.locks, table->locks, lock);
if (type_mode & LOCK_WAIT) { if (UNIV_UNLIKELY(type_mode & LOCK_WAIT)) {
lock_set_lock_and_trx_wait(lock, trx); lock_set_lock_and_trx_wait(lock, trx);
} }
...@@ -5391,4 +5406,3 @@ lock_clust_rec_read_check_and_lock_alt( ...@@ -5391,4 +5406,3 @@ lock_clust_rec_read_check_and_lock_alt(
} }
return(ret); return(ret);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment