mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
2f85f78db4
- _ma_apply_redo_index: Assertion `page_offset != 0 && page_offset + length <= page_length' failed Fixes one bug and one log assert when inserting rows: - _ma_log_split: Assertion `org_length <= info->s->max_index_block_size' failed - write_block_record: Assertion '(data_length < MAX_TAIL_SIZE(block_size)' failed Mark in recovery log where _ma_log_add() calls was done (for better debugging). storage/maria/ma_bitmap.c: Don't write a head part on a tail page. (Caused an assert in write_block_record()) storage/maria/ma_delete.c: Mark in recovery log where _ma_log_add() calls was done storage/maria/ma_key_recover.c: Mark in recovery log where _ma_log_add() calls was done Fixed not handled logging case for overfull index pages. storage/maria/ma_key_recover.h: Mark in recovery log where _ma_log_add() calls was done storage/maria/ma_loghandler.h: Mark in recovery log where _ma_log_add() calls was done storage/maria/ma_rt_key.c: Mark in recovery log where _ma_log_add() calls was done storage/maria/ma_write.c: Mark in recovery log where _ma_log_add() calls was done. Fixed wrong call to _ma_split_page() for overfull pages
122 lines
5.1 KiB
C
122 lines
5.1 KiB
C
/* Copyright (C) 2007 Michael Widenius
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
/*
|
|
When we have finished the write/update/delete of a row, we have cleanups to
|
|
do. For now it is signalling to Checkpoint that all dirtied pages have
|
|
their rec_lsn set and page LSN set (_ma_unpin_all_pages() has been called),
|
|
and that bitmap pages are correct (_ma_bitmap_release_unused() has been
|
|
called).
|
|
*/
|
|
|
|
/* Struct for clr_end */
|
|
|
|
struct st_msg_to_write_hook_for_clr_end
|
|
{
|
|
LSN previous_undo_lsn;
|
|
enum translog_record_type undone_record_type;
|
|
ha_checksum checksum_delta;
|
|
void *extra_msg;
|
|
};
|
|
|
|
struct st_msg_to_write_hook_for_undo_key
|
|
{
|
|
my_off_t *root;
|
|
my_off_t value;
|
|
uint keynr;
|
|
ulonglong auto_increment;
|
|
};
|
|
|
|
|
|
/* Function definitions for some redo functions */
|
|
|
|
my_bool _ma_write_clr(MARIA_HA *info, LSN undo_lsn,
|
|
enum translog_record_type undo_type,
|
|
my_bool store_checksum, ha_checksum checksum,
|
|
LSN *res_lsn, void *extra_msg);
|
|
int _ma_write_undo_key_insert(MARIA_HA *info, const MARIA_KEY *key,
|
|
my_off_t *root, my_off_t new_root,
|
|
LSN *res_lsn);
|
|
my_bool _ma_write_undo_key_delete(MARIA_HA *info, const MARIA_KEY *key,
|
|
my_off_t new_root, LSN *res_lsn);
|
|
my_bool write_hook_for_clr_end(enum translog_record_type type,
|
|
TRN *trn, MARIA_HA *tbl_info, LSN *lsn,
|
|
void *hook_arg);
|
|
extern my_bool write_hook_for_undo_key(enum translog_record_type type,
|
|
TRN *trn, MARIA_HA *tbl_info,
|
|
LSN *lsn, void *hook_arg);
|
|
extern my_bool write_hook_for_undo_key_insert(enum translog_record_type type,
|
|
TRN *trn, MARIA_HA *tbl_info,
|
|
LSN *lsn, void *hook_arg);
|
|
extern my_bool write_hook_for_undo_key_delete(enum translog_record_type type,
|
|
TRN *trn, MARIA_HA *tbl_info,
|
|
LSN *lsn, void *hook_arg);
|
|
|
|
my_bool _ma_log_prefix(MARIA_PAGE *page, uint changed_length, int move_length,
|
|
enum en_key_debug debug_marker);
|
|
my_bool _ma_log_suffix(MARIA_PAGE *page, uint org_length,
|
|
uint new_length);
|
|
my_bool _ma_log_add(MARIA_PAGE *page, uint buff_length, uchar *key_pos,
|
|
uint changed_length, int move_length,
|
|
my_bool handle_overflow,
|
|
enum en_key_debug debug_marker);
|
|
my_bool _ma_log_delete(MARIA_PAGE *page, const uchar *key_pos,
|
|
uint changed_length, uint move_length,
|
|
uint append_length, enum en_key_debug debug_marker);
|
|
my_bool _ma_log_change(MARIA_PAGE *page, const uchar *key_pos, uint length,
|
|
enum en_key_debug debug_marker);
|
|
my_bool _ma_log_new(MARIA_PAGE *page, my_bool root_page);
|
|
#ifdef EXTRA_DEBUG_KEY_CHANGES
|
|
void _ma_log_key_changes(MARIA_PAGE *ma_page, LEX_CUSTRING *log_array,
|
|
uchar *log_pos, uint *changed_length,
|
|
uint *translog_parts);
|
|
#else
|
|
#define _ma_log_key_changes(A,B,C,D,E)
|
|
#endif
|
|
|
|
uint _ma_apply_redo_index_new_page(MARIA_HA *info, LSN lsn,
|
|
const uchar *header, uint length);
|
|
uint _ma_apply_redo_index_free_page(MARIA_HA *info, LSN lsn,
|
|
const uchar *header);
|
|
uint _ma_apply_redo_index(MARIA_HA *info,
|
|
LSN lsn, const uchar *header, uint length);
|
|
|
|
my_bool _ma_apply_undo_key_insert(MARIA_HA *info, LSN undo_lsn,
|
|
const uchar *header, uint length);
|
|
my_bool _ma_apply_undo_key_delete(MARIA_HA *info, LSN undo_lsn,
|
|
const uchar *header, uint length,
|
|
my_bool with_root);
|
|
|
|
static inline void _ma_finalize_row(MARIA_HA *info)
|
|
{
|
|
info->trn->rec_lsn= LSN_IMPOSSIBLE;
|
|
}
|
|
|
|
/* unpinning is often the last operation before finalizing */
|
|
|
|
static inline void _ma_unpin_all_pages_and_finalize_row(MARIA_HA *info,
|
|
LSN undo_lsn)
|
|
{
|
|
_ma_unpin_all_pages(info, undo_lsn);
|
|
_ma_finalize_row(info);
|
|
}
|
|
|
|
extern my_bool _ma_lock_key_del(MARIA_HA *info, my_bool insert_at_end);
|
|
extern void _ma_unlock_key_del(MARIA_HA *info);
|
|
static inline void _ma_fast_unlock_key_del(MARIA_HA *info)
|
|
{
|
|
if (info->key_del_used)
|
|
_ma_unlock_key_del(info);
|
|
}
|