Commit df843c4c authored by unknown's avatar unknown

Fixed problems with ma_test2 and mi_test2 on high-byte-first system

Fixed bug in ma_test2 when last row in table is deleted
Fixed that ma_test_recovery.pl works on Solaris (by using digest instead of md5sum)
Fixed some compiler warnings generated by the Forte compiler


dbug/dbug.c:
  Added cast to get rid of compiler warning
mysys/lf_alloc-pin.c:
  Added cast to get rid of compiler warning
mysys/my_bitmap.c:
  Removed impossible DBUG_ASSERT()'s to get rid of compiler warnings
mysys/my_compress.c:
  Removed wrong cast to get rid of compiler warning
storage/maria/lockman.c:
  Added cast to get rid of compiler warning
storage/maria/ma_open.c:
  Added fix from MyISAM to allocate space in key buffer for nod pointer
storage/maria/ma_recovery.c:
  Fixed initialization that caused compiler warning
storage/maria/ma_rsame.c:
  More DBUG_PRINT
storage/maria/ma_scan.c:
  Better comment
storage/maria/ma_statrec.c:
  More DBUG_PRINT and comments
  Fixed indentation
BitKeeper/etc/ignore:
  added storage/maria/unittest/tmp/*
storage/maria/ma_test2.c:
  Fixed bug that caused maria_rsame() to fail if test removed last row
  Fixed wrong usage of longget();  Should be uint4korr()
storage/maria/unittest/ma_test_recovery.pl:
  Use md5sum or digest to calculate md5.
  This allows this script to be run on Linux and Solaris
storage/myisam/mi_test2.c:
  Fixed wrong usage of longget();  Should be uint4korr()
strings/ctype.c:
  Added casts to get rid of compiler warnings
sql-bench/myisam.cnf:
  New BitKeeper file ``sql-bench/myisam.cnf''
parent 8bb95a82
...@@ -3077,3 +3077,4 @@ maria_log.00000* ...@@ -3077,3 +3077,4 @@ maria_log.00000*
ma_test_recovery.output ma_test_recovery.output
test?.MA? test?.MA?
dbug/tests dbug/tests
storage/maria/unittest/tmp/*
...@@ -124,7 +124,7 @@ ...@@ -124,7 +124,7 @@
#define SANITY_CHECK_ON (1 << 10) /* Check safemalloc on DBUG_ENTER */ #define SANITY_CHECK_ON (1 << 10) /* Check safemalloc on DBUG_ENTER */
#define FLUSH_ON_WRITE (1 << 11) /* Flush on every write */ #define FLUSH_ON_WRITE (1 << 11) /* Flush on every write */
#define OPEN_APPEND (1 << 12) /* Open for append */ #define OPEN_APPEND (1 << 12) /* Open for append */
#define TRACE_ON (1 << 31) /* Trace enabled. MUST be the highest bit!*/ #define TRACE_ON ((uint)1 << 31) /* Trace enabled. MUST be the highest bit!*/
#define TRACING (cs->stack->flags & TRACE_ON) #define TRACING (cs->stack->flags & TRACE_ON)
#define DEBUGGING (cs->stack->flags & DEBUG_ON) #define DEBUGGING (cs->stack->flags & DEBUG_ON)
......
...@@ -169,7 +169,7 @@ LF_PINS *_lf_pinbox_get_pins(LF_PINBOX *pinbox, void *stack_end) ...@@ -169,7 +169,7 @@ LF_PINS *_lf_pinbox_get_pins(LF_PINBOX *pinbox, void *stack_end)
if (!(pins= top_ver % LF_PINBOX_MAX_PINS)) if (!(pins= top_ver % LF_PINBOX_MAX_PINS))
{ {
/* the stack of free elements is empty */ /* the stack of free elements is empty */
pins= my_atomic_add32(&pinbox->pins_in_array, 1)+1; pins= my_atomic_add32((int32 volatile*) &pinbox->pins_in_array, 1)+1;
if (unlikely(pins >= LF_PINBOX_MAX_PINS)) if (unlikely(pins >= LF_PINBOX_MAX_PINS))
return 0; return 0;
/* /*
...@@ -183,7 +183,8 @@ LF_PINS *_lf_pinbox_get_pins(LF_PINBOX *pinbox, void *stack_end) ...@@ -183,7 +183,8 @@ LF_PINS *_lf_pinbox_get_pins(LF_PINBOX *pinbox, void *stack_end)
} }
el= (LF_PINS *)_lf_dynarray_value(&pinbox->pinarray, pins); el= (LF_PINS *)_lf_dynarray_value(&pinbox->pinarray, pins);
next= el->link; next= el->link;
} while (!my_atomic_cas32(&pinbox->pinstack_top_ver, &top_ver, } while (!my_atomic_cas32((int32 volatile*) &pinbox->pinstack_top_ver,
(int32*) &top_ver,
top_ver-pins+next+LF_PINBOX_MAX_PINS)); top_ver-pins+next+LF_PINBOX_MAX_PINS));
/* /*
set el->link to the index of el in the dynarray (el->link has two usages: set el->link to the index of el in the dynarray (el->link has two usages:
...@@ -237,7 +238,8 @@ void _lf_pinbox_put_pins(LF_PINS *pins) ...@@ -237,7 +238,8 @@ void _lf_pinbox_put_pins(LF_PINS *pins)
do do
{ {
pins->link= top_ver % LF_PINBOX_MAX_PINS; pins->link= top_ver % LF_PINBOX_MAX_PINS;
} while (!my_atomic_cas32(&pinbox->pinstack_top_ver, &top_ver, } while (!my_atomic_cas32((int32 volatile*) &pinbox->pinstack_top_ver,
(int32*) &top_ver,
top_ver-pins->link+nr+LF_PINBOX_MAX_PINS)); top_ver-pins->link+nr+LF_PINBOX_MAX_PINS));
return; return;
} }
......
...@@ -508,10 +508,8 @@ uint bitmap_get_first_set(const MY_BITMAP *map) ...@@ -508,10 +508,8 @@ uint bitmap_get_first_set(const MY_BITMAP *map)
if (*byte_ptr & (1 << k)) if (*byte_ptr & (1 << k))
return (i*32) + (j*8) + k; return (i*32) + (j*8) + k;
} }
DBUG_ASSERT(0);
} }
} }
DBUG_ASSERT(0);
} }
} }
return MY_BIT_NONE; return MY_BIT_NONE;
...@@ -542,10 +540,8 @@ uint bitmap_get_first(const MY_BITMAP *map) ...@@ -542,10 +540,8 @@ uint bitmap_get_first(const MY_BITMAP *map)
if (!(*byte_ptr & (1 << k))) if (!(*byte_ptr & (1 << k)))
return (i*32) + (j*8) + k; return (i*32) + (j*8) + k;
} }
DBUG_ASSERT(0);
} }
} }
DBUG_ASSERT(0);
} }
} }
return MY_BIT_NONE; return MY_BIT_NONE;
......
...@@ -183,7 +183,7 @@ int packfrm(uchar *data, size_t len, ...@@ -183,7 +183,7 @@ int packfrm(uchar *data, size_t len,
DBUG_PRINT("info", ("org_len: %lu comp_len: %lu", (ulong) org_len, DBUG_PRINT("info", ("org_len: %lu comp_len: %lu", (ulong) org_len,
(ulong) comp_len)); (ulong) comp_len));
DBUG_DUMP("compressed", (char*)data, org_len); DBUG_DUMP("compressed", data, org_len);
error= 2; error= 2;
blob_len= BLOB_HEADER + org_len; blob_len= BLOB_HEADER + org_len;
......
[mysqld]
data=/data
key_buffer_size=256M
...@@ -631,7 +631,7 @@ enum lockman_getlock_result lockman_getlock(LOCKMAN *lm, LOCK_OWNER *lo, ...@@ -631,7 +631,7 @@ enum lockman_getlock_result lockman_getlock(LOCKMAN *lm, LOCK_OWNER *lo,
/* a new value was added to the hash */ /* a new value was added to the hash */
csize= lm->size; csize= lm->size;
if ((my_atomic_add32(&lm->count, 1)+1.0) / csize > MAX_LOAD) if ((my_atomic_add32(&lm->count, 1)+1.0) / csize > MAX_LOAD)
my_atomic_cas32(&lm->size, &csize, csize*2); my_atomic_cas32(&lm->size, (int*) &csize, csize*2);
node->lonext= lo->all_locks; node->lonext= lo->all_locks;
lo->all_locks= node; lo->all_locks= node;
for ( ; res & NEED_TO_WAIT; res= lockpeek(el, node, pins, &blocker)) for ( ; res & NEED_TO_WAIT; res= lockpeek(el, node, pins, &blocker))
......
...@@ -460,6 +460,8 @@ MARIA_HA *maria_open(const char *name, int mode, uint open_flags) ...@@ -460,6 +460,8 @@ MARIA_HA *maria_open(const char *name, int mode, uint open_flags)
if (share->options & HA_OPTION_COMPRESS_RECORD) if (share->options & HA_OPTION_COMPRESS_RECORD)
share->base.max_key_length+=2; /* For safety */ share->base.max_key_length+=2; /* For safety */
/* Add space for node pointer */
share->base.max_key_length+= share->base.key_reflength;
if (!my_multi_malloc(MY_WME, if (!my_multi_malloc(MY_WME,
&share,sizeof(*share), &share,sizeof(*share),
......
...@@ -3265,7 +3265,7 @@ static void print_redo_phase_progress(TRANSLOG_ADDRESS addr) ...@@ -3265,7 +3265,7 @@ static void print_redo_phase_progress(TRANSLOG_ADDRESS addr)
{ {
static uint end_logno= FILENO_IMPOSSIBLE, percentage_printed= 0; static uint end_logno= FILENO_IMPOSSIBLE, percentage_printed= 0;
static ulong end_offset; static ulong end_offset;
static ulonglong initial_remainder= -1; static ulonglong initial_remainder= ~(ulonglong) 0;
uint cur_logno; uint cur_logno;
ulong cur_offset; ulong cur_offset;
......
...@@ -34,11 +34,13 @@ int maria_rsame(MARIA_HA *info, uchar *record, int inx) ...@@ -34,11 +34,13 @@ int maria_rsame(MARIA_HA *info, uchar *record, int inx)
if (inx != -1 && ! maria_is_key_active(info->s->state.key_map, inx)) if (inx != -1 && ! maria_is_key_active(info->s->state.key_map, inx))
{ {
DBUG_PRINT("error", ("wrong index usage"));
DBUG_RETURN(my_errno=HA_ERR_WRONG_INDEX); DBUG_RETURN(my_errno=HA_ERR_WRONG_INDEX);
} }
if (info->cur_row.lastpos == HA_OFFSET_ERROR || if (info->cur_row.lastpos == HA_OFFSET_ERROR ||
info->update & HA_STATE_DELETED) info->update & HA_STATE_DELETED)
{ {
DBUG_PRINT("error", ("no current record"));
DBUG_RETURN(my_errno=HA_ERR_KEY_NOT_FOUND); /* No current record */ DBUG_RETURN(my_errno=HA_ERR_KEY_NOT_FOUND); /* No current record */
} }
info->update&= (HA_STATE_CHANGED | HA_STATE_ROW_CHANGED); info->update&= (HA_STATE_CHANGED | HA_STATE_ROW_CHANGED);
...@@ -65,5 +67,6 @@ int maria_rsame(MARIA_HA *info, uchar *record, int inx) ...@@ -65,5 +67,6 @@ int maria_rsame(MARIA_HA *info, uchar *record, int inx)
DBUG_RETURN(0); DBUG_RETURN(0);
if (my_errno == HA_ERR_RECORD_DELETED) if (my_errno == HA_ERR_RECORD_DELETED)
my_errno=HA_ERR_KEY_NOT_FOUND; my_errno=HA_ERR_KEY_NOT_FOUND;
DBUG_PRINT("error", ("my_errno: %d", my_errno));
DBUG_RETURN(my_errno); DBUG_RETURN(my_errno);
} /* maria_rsame */ } /* maria_rsame */
...@@ -42,6 +42,7 @@ int maria_scan_init(register MARIA_HA *info) ...@@ -42,6 +42,7 @@ int maria_scan_init(register MARIA_HA *info)
RETURN RETURN
0 ok 0 ok
HA_ERR_END_OF_FILE End of file HA_ERR_END_OF_FILE End of file
HA_ERR_RECORD_DELETED Record was deleted (can only happen for static rec)
# Error code # Error code
*/ */
......
...@@ -173,13 +173,14 @@ int _ma_read_static_record(register MARIA_HA *info, register uchar *record, ...@@ -173,13 +173,14 @@ int _ma_read_static_record(register MARIA_HA *info, register uchar *record,
MARIA_RECORD_POS pos) MARIA_RECORD_POS pos)
{ {
int error; int error;
DBUG_ENTER("_ma_read_static_record");
if (pos != HA_OFFSET_ERROR) if (pos != HA_OFFSET_ERROR)
{ {
if (info->opt_flag & WRITE_CACHE_USED && if (info->opt_flag & WRITE_CACHE_USED &&
info->rec_cache.pos_in_file <= pos && info->rec_cache.pos_in_file <= pos &&
flush_io_cache(&info->rec_cache)) flush_io_cache(&info->rec_cache))
return(my_errno); DBUG_RETURN(my_errno);
info->rec_cache.seek_not_done=1; /* We have done a seek */ info->rec_cache.seek_not_done=1; /* We have done a seek */
error= (int) info->s->file_read(info, record,info->s->base.reclength, error= (int) info->s->file_read(info, record,info->s->base.reclength,
...@@ -190,17 +191,27 @@ int _ma_read_static_record(register MARIA_HA *info, register uchar *record, ...@@ -190,17 +191,27 @@ int _ma_read_static_record(register MARIA_HA *info, register uchar *record,
if (!*record) if (!*record)
{ {
/* Record is deleted */ /* Record is deleted */
return ((my_errno=HA_ERR_RECORD_DELETED)); DBUG_PRINT("warning", ("Record is deleted"));
DBUG_RETURN((my_errno=HA_ERR_RECORD_DELETED));
} }
info->update|= HA_STATE_AKTIV; /* Record is read */ info->update|= HA_STATE_AKTIV; /* Record is read */
return(0); DBUG_RETURN(0);
} }
} }
fast_ma_writeinfo(info); /* No such record */ fast_ma_writeinfo(info); /* No such record */
return(my_errno); DBUG_RETURN(my_errno);
} }
/**
@brief Read record from given position or next record
@note
When scanning, this function will return HA_ERR_RECORD_DELETED
for deleted rows even if skip_deleted_blocks is set.
The reason for this is to allow the caller to calculate the record
position without having to do call maria_position() for each record.
*/
int _ma_read_rnd_static_record(MARIA_HA *info, uchar *buf, int _ma_read_rnd_static_record(MARIA_HA *info, uchar *buf,
MARIA_RECORD_POS filepos, MARIA_RECORD_POS filepos,
...@@ -219,7 +230,8 @@ int _ma_read_rnd_static_record(MARIA_HA *info, uchar *buf, ...@@ -219,7 +230,8 @@ int _ma_read_rnd_static_record(MARIA_HA *info, uchar *buf,
(skip_deleted_blocks || !filepos)) (skip_deleted_blocks || !filepos))
{ {
cache_read=1; /* Read record using cache */ cache_read=1; /* Read record using cache */
cache_length=(uint) (info->rec_cache.read_end - info->rec_cache.read_pos); cache_length= (uint) (info->rec_cache.read_end -
info->rec_cache.read_pos);
} }
else else
info->rec_cache.seek_not_done=1; /* Filepos is changed */ info->rec_cache.seek_not_done=1; /* Filepos is changed */
......
...@@ -660,6 +660,12 @@ int main(int argc, char *argv[]) ...@@ -660,6 +660,12 @@ int main(int argc, char *argv[])
printf("Got error %d when scanning table\n", tmp); printf("Got error %d when scanning table\n", tmp);
break; break;
} }
if (!tmp)
{
/* Remember position to last found row */
info.recpos= maria_position(file);
bmove(read_record2,read_record,reclength);
}
} }
maria_scan_end(file); maria_scan_end(file);
if (i != write_count && i != write_count - opt_delete) if (i != write_count && i != write_count - opt_delete)
...@@ -668,7 +674,14 @@ int main(int argc, char *argv[]) ...@@ -668,7 +674,14 @@ int main(int argc, char *argv[])
goto err; goto err;
} }
bmove(read_record2,read_record,reclength); if (maria_rsame_with_pos(file,read_record,0,info.recpos))
goto err;
if (bcmp(read_record,read_record2,reclength) != 0)
{
printf("maria_rsame_with_pos didn't find same record\n");
goto err;
}
for (i=min(2,keys) ; i-- > 0 ;) for (i=min(2,keys) ; i-- > 0 ;)
{ {
if (maria_rsame(file,read_record2,(int) i)) goto err; if (maria_rsame(file,read_record2,(int) i)) goto err;
...@@ -860,7 +873,7 @@ int main(int argc, char *argv[]) ...@@ -860,7 +873,7 @@ int main(int argc, char *argv[])
ulong blob_length,pos; ulong blob_length,pos;
uchar *ptr; uchar *ptr;
memcpy_fixed(&ptr, read_record+blob_pos+4, sizeof(ptr)); memcpy_fixed(&ptr, read_record+blob_pos+4, sizeof(ptr));
longget(blob_length,read_record+blob_pos); blob_length= uint4korr(read_record+blob_pos);
for (pos=0 ; pos < blob_length ; pos++) for (pos=0 ; pos < blob_length ; pos++)
{ {
if (ptr[pos] != (uchar) (blob_length+pos)) if (ptr[pos] != (uchar) (blob_length+pos))
......
...@@ -8,6 +8,7 @@ my $silent= "-s"; ...@@ -8,6 +8,7 @@ my $silent= "-s";
my $tmp= "./tmp"; my $tmp= "./tmp";
my $maria_path; # path to "storage/maria" my $maria_path; # path to "storage/maria"
my $maria_exe_path; # path to executables (ma_test1, maria_chk etc) my $maria_exe_path; # path to executables (ma_test1, maria_chk etc)
my $md5sum;
$maria_path= dirname($0) . "/.."; $maria_path= dirname($0) . "/..";
...@@ -31,6 +32,20 @@ if ( ! -f "$maria_exe_path/ma_test1$suffix" ) ...@@ -31,6 +32,20 @@ if ( ! -f "$maria_exe_path/ma_test1$suffix" )
} }
} }
# Test if we should use md5sum or digest -a md5
if (defined(my_which("md5sum")))
{
$md5sum="md5sum";
}
elsif (defined(my_which("digest")))
{
$md5sum="digest -a md5";
}
else
{
die "Can't find either md5sum or digest. Please install one of them"
}
# test data is always put in the current directory or a tmp subdirectory of it # test data is always put in the current directory or a tmp subdirectory of it
...@@ -307,11 +322,11 @@ sub apply_log ...@@ -307,11 +322,11 @@ sub apply_log
print MY_LOG "bad argument '$shouldchangelog'\n"; print MY_LOG "bad argument '$shouldchangelog'\n";
return 1; return 1;
} }
$log_md5= `md5sum maria_log.*`; $log_md5= `$md5sum maria_log.*`;
print MY_LOG "applying log\n"; print MY_LOG "applying log\n";
`$maria_exe_path/maria_read_log$suffix -a > $tmp/maria_read_log_$table.txt`; `$maria_exe_path/maria_read_log$suffix -a > $tmp/maria_read_log_$table.txt`;
$log_md5_2= `md5sum maria_log.*`; $log_md5_2= `$md5sum maria_log.*`;
if ("$log_md5" ne "$log_md5_2" ) if ("$log_md5" ne "$log_md5_2" )
{ {
if ("$shouldchangelog" eq "shouldnotchangelog") if ("$shouldchangelog" eq "shouldnotchangelog")
...@@ -326,3 +341,19 @@ sub apply_log ...@@ -326,3 +341,19 @@ sub apply_log
return 1; return 1;
} }
} }
sub my_which
{
my ($command) = @_;
my (@paths, $path);
return $command if (-f $command && -x $command);
@paths = split(':', $ENV{'PATH'});
foreach $path (@paths)
{
$path .= "/$command";
return $path if (-f $path && -x $path);
}
return undef();
}
...@@ -775,7 +775,7 @@ int main(int argc, char *argv[]) ...@@ -775,7 +775,7 @@ int main(int argc, char *argv[])
ulong blob_length,pos; ulong blob_length,pos;
uchar *ptr; uchar *ptr;
memcpy_fixed(&ptr, read_record+blob_pos+4, sizeof(ptr)); memcpy_fixed(&ptr, read_record+blob_pos+4, sizeof(ptr));
longget(blob_length,read_record+blob_pos); blob_length= uint4korr(read_record+blob_pos);
for (pos=0 ; pos < blob_length ; pos++) for (pos=0 ; pos < blob_length ; pos++)
{ {
if (ptr[pos] != (uchar) (blob_length+pos)) if (ptr[pos] != (uchar) (blob_length+pos))
......
...@@ -328,7 +328,9 @@ my_string_repertoire(CHARSET_INFO *cs, const char *str, ulong length) ...@@ -328,7 +328,9 @@ my_string_repertoire(CHARSET_INFO *cs, const char *str, ulong length)
{ {
my_wc_t wc; my_wc_t wc;
int chlen; int chlen;
for (; (chlen= cs->cset->mb_wc(cs, &wc, str, strend)) > 0; str+= chlen) for (;
(chlen= cs->cset->mb_wc(cs, &wc, (uchar*) str, (uchar*) strend)) > 0;
str+= chlen)
{ {
if (wc > 0x7F) if (wc > 0x7F)
return MY_REPERTOIRE_UNICODE30; return MY_REPERTOIRE_UNICODE30;
......
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