Commit 6ee5af16 authored by unknown's avatar unknown

fix for some gcc -ansi warnings.


storage/maria/ma_checkpoint.c:
  gcc -ansi warnings
storage/maria/ma_pagecache.c:
  comment
storage/maria/ma_recovery.c:
  gcc -ansi warnings
parent 908f6c79
...@@ -155,7 +155,7 @@ static int really_execute_checkpoint(void) ...@@ -155,7 +155,7 @@ static int really_execute_checkpoint(void)
LEX_STRING record_pieces[4]; /**< only malloc-ed pieces */ LEX_STRING record_pieces[4]; /**< only malloc-ed pieces */
LSN min_page_rec_lsn, min_trn_rec_lsn, min_first_undo_lsn; LSN min_page_rec_lsn, min_trn_rec_lsn, min_first_undo_lsn;
TRANSLOG_ADDRESS checkpoint_start_log_horizon; TRANSLOG_ADDRESS checkpoint_start_log_horizon;
uchar checkpoint_start_log_horizon_char[LSN_STORE_SIZE]; char checkpoint_start_log_horizon_char[LSN_STORE_SIZE];
DBUG_ENTER("really_execute_checkpoint"); DBUG_ENTER("really_execute_checkpoint");
bzero(&record_pieces, sizeof(record_pieces)); bzero(&record_pieces, sizeof(record_pieces));
...@@ -262,18 +262,20 @@ static int really_execute_checkpoint(void) ...@@ -262,18 +262,20 @@ static int really_execute_checkpoint(void)
(uint)pages_to_flush_before_next_checkpoint)); (uint)pages_to_flush_before_next_checkpoint));
/* compute log's low-water mark */ /* compute log's low-water mark */
TRANSLOG_ADDRESS log_low_water_mark= min_page_rec_lsn; {
set_if_smaller(log_low_water_mark, min_trn_rec_lsn); TRANSLOG_ADDRESS log_low_water_mark= min_page_rec_lsn;
set_if_smaller(log_low_water_mark, min_first_undo_lsn); set_if_smaller(log_low_water_mark, min_trn_rec_lsn);
set_if_smaller(log_low_water_mark, checkpoint_start_log_horizon); set_if_smaller(log_low_water_mark, min_first_undo_lsn);
/** set_if_smaller(log_low_water_mark, checkpoint_start_log_horizon);
Now purge unneeded logs. /**
As some systems have an unreliable fsync (drive lying), we could try to Now purge unneeded logs.
be robust against that: remember a few previous checkpoints in the As some systems have an unreliable fsync (drive lying), we could try to
control file, and not purge logs immediately... Think about it. be robust against that: remember a few previous checkpoints in the
*/ control file, and not purge logs immediately... Think about it.
if (translog_purge(log_low_water_mark)) */
ma_message_no_user(0, "log purging failed"); if (translog_purge(log_low_water_mark))
ma_message_no_user(0, "log purging failed");
}
goto end; goto end;
...@@ -758,9 +760,11 @@ static int collect_tables(LEX_STRING *str, LSN checkpoint_start_log_horizon) ...@@ -758,9 +760,11 @@ static int collect_tables(LEX_STRING *str, LSN checkpoint_start_log_horizon)
*state_copies_end, /**< cache ends here */ *state_copies_end, /**< cache ends here */
*state_copy; /**< iterator in cache */ *state_copy; /**< iterator in cache */
TRANSLOG_ADDRESS state_copies_horizon; /**< horizon of states' _copies_ */ TRANSLOG_ADDRESS state_copies_horizon; /**< horizon of states' _copies_ */
LINT_INIT(state_copies_horizon); struct st_filter_param filter_param;
PAGECACHE_FLUSH_FILTER filter;
DBUG_ENTER("collect_tables"); DBUG_ENTER("collect_tables");
LINT_INIT(state_copies_horizon);
/* let's make a list of distinct shares */ /* let's make a list of distinct shares */
pthread_mutex_lock(&THR_LOCK_maria); pthread_mutex_lock(&THR_LOCK_maria);
for (nb= 0, pos= maria_open_list; pos; pos= pos->next) for (nb= 0, pos= maria_open_list; pos; pos= pos->next)
...@@ -831,10 +835,8 @@ static int collect_tables(LEX_STRING *str, LSN checkpoint_start_log_horizon) ...@@ -831,10 +835,8 @@ static int collect_tables(LEX_STRING *str, LSN checkpoint_start_log_horizon)
ptr= str->str; ptr= str->str;
ptr+= 4; /* real number of stored tables is not yet know */ ptr+= 4; /* real number of stored tables is not yet know */
struct st_filter_param filter_param;
/* only possible checkpointer, so can do the read below without mutex */ /* only possible checkpointer, so can do the read below without mutex */
filter_param.up_to_lsn= last_checkpoint_lsn; filter_param.up_to_lsn= last_checkpoint_lsn;
PAGECACHE_FLUSH_FILTER filter;
switch(checkpoint_in_progress) switch(checkpoint_in_progress)
{ {
case CHECKPOINT_MEDIUM: case CHECKPOINT_MEDIUM:
......
...@@ -4219,6 +4219,10 @@ my_bool pagecache_collect_changed_blocks_with_lsn(PAGECACHE *pagecache, ...@@ -4219,6 +4219,10 @@ my_bool pagecache_collect_changed_blocks_with_lsn(PAGECACHE *pagecache,
continue; /* no need to store it in the checkpoint record */ continue; /* no need to store it in the checkpoint record */
compile_time_assert(sizeof(block->hash_link->file.file) <= 4); compile_time_assert(sizeof(block->hash_link->file.file) <= 4);
compile_time_assert(sizeof(block->hash_link->pageno) <= 4); compile_time_assert(sizeof(block->hash_link->pageno) <= 4);
/**
@todo RECOVERY when we have a pointer to MARIA_SHARE, store share->id
instead of this file.
*/
int4store(ptr, block->hash_link->file.file); int4store(ptr, block->hash_link->file.file);
ptr+= 4; ptr+= 4;
int4store(ptr, block->hash_link->pageno); int4store(ptr, block->hash_link->pageno);
......
...@@ -133,7 +133,11 @@ static my_bool close_one_table(const char *name, TRANSLOG_ADDRESS addr); ...@@ -133,7 +133,11 @@ static my_bool close_one_table(const char *name, TRANSLOG_ADDRESS addr);
static void print_redo_phase_progress(TRANSLOG_ADDRESS addr); static void print_redo_phase_progress(TRANSLOG_ADDRESS addr);
/** @brief global [out] buffer for translog_read_record(); never shrinks */ /** @brief global [out] buffer for translog_read_record(); never shrinks */
static LEX_STRING log_record_buffer; static struct
{
uchar *str;
size_t length;
} log_record_buffer;
static void enlarge_buffer(const TRANSLOG_HEADER_BUFFER *rec) static void enlarge_buffer(const TRANSLOG_HEADER_BUFFER *rec)
{ {
if (log_record_buffer.length < rec->record_length) if (log_record_buffer.length < rec->record_length)
...@@ -590,8 +594,9 @@ prototype_redo_exec_hook(INCOMPLETE_LOG) ...@@ -590,8 +594,9 @@ prototype_redo_exec_hook(INCOMPLETE_LOG)
prototype_redo_exec_hook(REDO_CREATE_TABLE) prototype_redo_exec_hook(REDO_CREATE_TABLE)
{ {
File dfile= -1, kfile= -1; File dfile= -1, kfile= -1;
char *linkname_ptr, filename[FN_REFLEN]; char *linkname_ptr, filename[FN_REFLEN], *name, *ptr, *data_file_name,
char *name, *ptr; *index_file_name;
uchar *kfile_header;
myf create_flag; myf create_flag;
uint flags; uint flags;
int error= 1, create_mode= O_RDWR | O_TRUNC; int error= 1, create_mode= O_RDWR | O_TRUNC;
...@@ -612,7 +617,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE) ...@@ -612,7 +617,7 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
eprint(tracef, "Failed to read record\n"); eprint(tracef, "Failed to read record\n");
goto end; goto end;
} }
name= log_record_buffer.str; name= (char *)log_record_buffer.str;
/* /*
TRUNCATE TABLE and REPAIR USE_FRM call maria_create(), so below we can TRUNCATE TABLE and REPAIR USE_FRM call maria_create(), so below we can
find a REDO_CREATE_TABLE for a table which we have open, that's why we find a REDO_CREATE_TABLE for a table which we have open, that's why we
...@@ -680,16 +685,16 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE) ...@@ -680,16 +685,16 @@ prototype_redo_exec_hook(REDO_CREATE_TABLE)
ptr+= 2; ptr+= 2;
keystart= uint2korr(ptr); keystart= uint2korr(ptr);
ptr+= 2; ptr+= 2;
uchar *kfile_header= ptr; kfile_header= (uchar *)ptr;
ptr+= kfile_size_before_extension; ptr+= kfile_size_before_extension;
/* set create_rename_lsn (for maria_read_log to be idempotent) */ /* set create_rename_lsn (for maria_read_log to be idempotent) */
lsn_store(kfile_header + sizeof(info->s->state.header) + 2, rec->lsn); lsn_store(kfile_header + sizeof(info->s->state.header) + 2, rec->lsn);
/* we also set is_of_horizon, like maria_create() does */ /* we also set is_of_horizon, like maria_create() does */
lsn_store(kfile_header + sizeof(info->s->state.header) + 2 + LSN_STORE_SIZE, lsn_store(kfile_header + sizeof(info->s->state.header) + 2 + LSN_STORE_SIZE,
rec->lsn); rec->lsn);
uchar *data_file_name= ptr; data_file_name= ptr;
ptr+= strlen(data_file_name) + 1; ptr+= strlen(data_file_name) + 1;
uchar *index_file_name= ptr; index_file_name= ptr;
ptr+= strlen(index_file_name) + 1; ptr+= strlen(index_file_name) + 1;
/** @todo handle symlinks */ /** @todo handle symlinks */
if (data_file_name[0] || index_file_name[0]) if (data_file_name[0] || index_file_name[0])
...@@ -775,7 +780,7 @@ prototype_redo_exec_hook(REDO_RENAME_TABLE) ...@@ -775,7 +780,7 @@ prototype_redo_exec_hook(REDO_RENAME_TABLE)
eprint(tracef, "Failed to read record\n"); eprint(tracef, "Failed to read record\n");
goto end; goto end;
} }
old_name= log_record_buffer.str; old_name= (char *)log_record_buffer.str;
new_name= old_name + strlen(old_name) + 1; new_name= old_name + strlen(old_name) + 1;
tprint(tracef, "Table '%s' to rename to '%s'; old-name table ", old_name, tprint(tracef, "Table '%s' to rename to '%s'; old-name table ", old_name,
new_name); new_name);
...@@ -1023,7 +1028,7 @@ prototype_redo_exec_hook(REDO_DROP_TABLE) ...@@ -1023,7 +1028,7 @@ prototype_redo_exec_hook(REDO_DROP_TABLE)
eprint(tracef, "Failed to read record\n"); eprint(tracef, "Failed to read record\n");
return 1; return 1;
} }
name= log_record_buffer.str; name= (char *)log_record_buffer.str;
tprint(tracef, "Table '%s'", name); tprint(tracef, "Table '%s'", name);
info= maria_open(name, O_RDONLY, HA_OPEN_FOR_REPAIR); info= maria_open(name, O_RDONLY, HA_OPEN_FOR_REPAIR);
if (info) if (info)
...@@ -1115,7 +1120,7 @@ prototype_redo_exec_hook(FILE_ID) ...@@ -1115,7 +1120,7 @@ prototype_redo_exec_hook(FILE_ID)
} }
all_tables[sid].info= NULL; all_tables[sid].info= NULL;
} }
name= log_record_buffer.str + FILEID_STORE_SIZE; name= (char *)log_record_buffer.str + FILEID_STORE_SIZE;
if (new_table(sid, name, -1, -1, rec->lsn)) if (new_table(sid, name, -1, -1, rec->lsn))
goto end; goto end;
error= 0; error= 0;
...@@ -1136,6 +1141,7 @@ static int new_table(uint16 sid, const char *name, ...@@ -1136,6 +1141,7 @@ static int new_table(uint16 sid, const char *name,
int error= 1; int error= 1;
MARIA_HA *info; MARIA_HA *info;
MARIA_SHARE *share; MARIA_SHARE *share;
my_off_t dfile_len, kfile_len;
checkpoint_useful= TRUE; checkpoint_useful= TRUE;
if ((name == NULL) || (name[0] == 0)) if ((name == NULL) || (name[0] == 0))
...@@ -1198,8 +1204,8 @@ static int new_table(uint16 sid, const char *name, ...@@ -1198,8 +1204,8 @@ static int new_table(uint16 sid, const char *name,
/* _ma_unpin_all_pages() reads info->trn: */ /* _ma_unpin_all_pages() reads info->trn: */
info->trn= &dummy_transaction_object; info->trn= &dummy_transaction_object;
/* execution of some REDO records relies on data_file_length */ /* execution of some REDO records relies on data_file_length */
my_off_t dfile_len= my_seek(info->dfile.file, 0, SEEK_END, MYF(MY_WME)); dfile_len= my_seek(info->dfile.file, 0, SEEK_END, MYF(MY_WME));
my_off_t kfile_len= my_seek(info->s->kfile.file, 0, SEEK_END, MYF(MY_WME)); kfile_len= my_seek(info->s->kfile.file, 0, SEEK_END, MYF(MY_WME));
if ((dfile_len == MY_FILEPOS_ERROR) || if ((dfile_len == MY_FILEPOS_ERROR) ||
(kfile_len == MY_FILEPOS_ERROR)) (kfile_len == MY_FILEPOS_ERROR))
{ {
...@@ -2443,12 +2449,13 @@ static int run_undo_phase(uint uncommitted) ...@@ -2443,12 +2449,13 @@ static int run_undo_phase(uint uncommitted)
tprint(tracef, "%u transactions will be rolled back\n", uncommitted); tprint(tracef, "%u transactions will be rolled back\n", uncommitted);
for( ; ; ) for( ; ; )
{ {
char llbuf[22];
TRN *trn;
if (recovery_message_printed == REC_MSG_UNDO) if (recovery_message_printed == REC_MSG_UNDO)
fprintf(stderr, " %u", uncommitted); fprintf(stderr, " %u", uncommitted);
if ((uncommitted--) == 0) if ((uncommitted--) == 0)
break; break;
char llbuf[22]; trn= trnman_get_any_trn();
TRN *trn= trnman_get_any_trn();
DBUG_ASSERT(trn != NULL); DBUG_ASSERT(trn != NULL);
llstr(trn->trid, llbuf); llstr(trn->trid, llbuf);
tprint(tracef, "Rolling back transaction of long id %s\n", llbuf); tprint(tracef, "Rolling back transaction of long id %s\n", llbuf);
...@@ -2644,15 +2651,18 @@ static MARIA_HA *get_MARIA_HA_from_UNDO_record(const ...@@ -2644,15 +2651,18 @@ static MARIA_HA *get_MARIA_HA_from_UNDO_record(const
static LSN parse_checkpoint_record(LSN lsn) static LSN parse_checkpoint_record(LSN lsn)
{ {
ulong i; ulong i, nb_dirty_pages;
TRANSLOG_HEADER_BUFFER rec; TRANSLOG_HEADER_BUFFER rec;
TRANSLOG_ADDRESS start_address; TRANSLOG_ADDRESS start_address;
int len;
uint nb_active_transactions, nb_committed_transactions, nb_tables;
uchar *ptr;
LSN minimum_rec_lsn_of_active_transactions, minimum_rec_lsn_of_dirty_pages;
struct st_dirty_page *next_dirty_page_in_pool;
tprint(tracef, "Loading data from checkpoint record at LSN (%lu,0x%lx)\n", tprint(tracef, "Loading data from checkpoint record at LSN (%lu,0x%lx)\n",
LSN_IN_PARTS(lsn)); LSN_IN_PARTS(lsn));
int len= translog_read_record_header(lsn, &rec); if ((len= translog_read_record_header(lsn, &rec)) == RECHEADER_READ_ERROR)
if (len == RECHEADER_READ_ERROR)
{ {
tprint(tracef, "Cannot find checkpoint record where it should be\n"); tprint(tracef, "Cannot find checkpoint record where it should be\n");
return LSN_ERROR; return LSN_ERROR;
...@@ -2668,15 +2678,15 @@ static LSN parse_checkpoint_record(LSN lsn) ...@@ -2668,15 +2678,15 @@ static LSN parse_checkpoint_record(LSN lsn)
return LSN_ERROR; return LSN_ERROR;
} }
char *ptr= log_record_buffer.str; ptr= log_record_buffer.str;
start_address= lsn_korr(ptr); start_address= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
/* transactions */ /* transactions */
uint nb_active_transactions= uint2korr(ptr); nb_active_transactions= uint2korr(ptr);
ptr+= 2; ptr+= 2;
tprint(tracef, "%u active transactions\n", nb_active_transactions); tprint(tracef, "%u active transactions\n", nb_active_transactions);
LSN minimum_rec_lsn_of_active_transactions= lsn_korr(ptr); minimum_rec_lsn_of_active_transactions= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
max_long_trid= transid_korr(ptr); max_long_trid= transid_korr(ptr);
ptr+= TRANSID_SIZE; ptr+= TRANSID_SIZE;
...@@ -2690,17 +2700,19 @@ static LSN parse_checkpoint_record(LSN lsn) ...@@ -2690,17 +2700,19 @@ static LSN parse_checkpoint_record(LSN lsn)
for (i= 0; i < nb_active_transactions; i++) for (i= 0; i < nb_active_transactions; i++)
{ {
uint16 sid= uint2korr(ptr); uint16 sid= uint2korr(ptr);
TrID long_id;
LSN undo_lsn, first_undo_lsn;
ptr+= 2; ptr+= 2;
TrID long_id= uint6korr(ptr); long_id= uint6korr(ptr);
ptr+= 6; ptr+= 6;
DBUG_ASSERT(sid > 0 && long_id > 0); DBUG_ASSERT(sid > 0 && long_id > 0);
LSN undo_lsn= lsn_korr(ptr); undo_lsn= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
LSN first_undo_lsn= lsn_korr(ptr); first_undo_lsn= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
new_transaction(sid, long_id, undo_lsn, first_undo_lsn); new_transaction(sid, long_id, undo_lsn, first_undo_lsn);
} }
uint nb_committed_transactions= uint4korr(ptr); nb_committed_transactions= uint4korr(ptr);
ptr+= 4; ptr+= 4;
tprint(tracef, "%lu committed transactions\n", tprint(tracef, "%lu committed transactions\n",
(ulong)nb_committed_transactions); (ulong)nb_committed_transactions);
...@@ -2708,30 +2720,33 @@ static LSN parse_checkpoint_record(LSN lsn) ...@@ -2708,30 +2720,33 @@ static LSN parse_checkpoint_record(LSN lsn)
ptr+= (6 + LSN_STORE_SIZE) * nb_committed_transactions; ptr+= (6 + LSN_STORE_SIZE) * nb_committed_transactions;
/* tables */ /* tables */
uint nb_tables= uint4korr(ptr); nb_tables= uint4korr(ptr);
ptr+= 4; ptr+= 4;
tprint(tracef, "%u open tables\n", nb_tables); tprint(tracef, "%u open tables\n", nb_tables);
for (i= 0; i< nb_tables; i++) for (i= 0; i< nb_tables; i++)
{ {
char name[FN_REFLEN]; char name[FN_REFLEN];
File kfile, dfile;
LSN first_log_write_lsn;
uint name_len;
uint16 sid= uint2korr(ptr); uint16 sid= uint2korr(ptr);
ptr+= 2; ptr+= 2;
DBUG_ASSERT(sid > 0); DBUG_ASSERT(sid > 0);
File kfile= uint4korr(ptr); kfile= uint4korr(ptr);
ptr+= 4; ptr+= 4;
File dfile= uint4korr(ptr); dfile= uint4korr(ptr);
ptr+= 4; ptr+= 4;
LSN first_log_write_lsn= lsn_korr(ptr); first_log_write_lsn= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
uint name_len= strlen(ptr) + 1; name_len= strlen((char *)ptr) + 1;
strmake(name, ptr, sizeof(name)-1); strmake(name, (char *)ptr, sizeof(name)-1);
ptr+= name_len; ptr+= name_len;
if (new_table(sid, name, kfile, dfile, first_log_write_lsn)) if (new_table(sid, name, kfile, dfile, first_log_write_lsn))
return LSN_ERROR; return LSN_ERROR;
} }
/* dirty pages */ /* dirty pages */
ulong nb_dirty_pages= uint8korr(ptr); nb_dirty_pages= uint8korr(ptr);
ptr+= 8; ptr+= 8;
tprint(tracef, "%lu dirty pages\n", nb_dirty_pages); tprint(tracef, "%lu dirty pages\n", nb_dirty_pages);
if (hash_init(&all_dirty_pages, &my_charset_bin, nb_dirty_pages, if (hash_init(&all_dirty_pages, &my_charset_bin, nb_dirty_pages,
...@@ -2745,15 +2760,17 @@ static LSN parse_checkpoint_record(LSN lsn) ...@@ -2745,15 +2760,17 @@ static LSN parse_checkpoint_record(LSN lsn)
MYF(MY_WME)); MYF(MY_WME));
if (unlikely(dirty_pages_pool == NULL)) if (unlikely(dirty_pages_pool == NULL))
return LSN_ERROR; return LSN_ERROR;
struct st_dirty_page *next_dirty_page_in_pool= dirty_pages_pool; next_dirty_page_in_pool= dirty_pages_pool;
LSN minimum_rec_lsn_of_dirty_pages= LSN_MAX; minimum_rec_lsn_of_dirty_pages= LSN_MAX;
for (i= 0; i < nb_dirty_pages ; i++) for (i= 0; i < nb_dirty_pages ; i++)
{ {
pgcache_page_no_t pageid;
LSN rec_lsn;
File fileid= uint4korr(ptr); File fileid= uint4korr(ptr);
ptr+= 4; ptr+= 4;
pgcache_page_no_t pageid= uint4korr(ptr); pageid= uint4korr(ptr);
ptr+= 4; ptr+= 4;
LSN rec_lsn= lsn_korr(ptr); rec_lsn= lsn_korr(ptr);
ptr+= LSN_STORE_SIZE; ptr+= LSN_STORE_SIZE;
if (new_page(fileid, pageid, rec_lsn, next_dirty_page_in_pool++)) if (new_page(fileid, pageid, rec_lsn, next_dirty_page_in_pool++))
return LSN_ERROR; return LSN_ERROR;
...@@ -2803,6 +2820,7 @@ static int close_all_tables(void) ...@@ -2803,6 +2820,7 @@ static int close_all_tables(void)
uint count= 0; uint count= 0;
LIST *list_element, *next_open; LIST *list_element, *next_open;
MARIA_HA *info; MARIA_HA *info;
TRANSLOG_ADDRESS addr;
pthread_mutex_lock(&THR_LOCK_maria); pthread_mutex_lock(&THR_LOCK_maria);
if (maria_open_list == NULL) if (maria_open_list == NULL)
goto end; goto end;
...@@ -2821,7 +2839,7 @@ static int close_all_tables(void) ...@@ -2821,7 +2839,7 @@ static int close_all_tables(void)
(if UNDO phase ran) and thus the state is newer than at (if UNDO phase ran) and thus the state is newer than at
end_of_redo_phase(), we need to bump is_of_horizon again. end_of_redo_phase(), we need to bump is_of_horizon again.
*/ */
TRANSLOG_ADDRESS addr= translog_get_horizon(); addr= translog_get_horizon();
for (list_element= maria_open_list ; ; list_element= next_open) for (list_element= maria_open_list ; ; list_element= next_open)
{ {
if (recovery_message_printed == REC_MSG_FLUSH) if (recovery_message_printed == REC_MSG_FLUSH)
......
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