diff options
Diffstat (limited to 'myisammrg/myrg_open.c')
-rw-r--r-- | myisammrg/myrg_open.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/myisammrg/myrg_open.c b/myisammrg/myrg_open.c index c12fa1fa52b..7f80a88dddc 100644 --- a/myisammrg/myrg_open.c +++ b/myisammrg/myrg_open.c @@ -86,7 +86,7 @@ int handle_locking; *m_info=info; m_info->open_tables=(MYRG_TABLE *) (m_info+1); m_info->tables=files; - + for (i=files ; i-- > 0 ; ) { m_info->open_tables[i].table=isam; @@ -104,12 +104,16 @@ int handle_locking; m_info->open_tables[i].file_offset=(my_off_t) file_offset; file_offset+=m_info->open_tables[i].table->state->data_file_length; } + errpos=2; if (sizeof(my_off_t) == 4 && file_offset > (ulonglong) (ulong) ~0L) { my_errno=HA_ERR_RECORD_FILE_FULL; - my_free((char*) m_info,MYF(0)); goto err; } + /* Allocate memory for queue */ + if (m_info->open_tables->table->s->base.keys && + _myrg_init_queue(m_info,0,HA_READ_KEY_EXACT)) + goto err; m_info->end_table=m_info->open_tables+files; m_info->last_used_table=m_info->open_tables; @@ -119,12 +123,14 @@ int handle_locking; pthread_mutex_lock(&THR_LOCK_open); myrg_open_list=list_add(myrg_open_list,&m_info->open_list); pthread_mutex_unlock(&THR_LOCK_open); - m_info->by_key.root=0; DBUG_RETURN(m_info); err: save_errno=my_errno; switch (errpos) { + case 2: + my_free((char*) m_info,MYF(0)); + /* Fall through */ case 1: VOID(my_fclose(file,MYF(0))); for (i=files ; i-- > 0 ; ) |