Commit 49d25239 authored by marko's avatar marko

branches/zip: Remove remaining occurrences of XDES_DESCRIBED_PER_PAGE.

mlog_parse_string(): Remove an off-by-one error in an assertion.

fil_extend_space_to_desired_size(): fsp_header_get_free_limit(),
fsp_try_extend_data_file(): Replace UNIV_PAGE_SIZE with the actual page size.

PAGE_ZIP_MIN_SIZE: New constant, to be used in assertions.

FSP_SEG_INODES_PER_PAGE: Add parameter zip_size.

fsp_seg_inode_page_get_nth_inode(), fsp_seg_inode_page_find_used(),
fsp_seg_inode_page_find_free(): Add parameter zip_size.
parent 8b14f397
...@@ -3583,6 +3583,7 @@ fil_extend_space_to_desired_size( ...@@ -3583,6 +3583,7 @@ fil_extend_space_to_desired_size(
ulint file_start_page_no; ulint file_start_page_no;
ulint offset_high; ulint offset_high;
ulint offset_low; ulint offset_low;
ulint page_size;
ibool success = TRUE; ibool success = TRUE;
fil_mutex_enter_and_prepare_for_io(space_id); fil_mutex_enter_and_prepare_for_io(space_id);
...@@ -3601,6 +3602,11 @@ fil_extend_space_to_desired_size( ...@@ -3601,6 +3602,11 @@ fil_extend_space_to_desired_size(
return(TRUE); return(TRUE);
} }
page_size = space->zip_size;
if (!page_size) {
page_size = UNIV_PAGE_SIZE;
}
node = UT_LIST_GET_LAST(space->chain); node = UT_LIST_GET_LAST(space->chain);
fil_node_prepare_for_io(node, system, space); fil_node_prepare_for_io(node, system, space);
...@@ -3610,30 +3616,30 @@ fil_extend_space_to_desired_size( ...@@ -3610,30 +3616,30 @@ fil_extend_space_to_desired_size(
/* Extend at most 64 pages at a time */ /* Extend at most 64 pages at a time */
buf_size = ut_min(64, size_after_extend - start_page_no) buf_size = ut_min(64, size_after_extend - start_page_no)
* UNIV_PAGE_SIZE; * page_size;
buf2 = mem_alloc(buf_size + UNIV_PAGE_SIZE); buf2 = mem_alloc(buf_size + page_size);
buf = ut_align(buf2, UNIV_PAGE_SIZE); buf = ut_align(buf2, page_size);
memset(buf, 0, buf_size); memset(buf, 0, buf_size);
while (start_page_no < size_after_extend) { while (start_page_no < size_after_extend) {
ulint n_pages = ut_min(buf_size / UNIV_PAGE_SIZE, ulint n_pages = ut_min(buf_size / page_size,
size_after_extend - start_page_no); size_after_extend - start_page_no);
offset_high = (start_page_no - file_start_page_no) offset_high = (start_page_no - file_start_page_no)
/ (4096 * ((1024 * 1024) / UNIV_PAGE_SIZE)); / (4096 * ((1024 * 1024) / page_size));
offset_low = ((start_page_no - file_start_page_no) offset_low = ((start_page_no - file_start_page_no)
% (4096 * ((1024 * 1024) / UNIV_PAGE_SIZE))) % (4096 * ((1024 * 1024) / page_size)))
* UNIV_PAGE_SIZE; * page_size;
#ifdef UNIV_HOTBACKUP #ifdef UNIV_HOTBACKUP
success = os_file_write(node->name, node->handle, buf, success = os_file_write(node->name, node->handle, buf,
offset_low, offset_high, offset_low, offset_high,
UNIV_PAGE_SIZE * n_pages); page_size * n_pages);
#else #else
success = os_aio(OS_FILE_WRITE, OS_AIO_SYNC, success = os_aio(OS_FILE_WRITE, OS_AIO_SYNC,
node->name, node->handle, buf, node->name, node->handle, buf,
offset_low, offset_high, offset_low, offset_high,
UNIV_PAGE_SIZE * n_pages, page_size * n_pages,
NULL, NULL); NULL, NULL);
#endif #endif
if (success) { if (success) {
...@@ -3647,7 +3653,7 @@ fil_extend_space_to_desired_size( ...@@ -3647,7 +3653,7 @@ fil_extend_space_to_desired_size(
n_pages = ((ulint) n_pages = ((ulint)
(os_file_get_size_as_iblonglong(node->handle) (os_file_get_size_as_iblonglong(node->handle)
/ UNIV_PAGE_SIZE)) - node->size; / page_size)) - node->size;
node->size += n_pages; node->size += n_pages;
space->size += n_pages; space->size += n_pages;
...@@ -3666,7 +3672,7 @@ fil_extend_space_to_desired_size( ...@@ -3666,7 +3672,7 @@ fil_extend_space_to_desired_size(
#ifndef UNIV_HOTBACKUP #ifndef UNIV_HOTBACKUP
if (space_id == 0) { if (space_id == 0) {
ulint pages_per_mb = (1024 * 1024) / UNIV_PAGE_SIZE; ulint pages_per_mb = (1024 * 1024) / page_size;
/* Keep the last data file size info up to date, rounded to /* Keep the last data file size info up to date, rounded to
full megabytes */ full megabytes */
......
...@@ -135,7 +135,9 @@ typedef byte fseg_inode_t; ...@@ -135,7 +135,9 @@ typedef byte fseg_inode_t;
/*-------------------------------------*/ /*-------------------------------------*/
#define FSEG_INODE_SIZE (16 + 3 * FLST_BASE_NODE_SIZE + FSEG_FRAG_ARR_N_SLOTS * FSEG_FRAG_SLOT_SIZE) #define FSEG_INODE_SIZE (16 + 3 * FLST_BASE_NODE_SIZE + FSEG_FRAG_ARR_N_SLOTS * FSEG_FRAG_SLOT_SIZE)
#define FSP_SEG_INODES_PER_PAGE ((UNIV_PAGE_SIZE - FSEG_ARR_OFFSET - 10) / FSEG_INODE_SIZE) #define FSP_SEG_INODES_PER_PAGE(zip_size) \
(((zip_size ? zip_size : UNIV_PAGE_SIZE) \
- FSEG_ARR_OFFSET - 10) / FSEG_INODE_SIZE)
/* Number of segment inodes which fit on a /* Number of segment inodes which fit on a
single page */ single page */
...@@ -614,8 +616,9 @@ xdes_calc_descriptor_page( ...@@ -614,8 +616,9 @@ xdes_calc_descriptor_page(
+ (UNIV_PAGE_SIZE / FSP_EXTENT_SIZE) * XDES_SIZE + (UNIV_PAGE_SIZE / FSP_EXTENT_SIZE) * XDES_SIZE
# error # error
#endif #endif
#if 1024 <= XDES_ARR_OFFSET + (1024 / FSP_EXTENT_SIZE) * XDES_SIZE #if PAGE_ZIP_MIN_SIZE <= XDES_ARR_OFFSET \
# error /* extent descriptor will not fit on smallest page_zip */ + (PAGE_ZIP_MIN_SIZE / FSP_EXTENT_SIZE) * XDES_SIZE
# error
#endif #endif
ut_ad(zip_size <= XDES_ARR_OFFSET ut_ad(zip_size <= XDES_ARR_OFFSET
+ (zip_size / FSP_EXTENT_SIZE) * XDES_SIZE); + (zip_size / FSP_EXTENT_SIZE) * XDES_SIZE);
...@@ -1031,6 +1034,7 @@ fsp_header_get_free_limit( ...@@ -1031,6 +1034,7 @@ fsp_header_get_free_limit(
{ {
fsp_header_t* header; fsp_header_t* header;
ulint limit; ulint limit;
ulint zip_size;
mtr_t mtr; mtr_t mtr;
ut_a(space == 0); /* We have only one log_fsp_current_... variable */ ut_a(space == 0); /* We have only one log_fsp_current_... variable */
...@@ -1042,8 +1046,13 @@ fsp_header_get_free_limit( ...@@ -1042,8 +1046,13 @@ fsp_header_get_free_limit(
header = fsp_get_space_header(space, &mtr); header = fsp_get_space_header(space, &mtr);
limit = mtr_read_ulint(header + FSP_FREE_LIMIT, MLOG_4BYTES, &mtr); limit = mtr_read_ulint(header + FSP_FREE_LIMIT, MLOG_4BYTES, &mtr);
zip_size = mach_read_from_4(header + FSP_PAGE_ZIP_SIZE);
limit = limit / ((1024 * 1024) / UNIV_PAGE_SIZE); if (!zip_size) {
limit /= ((1024 * 1024) / UNIV_PAGE_SIZE);
} else {
limit /= ((1024 * 1024) / zip_size);
}
log_fsp_current_free_limit_set_and_checkpoint(limit); log_fsp_current_free_limit_set_and_checkpoint(limit);
...@@ -1132,6 +1141,7 @@ fsp_try_extend_data_file( ...@@ -1132,6 +1141,7 @@ fsp_try_extend_data_file(
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
ulint size; ulint size;
ulint zip_size;
ulint new_size; ulint new_size;
ulint old_size; ulint old_size;
ulint size_increase; ulint size_increase;
...@@ -1211,10 +1221,16 @@ fsp_try_extend_data_file( ...@@ -1211,10 +1221,16 @@ fsp_try_extend_data_file(
/* We ignore any fragments of a full megabyte when storing the size /* We ignore any fragments of a full megabyte when storing the size
to the space header */ to the space header */
mlog_write_ulint(header + FSP_SIZE, zip_size = mach_read_from_4(header + FSP_PAGE_ZIP_SIZE);
ut_calc_align_down(actual_size, (1024 * 1024) / UNIV_PAGE_SIZE),
MLOG_4BYTES, mtr); if (!zip_size) {
new_size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, mtr); new_size = ut_calc_align_down(actual_size,
(1024 * 1024) / UNIV_PAGE_SIZE);
} else {
new_size = ut_calc_align_down(actual_size,
(1024 * 1024) / zip_size);
}
mlog_write_ulint(header + FSP_SIZE, new_size, MLOG_4BYTES, mtr);
*actual_increase = new_size - old_size; *actual_increase = new_size - old_size;
...@@ -1257,6 +1273,9 @@ fsp_fill_free_list( ...@@ -1257,6 +1273,9 @@ fsp_fill_free_list(
limit = mtr_read_ulint(header + FSP_FREE_LIMIT, MLOG_4BYTES, mtr); limit = mtr_read_ulint(header + FSP_FREE_LIMIT, MLOG_4BYTES, mtr);
zip_size = mach_read_from_4(FSP_PAGE_ZIP_SIZE + header); zip_size = mach_read_from_4(FSP_PAGE_ZIP_SIZE + header);
ut_a(!(zip_size & (zip_size - 1))); /* must be a power of 2 */
ut_a(zip_size <= UNIV_PAGE_SIZE);
ut_a(!zip_size || zip_size >= PAGE_ZIP_MIN_SIZE);
if (space == 0 && srv_auto_extend_last_data_file if (space == 0 && srv_auto_extend_last_data_file
&& size < limit + FSP_EXTENT_SIZE * FSP_FREE_ADD) { && size < limit + FSP_EXTENT_SIZE * FSP_FREE_ADD) {
...@@ -1279,18 +1298,22 @@ fsp_fill_free_list( ...@@ -1279,18 +1298,22 @@ fsp_fill_free_list(
while ((init_space && i < 1) while ((init_space && i < 1)
|| ((i + FSP_EXTENT_SIZE <= size) && (count < FSP_FREE_ADD))) { || ((i + FSP_EXTENT_SIZE <= size) && (count < FSP_FREE_ADD))) {
const ibool init_xdes
= !(i & (zip_size ? UNIV_PAGE_SIZE - 1 : zip_size - 1));
mlog_write_ulint(header + FSP_FREE_LIMIT, i + FSP_EXTENT_SIZE, mlog_write_ulint(header + FSP_FREE_LIMIT, i + FSP_EXTENT_SIZE,
MLOG_4BYTES, mtr); MLOG_4BYTES, mtr);
/* Update the free limit info in the log system and make /* Update the free limit info in the log system and make
a checkpoint */ a checkpoint */
if (space == 0) { if (space == 0) {
ut_a(!zip_size);
log_fsp_current_free_limit_set_and_checkpoint( log_fsp_current_free_limit_set_and_checkpoint(
(i + FSP_EXTENT_SIZE) (i + FSP_EXTENT_SIZE)
/ ((1024 * 1024) / UNIV_PAGE_SIZE)); / ((1024 * 1024) / UNIV_PAGE_SIZE));
} }
if (0 == i % XDES_DESCRIBED_PER_PAGE) { if (UNIV_UNLIKELY(init_xdes)) {
/* We are going to initialize a new descriptor page /* We are going to initialize a new descriptor page
and a new ibuf bitmap page: the prior contents of the and a new ibuf bitmap page: the prior contents of the
...@@ -1338,11 +1361,11 @@ fsp_fill_free_list( ...@@ -1338,11 +1361,11 @@ fsp_fill_free_list(
#if UNIV_PAGE_SIZE % FSP_EXTENT_SIZE #if UNIV_PAGE_SIZE % FSP_EXTENT_SIZE
# error "UNIV_PAGE_SIZE % FSP_EXTENT_SIZE != 0" # error "UNIV_PAGE_SIZE % FSP_EXTENT_SIZE != 0"
#endif #endif
#if 1024 % FSP_EXTENT_SIZE /* smallest page_zip->size */ #if PAGE_ZIP_MIN_SIZE % FSP_EXTENT_SIZE
# error "1024 % FSP_EXTENT_SIZE != 0" # error "PAGE_ZIP_MIN_SIZE % FSP_EXTENT_SIZE != 0"
#endif #endif
if (0 == i % XDES_DESCRIBED_PER_PAGE) { if (UNIV_UNLIKELY(init_xdes)) {
/* The first page in the extent is a descriptor page /* The first page in the extent is a descriptor page
and the second is an ibuf bitmap page: mark them and the second is an ibuf bitmap page: mark them
...@@ -1681,9 +1704,10 @@ fsp_seg_inode_page_get_nth_inode( ...@@ -1681,9 +1704,10 @@ fsp_seg_inode_page_get_nth_inode(
/* out: segment inode */ /* out: segment inode */
page_t* page, /* in: segment inode page */ page_t* page, /* in: segment inode page */
ulint i, /* in: inode index on page */ ulint i, /* in: inode index on page */
ulint zip_size __attribute__((unused)),/* in: compressed page size, or 0 */
mtr_t* mtr __attribute__((unused))) /* in: mini-transaction handle */ mtr_t* mtr __attribute__((unused))) /* in: mini-transaction handle */
{ {
ut_ad(i < FSP_SEG_INODES_PER_PAGE); ut_ad(i < FSP_SEG_INODES_PER_PAGE(zip_size));
ut_ad(mtr_memo_contains(mtr, buf_block_align(page), ut_ad(mtr_memo_contains(mtr, buf_block_align(page),
MTR_MEMO_PAGE_X_FIX)); MTR_MEMO_PAGE_X_FIX));
...@@ -1699,14 +1723,16 @@ fsp_seg_inode_page_find_used( ...@@ -1699,14 +1723,16 @@ fsp_seg_inode_page_find_used(
/* out: segment inode index, or ULINT_UNDEFINED /* out: segment inode index, or ULINT_UNDEFINED
if not found */ if not found */
page_t* page, /* in: segment inode page */ page_t* page, /* in: segment inode page */
ulint zip_size,/* in: compressed page size, or 0 */
mtr_t* mtr) /* in: mini-transaction handle */ mtr_t* mtr) /* in: mini-transaction handle */
{ {
ulint i; ulint i;
fseg_inode_t* inode; fseg_inode_t* inode;
for (i = 0; i < FSP_SEG_INODES_PER_PAGE; i++) { for (i = 0; i < FSP_SEG_INODES_PER_PAGE(zip_size); i++) {
inode = fsp_seg_inode_page_get_nth_inode(page, i, mtr); inode = fsp_seg_inode_page_get_nth_inode(
page, i, zip_size, mtr);
if (ut_dulint_cmp(mach_read_from_8(inode + FSEG_ID), if (ut_dulint_cmp(mach_read_from_8(inode + FSEG_ID),
ut_dulint_zero) != 0) { ut_dulint_zero) != 0) {
...@@ -1728,15 +1754,16 @@ fsp_seg_inode_page_find_free( ...@@ -1728,15 +1754,16 @@ fsp_seg_inode_page_find_free(
/* out: segment inode index, or ULINT_UNDEFINED /* out: segment inode index, or ULINT_UNDEFINED
if not found */ if not found */
page_t* page, /* in: segment inode page */ page_t* page, /* in: segment inode page */
ulint j, /* in: search forward starting from this index */ ulint i, /* in: search forward starting from this index */
ulint zip_size,/* in: compressed page size, or 0 */
mtr_t* mtr) /* in: mini-transaction handle */ mtr_t* mtr) /* in: mini-transaction handle */
{ {
ulint i;
fseg_inode_t* inode; fseg_inode_t* inode;
for (i = j; i < FSP_SEG_INODES_PER_PAGE; i++) { for (; i < FSP_SEG_INODES_PER_PAGE(zip_size); i++) {
inode = fsp_seg_inode_page_get_nth_inode(page, i, mtr); inode = fsp_seg_inode_page_get_nth_inode(
page, i, zip_size, mtr);
if (ut_dulint_cmp(mach_read_from_8(inode + FSEG_ID), if (ut_dulint_cmp(mach_read_from_8(inode + FSEG_ID),
ut_dulint_zero) == 0) { ut_dulint_zero) == 0) {
...@@ -1763,6 +1790,7 @@ fsp_alloc_seg_inode_page( ...@@ -1763,6 +1790,7 @@ fsp_alloc_seg_inode_page(
page_t* page; page_t* page;
ulint page_no; ulint page_no;
ulint space; ulint space;
ulint zip_size;
ulint i; ulint i;
space = buf_frame_get_space_id(space_header); space = buf_frame_get_space_id(space_header);
...@@ -1784,9 +1812,13 @@ fsp_alloc_seg_inode_page( ...@@ -1784,9 +1812,13 @@ fsp_alloc_seg_inode_page(
buf_page_dbg_add_level(page, SYNC_FSP_PAGE); buf_page_dbg_add_level(page, SYNC_FSP_PAGE);
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
for (i = 0; i < FSP_SEG_INODES_PER_PAGE; i++) { zip_size = mtr_read_ulint(
space_header + FSP_PAGE_ZIP_SIZE, MLOG_4BYTES, mtr);
for (i = 0; i < FSP_SEG_INODES_PER_PAGE(zip_size); i++) {
inode = fsp_seg_inode_page_get_nth_inode(page, i, mtr); inode = fsp_seg_inode_page_get_nth_inode(
page, i, zip_size, mtr);
mlog_write_dulint(inode + FSEG_ID, ut_dulint_zero, mtr); mlog_write_dulint(inode + FSEG_ID, ut_dulint_zero, mtr);
} }
...@@ -1811,6 +1843,7 @@ fsp_alloc_seg_inode( ...@@ -1811,6 +1843,7 @@ fsp_alloc_seg_inode(
page_t* page; page_t* page;
fseg_inode_t* inode; fseg_inode_t* inode;
ibool success; ibool success;
ulint zip_size;
ulint n; ulint n;
if (flst_get_len(space_header + FSP_SEG_INODES_FREE, mtr) == 0) { if (flst_get_len(space_header + FSP_SEG_INODES_FREE, mtr) == 0) {
...@@ -1826,20 +1859,21 @@ fsp_alloc_seg_inode( ...@@ -1826,20 +1859,21 @@ fsp_alloc_seg_inode(
page_no = flst_get_first(space_header + FSP_SEG_INODES_FREE, mtr).page; page_no = flst_get_first(space_header + FSP_SEG_INODES_FREE, mtr).page;
zip_size = mach_read_from_4(space_header + FSP_PAGE_ZIP_SIZE);
page = buf_page_get(buf_frame_get_space_id(space_header), page_no, page = buf_page_get(buf_frame_get_space_id(space_header), page_no,
RW_X_LATCH, mtr); RW_X_LATCH, mtr);
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
buf_page_dbg_add_level(page, SYNC_FSP_PAGE); buf_page_dbg_add_level(page, SYNC_FSP_PAGE);
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
n = fsp_seg_inode_page_find_free(page, 0, mtr); n = fsp_seg_inode_page_find_free(page, 0, zip_size, mtr);
ut_a(n != ULINT_UNDEFINED); ut_a(n != ULINT_UNDEFINED);
inode = fsp_seg_inode_page_get_nth_inode(page, n, mtr); inode = fsp_seg_inode_page_get_nth_inode(page, n, zip_size, mtr);
if (ULINT_UNDEFINED == fsp_seg_inode_page_find_free(page, n + 1, if (ULINT_UNDEFINED == fsp_seg_inode_page_find_free(page, n + 1,
mtr)) { zip_size, mtr)) {
/* There are no other unused headers left on the page: move it /* There are no other unused headers left on the page: move it
to another list */ to another list */
...@@ -1865,14 +1899,17 @@ fsp_free_seg_inode( ...@@ -1865,14 +1899,17 @@ fsp_free_seg_inode(
{ {
page_t* page; page_t* page;
fsp_header_t* space_header; fsp_header_t* space_header;
ulint zip_size;
page = buf_frame_align(inode); page = buf_frame_align(inode);
space_header = fsp_get_space_header(space, mtr); space_header = fsp_get_space_header(space, mtr);
zip_size = mach_read_from_4(space_header + FSP_PAGE_ZIP_SIZE);
ut_ad(mach_read_from_4(inode + FSEG_MAGIC_N) == FSEG_MAGIC_N_VALUE); ut_ad(mach_read_from_4(inode + FSEG_MAGIC_N) == FSEG_MAGIC_N_VALUE);
if (ULINT_UNDEFINED == fsp_seg_inode_page_find_free(page, 0, mtr)) { if (ULINT_UNDEFINED == fsp_seg_inode_page_find_free(
page, 0, zip_size, mtr)) {
/* Move the page to another list */ /* Move the page to another list */
...@@ -1886,7 +1923,8 @@ fsp_free_seg_inode( ...@@ -1886,7 +1923,8 @@ fsp_free_seg_inode(
mlog_write_dulint(inode + FSEG_ID, ut_dulint_zero, mtr); mlog_write_dulint(inode + FSEG_ID, ut_dulint_zero, mtr);
mlog_write_ulint(inode + FSEG_MAGIC_N, 0, MLOG_4BYTES, mtr); mlog_write_ulint(inode + FSEG_MAGIC_N, 0, MLOG_4BYTES, mtr);
if (ULINT_UNDEFINED == fsp_seg_inode_page_find_used(page, mtr)) { if (ULINT_UNDEFINED == fsp_seg_inode_page_find_used(
page, zip_size, mtr)) {
/* There are no other used headers left on the page: free it */ /* There are no other used headers left on the page: free it */
...@@ -2783,6 +2821,7 @@ fsp_reserve_free_extents( ...@@ -2783,6 +2821,7 @@ fsp_reserve_free_extents(
ulint n_free_list_ext; ulint n_free_list_ext;
ulint free_limit; ulint free_limit;
ulint size; ulint size;
ulint zip_size;
ulint n_free; ulint n_free;
ulint n_free_up; ulint n_free_up;
ulint reserve; ulint reserve;
...@@ -2802,6 +2841,10 @@ fsp_reserve_free_extents( ...@@ -2802,6 +2841,10 @@ fsp_reserve_free_extents(
mtr_x_lock(latch, mtr); mtr_x_lock(latch, mtr);
space_header = fsp_get_space_header(space, mtr); space_header = fsp_get_space_header(space, mtr);
zip_size = mach_read_from_4(FSP_PAGE_ZIP_SIZE + space_header);
ut_a(!(zip_size & (zip_size - 1))); /* must be a power of 2 */
ut_a(zip_size <= UNIV_PAGE_SIZE);
ut_a(!zip_size || zip_size >= PAGE_ZIP_MIN_SIZE);
try_again: try_again:
size = mtr_read_ulint(space_header + FSP_SIZE, MLOG_4BYTES, mtr); size = mtr_read_ulint(space_header + FSP_SIZE, MLOG_4BYTES, mtr);
...@@ -2824,8 +2867,13 @@ try_again: ...@@ -2824,8 +2867,13 @@ try_again:
if (n_free_up > 0) { if (n_free_up > 0) {
n_free_up--; n_free_up--;
n_free_up = n_free_up - n_free_up if (!zip_size) {
/ (XDES_DESCRIBED_PER_PAGE / FSP_EXTENT_SIZE); n_free_up -= n_free_up
/ (UNIV_PAGE_SIZE / FSP_EXTENT_SIZE);
} else {
n_free_up -= n_free_up
/ (zip_size / FSP_EXTENT_SIZE);
}
} }
n_free = n_free_list_ext + n_free_up; n_free = n_free_list_ext + n_free_up;
...@@ -2886,6 +2934,7 @@ fsp_get_available_space_in_free_extents( ...@@ -2886,6 +2934,7 @@ fsp_get_available_space_in_free_extents(
ulint n_free_list_ext; ulint n_free_list_ext;
ulint free_limit; ulint free_limit;
ulint size; ulint size;
ulint zip_size;
ulint n_free; ulint n_free;
ulint n_free_up; ulint n_free_up;
ulint reserve; ulint reserve;
...@@ -2903,6 +2952,8 @@ fsp_get_available_space_in_free_extents( ...@@ -2903,6 +2952,8 @@ fsp_get_available_space_in_free_extents(
space_header = fsp_get_space_header(space, &mtr); space_header = fsp_get_space_header(space, &mtr);
zip_size = mach_read_from_4(FSP_PAGE_ZIP_SIZE + space_header);
size = mtr_read_ulint(space_header + FSP_SIZE, MLOG_4BYTES, &mtr); size = mtr_read_ulint(space_header + FSP_SIZE, MLOG_4BYTES, &mtr);
n_free_list_ext = flst_get_len(space_header + FSP_FREE, &mtr); n_free_list_ext = flst_get_len(space_header + FSP_FREE, &mtr);
...@@ -2927,8 +2978,13 @@ fsp_get_available_space_in_free_extents( ...@@ -2927,8 +2978,13 @@ fsp_get_available_space_in_free_extents(
if (n_free_up > 0) { if (n_free_up > 0) {
n_free_up--; n_free_up--;
n_free_up = n_free_up - n_free_up if (!zip_size) {
/ (XDES_DESCRIBED_PER_PAGE / FSP_EXTENT_SIZE); n_free_up -= n_free_up
/ (UNIV_PAGE_SIZE / FSP_EXTENT_SIZE);
} else {
n_free_up -= n_free_up
/ (zip_size / FSP_EXTENT_SIZE);
}
} }
n_free = n_free_list_ext + n_free_up; n_free = n_free_list_ext + n_free_up;
...@@ -2943,8 +2999,13 @@ fsp_get_available_space_in_free_extents( ...@@ -2943,8 +2999,13 @@ fsp_get_available_space_in_free_extents(
return(0); return(0);
} }
if (!zip_size) {
return(((n_free - reserve) * FSP_EXTENT_SIZE) return(((n_free - reserve) * FSP_EXTENT_SIZE)
* (UNIV_PAGE_SIZE / 1024)); * (UNIV_PAGE_SIZE / 1024));
} else {
return(((n_free - reserve) * FSP_EXTENT_SIZE)
* (zip_size / 1024));
}
} }
/************************************************************************ /************************************************************************
...@@ -3659,6 +3720,7 @@ fsp_validate( ...@@ -3659,6 +3720,7 @@ fsp_validate(
fseg_inode_t* seg_inode; fseg_inode_t* seg_inode;
page_t* seg_inode_page; page_t* seg_inode_page;
ulint size; ulint size;
ulint zip_size;
ulint free_limit; ulint free_limit;
ulint frag_n_used; ulint frag_n_used;
mtr_t mtr; mtr_t mtr;
...@@ -3684,6 +3746,11 @@ fsp_validate( ...@@ -3684,6 +3746,11 @@ fsp_validate(
header = fsp_get_space_header(space, &mtr); header = fsp_get_space_header(space, &mtr);
zip_size = mach_read_from_4(FSP_PAGE_ZIP_SIZE + header);
ut_a(!(zip_size & (zip_size - 1))); /* must be a power of 2 */
ut_a(zip_size <= UNIV_PAGE_SIZE);
ut_a(!zip_size || zip_size >= PAGE_ZIP_MIN_SIZE);
size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, &mtr); size = mtr_read_ulint(header + FSP_SIZE, MLOG_4BYTES, &mtr);
free_limit = mtr_read_ulint(header + FSP_FREE_LIMIT, free_limit = mtr_read_ulint(header + FSP_FREE_LIMIT,
MLOG_4BYTES, &mtr); MLOG_4BYTES, &mtr);
...@@ -3787,8 +3854,8 @@ fsp_validate( ...@@ -3787,8 +3854,8 @@ fsp_validate(
while (!fil_addr_is_null(node_addr)) { while (!fil_addr_is_null(node_addr)) {
for (n = 0; n < FSP_SEG_INODES_PER_PAGE; n++) { n = 0;
do {
mtr_start(&mtr); mtr_start(&mtr);
mtr_x_lock(fil_space_get_latch(space), &mtr); mtr_x_lock(fil_space_get_latch(space), &mtr);
...@@ -3796,7 +3863,7 @@ fsp_validate( ...@@ -3796,7 +3863,7 @@ fsp_validate(
RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE; RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE;
seg_inode = fsp_seg_inode_page_get_nth_inode( seg_inode = fsp_seg_inode_page_get_nth_inode(
seg_inode_page, n, &mtr); seg_inode_page, n, zip_size, &mtr);
ut_a(ut_dulint_cmp( ut_a(ut_dulint_cmp(
mach_read_from_8(seg_inode + FSEG_ID), mach_read_from_8(seg_inode + FSEG_ID),
ut_dulint_zero) != 0); ut_dulint_zero) != 0);
...@@ -3814,7 +3881,7 @@ fsp_validate( ...@@ -3814,7 +3881,7 @@ fsp_validate(
next_node_addr = flst_get_next_addr(seg_inode_page next_node_addr = flst_get_next_addr(seg_inode_page
+ FSEG_INODE_PAGE_NODE, &mtr); + FSEG_INODE_PAGE_NODE, &mtr);
mtr_commit(&mtr); mtr_commit(&mtr);
} } while (++n < FSP_SEG_INODES_PER_PAGE(zip_size));
node_addr = next_node_addr; node_addr = next_node_addr;
} }
...@@ -3832,8 +3899,9 @@ fsp_validate( ...@@ -3832,8 +3899,9 @@ fsp_validate(
while (!fil_addr_is_null(node_addr)) { while (!fil_addr_is_null(node_addr)) {
for (n = 0; n < FSP_SEG_INODES_PER_PAGE; n++) { n = 0;
do {
mtr_start(&mtr); mtr_start(&mtr);
mtr_x_lock(fil_space_get_latch(space), &mtr); mtr_x_lock(fil_space_get_latch(space), &mtr);
...@@ -3841,7 +3909,7 @@ fsp_validate( ...@@ -3841,7 +3909,7 @@ fsp_validate(
RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE; RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE;
seg_inode = fsp_seg_inode_page_get_nth_inode( seg_inode = fsp_seg_inode_page_get_nth_inode(
seg_inode_page, n, &mtr); seg_inode_page, n, zip_size, &mtr);
if (ut_dulint_cmp(mach_read_from_8( if (ut_dulint_cmp(mach_read_from_8(
seg_inode + FSEG_ID), seg_inode + FSEG_ID),
ut_dulint_zero) != 0) { ut_dulint_zero) != 0) {
...@@ -3860,16 +3928,23 @@ fsp_validate( ...@@ -3860,16 +3928,23 @@ fsp_validate(
next_node_addr = flst_get_next_addr(seg_inode_page next_node_addr = flst_get_next_addr(seg_inode_page
+ FSEG_INODE_PAGE_NODE, &mtr); + FSEG_INODE_PAGE_NODE, &mtr);
mtr_commit(&mtr); mtr_commit(&mtr);
} } while (++n < FSP_SEG_INODES_PER_PAGE(zip_size));
node_addr = next_node_addr; node_addr = next_node_addr;
} }
ut_a(descr_count * FSP_EXTENT_SIZE == free_limit); ut_a(descr_count * FSP_EXTENT_SIZE == free_limit);
if (!zip_size) {
ut_a(n_used + n_full_frag_pages
== n_used2 + 2 * ((free_limit + (UNIV_PAGE_SIZE - 1))
/ UNIV_PAGE_SIZE)
+ seg_inode_len_full + seg_inode_len_free);
} else {
ut_a(n_used + n_full_frag_pages ut_a(n_used + n_full_frag_pages
== n_used2 + 2* ((free_limit + XDES_DESCRIBED_PER_PAGE - 1) == n_used2 + 2 * ((free_limit + (zip_size - 1))
/ XDES_DESCRIBED_PER_PAGE) / zip_size)
+ seg_inode_len_full + seg_inode_len_free); + seg_inode_len_full + seg_inode_len_free);
}
ut_a(frag_n_used == n_used); ut_a(frag_n_used == n_used);
mtr_commit(&mtr2); mtr_commit(&mtr2);
...@@ -3888,6 +3963,7 @@ fsp_print( ...@@ -3888,6 +3963,7 @@ fsp_print(
fsp_header_t* header; fsp_header_t* header;
fseg_inode_t* seg_inode; fseg_inode_t* seg_inode;
page_t* seg_inode_page; page_t* seg_inode_page;
ulint zip_size;
ulint size; ulint size;
ulint free_limit; ulint free_limit;
ulint frag_n_used; ulint frag_n_used;
...@@ -3950,6 +4026,7 @@ fsp_print( ...@@ -3950,6 +4026,7 @@ fsp_print(
mtr_x_lock(fil_space_get_latch(space), &mtr); mtr_x_lock(fil_space_get_latch(space), &mtr);
header = fsp_get_space_header(space, &mtr); header = fsp_get_space_header(space, &mtr);
zip_size = mach_read_from_4(header + FSP_PAGE_ZIP_SIZE);
node_addr = flst_get_first(header + FSP_SEG_INODES_FULL, &mtr); node_addr = flst_get_first(header + FSP_SEG_INODES_FULL, &mtr);
...@@ -3957,7 +4034,9 @@ fsp_print( ...@@ -3957,7 +4034,9 @@ fsp_print(
while (!fil_addr_is_null(node_addr)) { while (!fil_addr_is_null(node_addr)) {
for (n = 0; n < FSP_SEG_INODES_PER_PAGE; n++) { n = 0;
do {
mtr_start(&mtr); mtr_start(&mtr);
mtr_x_lock(fil_space_get_latch(space), &mtr); mtr_x_lock(fil_space_get_latch(space), &mtr);
...@@ -3966,7 +4045,7 @@ fsp_print( ...@@ -3966,7 +4045,7 @@ fsp_print(
RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE; RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE;
seg_inode = fsp_seg_inode_page_get_nth_inode( seg_inode = fsp_seg_inode_page_get_nth_inode(
seg_inode_page, n, &mtr); seg_inode_page, n, zip_size, &mtr);
ut_a(ut_dulint_cmp(mach_read_from_8( ut_a(ut_dulint_cmp(mach_read_from_8(
seg_inode + FSEG_ID), seg_inode + FSEG_ID),
ut_dulint_zero) != 0); ut_dulint_zero) != 0);
...@@ -3977,7 +4056,7 @@ fsp_print( ...@@ -3977,7 +4056,7 @@ fsp_print(
next_node_addr = flst_get_next_addr(seg_inode_page next_node_addr = flst_get_next_addr(seg_inode_page
+ FSEG_INODE_PAGE_NODE, &mtr); + FSEG_INODE_PAGE_NODE, &mtr);
mtr_commit(&mtr); mtr_commit(&mtr);
} } while (++n < FSP_SEG_INODES_PER_PAGE(zip_size));
node_addr = next_node_addr; node_addr = next_node_addr;
} }
...@@ -3993,7 +4072,9 @@ fsp_print( ...@@ -3993,7 +4072,9 @@ fsp_print(
while (!fil_addr_is_null(node_addr)) { while (!fil_addr_is_null(node_addr)) {
for (n = 0; n < FSP_SEG_INODES_PER_PAGE; n++) { n = 0;
do {
mtr_start(&mtr); mtr_start(&mtr);
mtr_x_lock(fil_space_get_latch(space), &mtr); mtr_x_lock(fil_space_get_latch(space), &mtr);
...@@ -4002,7 +4083,7 @@ fsp_print( ...@@ -4002,7 +4083,7 @@ fsp_print(
RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE; RW_X_LATCH, &mtr) - FSEG_INODE_PAGE_NODE;
seg_inode = fsp_seg_inode_page_get_nth_inode( seg_inode = fsp_seg_inode_page_get_nth_inode(
seg_inode_page, n, &mtr); seg_inode_page, n, zip_size, &mtr);
if (ut_dulint_cmp(mach_read_from_8( if (ut_dulint_cmp(mach_read_from_8(
seg_inode + FSEG_ID), seg_inode + FSEG_ID),
ut_dulint_zero) != 0) { ut_dulint_zero) != 0) {
...@@ -4014,7 +4095,7 @@ fsp_print( ...@@ -4014,7 +4095,7 @@ fsp_print(
next_node_addr = flst_get_next_addr(seg_inode_page next_node_addr = flst_get_next_addr(seg_inode_page
+ FSEG_INODE_PAGE_NODE, &mtr); + FSEG_INODE_PAGE_NODE, &mtr);
mtr_commit(&mtr); mtr_commit(&mtr);
} } while (++n < FSP_SEG_INODES_PER_PAGE(zip_size));
node_addr = next_node_addr; node_addr = next_node_addr;
} }
......
...@@ -369,7 +369,8 @@ fseg_print( ...@@ -369,7 +369,8 @@ fseg_print(
/* Number of pages described in a single descriptor page: currently each page /* Number of pages described in a single descriptor page: currently each page
description takes less than 1 byte; a descriptor page is repeated every description takes less than 1 byte; a descriptor page is repeated every
this many file pages */ this many file pages */
#define XDES_DESCRIBED_PER_PAGE UNIV_PAGE_SIZE /* #define XDES_DESCRIBED_PER_PAGE UNIV_PAGE_SIZE */
/* This has been replaced with either UNIV_PAGE_SIZE or page_zip->size. */
/* The space low address page map */ /* The space low address page map */
/*--------------------------------------*/ /*--------------------------------------*/
......
...@@ -38,6 +38,8 @@ struct page_zip_des_struct ...@@ -38,6 +38,8 @@ struct page_zip_des_struct
ulint m_end; /* end offset of modification log */ ulint m_end; /* end offset of modification log */
}; };
#define PAGE_ZIP_MIN_SIZE 1024 /* smallest page_zip_des_struct.size */
/************************************************************************** /**************************************************************************
Write data to the compressed page. The data must already be written to Write data to the compressed page. The data must already be written to
the uncompressed page. */ the uncompressed page. */
......
...@@ -396,7 +396,7 @@ mlog_parse_string( ...@@ -396,7 +396,7 @@ mlog_parse_string(
len = mach_read_from_2(ptr); len = mach_read_from_2(ptr);
ptr += 2; ptr += 2;
ut_a(len + offset < UNIV_PAGE_SIZE); ut_a(len + offset <= UNIV_PAGE_SIZE);
if (end_ptr < ptr + len) { if (end_ptr < ptr + len) {
......
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