Commit ecff2cb1 authored by marko's avatar marko

branches/zip: Enable assertions on ut_ad(lock_rec_validate_page()).

lock_rec_get_nth_bit(), lock_rec_set_nth_bit(), lock_rec_reset_nth_bit(),
lock_rec_copy(): Simplify the code.
parent f5652a6a
...@@ -322,6 +322,16 @@ ibool ...@@ -322,6 +322,16 @@ ibool
lock_validate(void); lock_validate(void);
/*===============*/ /*===============*/
/* out: TRUE if ok */ /* out: TRUE if ok */
/*************************************************************************
Validates the record lock queues on a page. */
static
ibool
lock_rec_validate_page(
/*===================*/
/* out: TRUE if ok */
ulint space, /* in: space id */
ulint page_no);/* in: page number */
#endif /* UNIV_DEBUG */ #endif /* UNIV_DEBUG */
/* The lock system */ /* The lock system */
...@@ -434,7 +444,6 @@ lock_rec_get_nth_bit( ...@@ -434,7 +444,6 @@ lock_rec_get_nth_bit(
{ {
ulint byte_index; ulint byte_index;
ulint bit_index; ulint bit_index;
ulint b;
ut_ad(lock); ut_ad(lock);
ut_ad(lock_get_type(lock) == LOCK_REC); ut_ad(lock_get_type(lock) == LOCK_REC);
...@@ -447,9 +456,7 @@ lock_rec_get_nth_bit( ...@@ -447,9 +456,7 @@ lock_rec_get_nth_bit(
byte_index = i / 8; byte_index = i / 8;
bit_index = i % 8; bit_index = i % 8;
b = (ulint)*((byte*)lock + sizeof(lock_t) + byte_index); return(1 & ((const byte*) &lock[1])[byte_index] >> bit_index);
return(ut_bit_get_nth(b, bit_index));
} }
/*************************************************************************/ /*************************************************************************/
...@@ -1084,8 +1091,6 @@ lock_rec_set_nth_bit( ...@@ -1084,8 +1091,6 @@ lock_rec_set_nth_bit(
{ {
ulint byte_index; ulint byte_index;
ulint bit_index; ulint bit_index;
byte* ptr;
ulint b;
ut_ad(lock); ut_ad(lock);
ut_ad(lock_get_type(lock) == LOCK_REC); ut_ad(lock_get_type(lock) == LOCK_REC);
...@@ -1094,13 +1099,7 @@ lock_rec_set_nth_bit( ...@@ -1094,13 +1099,7 @@ lock_rec_set_nth_bit(
byte_index = i / 8; byte_index = i / 8;
bit_index = i % 8; bit_index = i % 8;
ptr = (byte*)lock + sizeof(lock_t) + byte_index; ((byte*) &lock[1])[byte_index] |= 1 << bit_index;
b = (ulint)*ptr;
b = ut_bit_set_nth(b, bit_index, TRUE);
*ptr = (byte)b;
} }
/************************************************************************** /**************************************************************************
...@@ -1139,8 +1138,6 @@ lock_rec_reset_nth_bit( ...@@ -1139,8 +1138,6 @@ lock_rec_reset_nth_bit(
{ {
ulint byte_index; ulint byte_index;
ulint bit_index; ulint bit_index;
byte* ptr;
ulint b;
ut_ad(lock); ut_ad(lock);
ut_ad(lock_get_type(lock) == LOCK_REC); ut_ad(lock_get_type(lock) == LOCK_REC);
...@@ -1149,13 +1146,7 @@ lock_rec_reset_nth_bit( ...@@ -1149,13 +1146,7 @@ lock_rec_reset_nth_bit(
byte_index = i / 8; byte_index = i / 8;
bit_index = i % 8; bit_index = i % 8;
ptr = (byte*)lock + sizeof(lock_t) + byte_index; ((byte*) &lock[1])[byte_index] &= ~(1 << bit_index);
b = (ulint)*ptr;
b = ut_bit_set_nth(b, bit_index, FALSE);
*ptr = (byte)b;
} }
/************************************************************************* /*************************************************************************
...@@ -1351,7 +1342,7 @@ lock_rec_bitmap_reset( ...@@ -1351,7 +1342,7 @@ lock_rec_bitmap_reset(
ut_ad((lock_rec_get_n_bits(lock) % 8) == 0); ut_ad((lock_rec_get_n_bits(lock) % 8) == 0);
memset((byte*) lock + sizeof(lock_t), 0, n_bytes); memset(&lock[1], 0, n_bytes);
} }
/************************************************************************* /*************************************************************************
...@@ -1364,18 +1355,13 @@ lock_rec_copy( ...@@ -1364,18 +1355,13 @@ lock_rec_copy(
const lock_t* lock, /* in: record lock */ const lock_t* lock, /* in: record lock */
mem_heap_t* heap) /* in: memory heap */ mem_heap_t* heap) /* in: memory heap */
{ {
lock_t* dupl_lock;
ulint size; ulint size;
ut_ad(lock_get_type(lock) == LOCK_REC); ut_ad(lock_get_type(lock) == LOCK_REC);
size = sizeof(lock_t) + lock_rec_get_n_bits(lock) / 8; size = sizeof(lock_t) + lock_rec_get_n_bits(lock) / 8;
dupl_lock = mem_heap_alloc(heap, size); return(memcpy(mem_heap_alloc(heap, size), lock, size));
ut_memcpy(dupl_lock, lock, size);
return(dupl_lock);
} }
/************************************************************************* /*************************************************************************
...@@ -2709,10 +2695,8 @@ lock_move_reorganize_page( ...@@ -2709,10 +2695,8 @@ lock_move_reorganize_page(
mem_heap_free(heap); mem_heap_free(heap);
#if 0 ut_ad(lock_rec_validate_page(buf_block_get_space(block),
ut_ad(lock_rec_validate_page(page_get_space_id(page), buf_block_get_page_no(block)));
page_get_page_no(page)));
#endif
} }
/***************************************************************** /*****************************************************************
...@@ -2803,12 +2787,10 @@ lock_move_rec_list_end( ...@@ -2803,12 +2787,10 @@ lock_move_rec_list_end(
lock_mutex_exit_kernel(); lock_mutex_exit_kernel();
#if 0
ut_ad(lock_rec_validate_page(buf_block_get_space(block), ut_ad(lock_rec_validate_page(buf_block_get_space(block),
buf_block_get_page_no(block))); buf_block_get_page_no(block)));
ut_ad(lock_rec_validate_page(buf_block_get_space(new_block), ut_ad(lock_rec_validate_page(buf_block_get_space(new_block),
buf_block_get_page_no(new_block))); buf_block_get_page_no(new_block)));
#endif
} }
/***************************************************************** /*****************************************************************
...@@ -2899,10 +2881,9 @@ lock_move_rec_list_start( ...@@ -2899,10 +2881,9 @@ lock_move_rec_list_start(
} }
lock_mutex_exit_kernel(); lock_mutex_exit_kernel();
#if 0
ut_ad(lock_rec_validate_page(buf_block_get_space(block), ut_ad(lock_rec_validate_page(buf_block_get_space(block),
buf_block_get_page_no(block))); buf_block_get_page_no(block)));
#endif
} }
/***************************************************************** /*****************************************************************
......
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