summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--BitKeeper/etc/logging_ok27
-rw-r--r--heap/hp_extra.c1
-rw-r--r--include/my_base.h3
-rw-r--r--isam/extra.c8
-rw-r--r--isam/pack_isam.c4
-rw-r--r--merge/extra.c4
-rw-r--r--myisam/mi_extra.c18
-rw-r--r--myisam/myisampack.c4
-rw-r--r--myisammrg/myrg_extra.c4
-rw-r--r--sql/filesort.cc4
-rw-r--r--sql/ha_berkeley.cc31
-rw-r--r--sql/ha_berkeley.h5
12 files changed, 71 insertions, 42 deletions
diff --git a/BitKeeper/etc/logging_ok b/BitKeeper/etc/logging_ok
index 9fd5747e088..a6b0f220269 100644
--- a/BitKeeper/etc/logging_ok
+++ b/BitKeeper/etc/logging_ok
@@ -1,26 +1 @@
-bk@work.mysql.com
-davida@work.mysql.com
-jamppa@work.mysql.com
-jcole@ham.spaceapes.com
-jcole@jcole.burghcom.com
-jcole@nslinux.bedford.progress.com
-jcole@tetra.bedford.progress.com
-jcole@tetra.spaceapes.com
-matt@work.mysql.com
-monty@donna.mysql.com
-monty@work.mysql.com
-mwagner@evoq.home.mwagner.org
-nusphere@main.burghcom.com
-paul@central.snake.net
-paul@work.mysql.com
-sasha@mysql.sashanet.com
-sasha@work.mysql.com
-serg@infomag.ape.relarn.ru
-serg@serg.mysql.com
-serg@work.mysql.com
-sinisa@work.mysql.com
-spurr@nslinux.bedford.progress.com
-tim@localhost.polyesthetic.msg
-tim@threads.polyesthetic.msg
-tim@work.mysql.com
-tonu@work.mysql.com
+monty@tik.mysql.com
diff --git a/heap/hp_extra.c b/heap/hp_extra.c
index 581ca1e8e56..133be01c676 100644
--- a/heap/hp_extra.c
+++ b/heap/hp_extra.c
@@ -29,6 +29,7 @@ int heap_extra(register HP_INFO *info, enum ha_extra_function function)
switch (function) {
case HA_EXTRA_RESET:
+ case HA_EXTRA_RESET_STATE:
info->lastinx= -1;
info->current_record= (ulong) ~0L;
info->current_hash_ptr=0;
diff --git a/include/my_base.h b/include/my_base.h
index 033b38672d3..5c76b5a6bc3 100644
--- a/include/my_base.h
+++ b/include/my_base.h
@@ -87,7 +87,8 @@ enum ha_extra_function {
HA_EXTRA_REINIT_CACHE=20, /* init cache from current record */
HA_EXTRA_FORCE_REOPEN=21, /* Datafile have changed on disk */
HA_EXTRA_FLUSH, /* Flush tables to disk */
- HA_EXTRA_NO_ROWS /* Don't write rows */
+ HA_EXTRA_NO_ROWS, /* Don't write rows */
+ HA_EXTRA_RESET_STATE /* Reset positions */
};
/* The following is parameter to ha_panic() */
diff --git a/isam/extra.c b/isam/extra.c
index dc9b6ce2d19..1d333fa372f 100644
--- a/isam/extra.c
+++ b/isam/extra.c
@@ -36,6 +36,14 @@ int nisam_extra(N_INFO *info, enum ha_extra_function function)
switch (function) {
case HA_EXTRA_RESET:
+ if (info->opt_flag & (READ_CACHE_USED | WRITE_CACHE_USED))
+ {
+ info->opt_flag&= ~(READ_CACHE_USED | WRITE_CACHE_USED);
+ error=end_io_cache(&info->rec_cache);
+ }
+ info->opt_flag&= ~(KEY_READ_USED | REMEMBER_OLD_POS);
+
+ case HA_EXTRA_RESET_STATE:
info->lastinx= 0; /* Use first index as def */
info->int_pos=info->lastpos= NI_POS_ERROR;
info->page_changed=1;
diff --git a/isam/pack_isam.c b/isam/pack_isam.c
index 1040096fa4a..cadec5bcef5 100644
--- a/isam/pack_isam.c
+++ b/isam/pack_isam.c
@@ -2012,8 +2012,8 @@ static int mrg_rrnd(MRG_INFO *info,byte *buf)
{
isam_info= *(info->current=info->file);
info->end=info->current+info->count;
- nisam_extra(isam_info,HA_EXTRA_CACHE);
nisam_extra(isam_info,HA_EXTRA_RESET);
+ nisam_extra(isam_info,HA_EXTRA_CACHE);
filepos=isam_info->s->pack.header_length;
}
else
@@ -2035,8 +2035,8 @@ static int mrg_rrnd(MRG_INFO *info,byte *buf)
info->current++;
isam_info= *info->current;
filepos=isam_info->s->pack.header_length;
- nisam_extra(isam_info,HA_EXTRA_CACHE);
nisam_extra(isam_info,HA_EXTRA_RESET);
+ nisam_extra(isam_info,HA_EXTRA_CACHE);
}
}
diff --git a/merge/extra.c b/merge/extra.c
index c20241228a2..343806dbfad 100644
--- a/merge/extra.c
+++ b/merge/extra.c
@@ -32,9 +32,9 @@ enum ha_extra_function function;
info->cache_in_use=1;
else
{
- if (function == HA_EXTRA_NO_CACHE)
+ if (function == HA_EXTRA_NO_CACHE || function == HA_EXTRA_RESET)
info->cache_in_use=0;
- if (function == HA_EXTRA_RESET)
+ if (function == HA_EXTRA_RESET || function == HA_EXTRA_RESET_STATE)
{
info->current_table=0;
info->last_used_table=info->open_tables;
diff --git a/myisam/mi_extra.c b/myisam/mi_extra.c
index b90b5b35780..eaf9400babe 100644
--- a/myisam/mi_extra.c
+++ b/myisam/mi_extra.c
@@ -37,6 +37,24 @@ int mi_extra(MI_INFO *info, enum ha_extra_function function)
switch (function) {
case HA_EXTRA_RESET:
+ /*
+ Free buffers and reset the following flags:
+ EXTRA_CACHE, EXTRA_WRITE_CACHE, EXTRA_KEYREAD, EXTRA_QUICK
+ */
+ if (info->opt_flag & (READ_CACHE_USED | WRITE_CACHE_USED))
+ {
+ info->opt_flag&= ~(READ_CACHE_USED | WRITE_CACHE_USED);
+ error=end_io_cache(&info->rec_cache);
+ }
+#if defined(HAVE_MMAP) && defined(HAVE_MADVICE)
+ if (info->opt_flag & MEMMAP_USED)
+ madvise(share->file_map,share->state.state.data_file_length,MADV_RANDOM);
+#endif
+ info->opt_flag&= ~(KEY_READ_USED | REMEMBER_OLD_POS);
+ info->quick_mode=0;
+ /* Fall through */
+
+ case HA_EXTRA_RESET_STATE: /* Reset state (don't free buffers) */
info->lastinx= 0; /* Use first index as def */
info->last_search_keypage=info->lastpos= HA_OFFSET_ERROR;
info->page_changed=1;
diff --git a/myisam/myisampack.c b/myisam/myisampack.c
index fbb543152f8..ef9be13687e 100644
--- a/myisam/myisampack.c
+++ b/myisam/myisampack.c
@@ -2104,8 +2104,8 @@ static int mrg_rrnd(MRG_INFO *info,byte *buf)
{
isam_info= *(info->current=info->file);
info->end=info->current+info->count;
- mi_extra(isam_info,HA_EXTRA_CACHE);
mi_extra(isam_info,HA_EXTRA_RESET);
+ mi_extra(isam_info,HA_EXTRA_CACHE);
filepos=isam_info->s->pack.header_length;
}
else
@@ -2127,8 +2127,8 @@ static int mrg_rrnd(MRG_INFO *info,byte *buf)
info->current++;
isam_info= *info->current;
filepos=isam_info->s->pack.header_length;
- mi_extra(isam_info,HA_EXTRA_CACHE);
mi_extra(isam_info,HA_EXTRA_RESET);
+ mi_extra(isam_info,HA_EXTRA_CACHE);
}
}
diff --git a/myisammrg/myrg_extra.c b/myisammrg/myrg_extra.c
index 0927728e2c1..4b5353a146d 100644
--- a/myisammrg/myrg_extra.c
+++ b/myisammrg/myrg_extra.c
@@ -31,9 +31,9 @@ int myrg_extra(MYRG_INFO *info,enum ha_extra_function function)
info->cache_in_use=1;
else
{
- if (function == HA_EXTRA_NO_CACHE)
+ if (function == HA_EXTRA_NO_CACHE || function == HA_EXTRA_RESET)
info->cache_in_use=0;
- if (function == HA_EXTRA_RESET)
+ if (function == HA_EXTRA_RESET || function == HA_EXTRA_RESET_STATE)
{
info->current_table=0;
info->last_used_table=info->open_tables;
diff --git a/sql/filesort.cc b/sql/filesort.cc
index 32947a06ba1..08aca12d5b8 100644
--- a/sql/filesort.cc
+++ b/sql/filesort.cc
@@ -330,7 +330,9 @@ static ha_rows find_all_keys(SORTPARAM *param, SQL_SELECT *select,
next_pos=ref_pos;
if (! indexfile && ! quick_select)
{
- file->reset();
+ file->reset(); // QQ; Shouldn't be needed
+ if (table->keyread) // QQ Can be removed after the reset
+ file->extra(HA_EXTRA_KEYREAD); // QQ is removed
next_pos=(byte*) 0; /* Find records in sequence */
file->rnd_init();
file->extra(HA_EXTRA_CACHE); /* Quicker reads */
diff --git a/sql/ha_berkeley.cc b/sql/ha_berkeley.cc
index 5f156622901..e5c9f66e200 100644
--- a/sql/ha_berkeley.cc
+++ b/sql/ha_berkeley.cc
@@ -319,8 +319,14 @@ int ha_berkeley::open(const char *name, int mode, uint test_if_locked)
/* Open other keys */
bzero((char*) key_file,sizeof(*key_file)*table->keys);
- key_used_on_scan=primary_key=table->primary_key;
- key_file[primary_key]=file;
+ if ((key_used_on_scan=primary_key=table->primary_key) < MAX_KEY)
+ key_file[primary_key]=file;
+ else // No primary key
+ {
+ hidden_primary_key=1;
+ if (!share->primary_key_inited)
+ update_auto_primary_key();
+ }
bzero((char*) &current_row,sizeof(current_row));
DB **ptr=key_file;
@@ -1387,8 +1393,6 @@ static BDB_SHARE *get_share(const char *table_name)
if ((share=(BDB_SHARE *) my_malloc(sizeof(*share)+length+1,
MYF(MY_WME | MY_ZEROFILL))))
{
- // pthread_mutex_init(&share->mutex);
- // pthread_cond_init(&share->cond);
share->table_name_length=length;
share->table_name=(char*) (share+1);
strmov(share->table_name,table_name);
@@ -1399,6 +1403,7 @@ static BDB_SHARE *get_share(const char *table_name)
return 0;
}
thr_lock_init(&share->lock);
+ pthread_mutex_init(&share->mutex);
}
}
share->use_count++;
@@ -1413,10 +1418,26 @@ static void free_share(BDB_SHARE *share)
{
hash_delete(&bdb_open_tables, (gptr) share);
thr_lock_delete(&share->lock);
- // pthread_mutex_destroy(&share->mutex);
+ pthread_mutex_destroy(&share->mutex);
my_free((gptr) share, MYF(0));
}
pthread_mutex_unlock(&bdb_mutex);
}
+
+void ha_berkeley::update_auto_primary_key()
+{
+ (void) extra(HA_EXTRA_KEYREAD);
+ pthread_mutex_lock(&share->mutex);
+ if (!share->primary_key_inited)
+ {
+ index_init(primary_key);
+ if (!index_last(table->record[1]))
+ share->auto_ident=current_ident;
+ index_end();
+ }
+ pthread_mutex_unlock(&share->mutex);
+ (void) extra(HA_EXTRA_NO_KEYREAD);
+}
+
#endif /* HAVE_BERKELEY_DB */
diff --git a/sql/ha_berkeley.h b/sql/ha_berkeley.h
index 519e4b62cf9..89ee6e58332 100644
--- a/sql/ha_berkeley.h
+++ b/sql/ha_berkeley.h
@@ -24,9 +24,12 @@
#include <db.h>
typedef struct st_berkeley_share {
+ ulonglong auto_ident;
THR_LOCK lock;
+ pthread_mutex_t mutex;
char *table_name;
uint table_name_length,use_count;
+ my_bool inited;
} BDB_SHARE;
class ha_berkeley: public handler
@@ -44,7 +47,7 @@ class ha_berkeley: public handler
ulong int_option_flag;
ulong alloced_rec_buff_length;
uint primary_key,last_dup_key;
- bool fixed_length_row, fixed_length_primary_key;
+ bool fixed_length_row, fixed_length_primary_key, hidden_primary_key;
bool fix_rec_buff_for_blob(ulong length);
ulong max_row_length(const byte *buf);