mariadb/storage/xtradb/include/btr0sea.ic

215 lines
5.7 KiB
Text
Raw Normal View History

2009-03-25 23:11:11 -07:00
/*****************************************************************************
2013-12-16 15:38:05 +01:00
Copyright (c) 1996, 2011, Oracle and/or its affiliates. All Rights Reserved.
2009-03-25 23:11:11 -07:00
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
2013-12-16 15:38:05 +01:00
this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA
2009-03-25 23:11:11 -07:00
*****************************************************************************/
2009-09-07 10:22:53 +00:00
/********************************************************************//**
@file include/btr0sea.ic
The index tree adaptive search
Created 2/17/1996 Heikki Tuuri
*************************************************************************/
#include "dict0mem.h"
#include "btr0cur.h"
#include "buf0buf.h"
2009-09-07 10:22:53 +00:00
/*********************************************************************//**
Updates the search info. */
UNIV_INTERN
void
btr_search_info_update_slow(
/*========================*/
2009-09-07 10:22:53 +00:00
btr_search_t* info, /*!< in/out: search info */
btr_cur_t* cursor);/*!< in: cursor which was just positioned */
2009-09-07 10:22:53 +00:00
/********************************************************************//**
Returns search info for an index.
@return search info; search mutex reserved */
UNIV_INLINE
btr_search_t*
btr_search_get_info(
/*================*/
2009-09-07 10:22:53 +00:00
dict_index_t* index) /*!< in: index */
{
return(index->search_info);
}
2009-09-07 10:22:53 +00:00
/*********************************************************************//**
Updates the search info. */
UNIV_INLINE
void
btr_search_info_update(
/*===================*/
2009-09-07 10:22:53 +00:00
dict_index_t* index, /*!< in: index of the cursor */
btr_cur_t* cursor) /*!< in: cursor which was just positioned */
{
btr_search_t* info;
#ifdef UNIV_SYNC_DEBUG
2013-12-16 15:38:05 +01:00
ut_ad(!rw_lock_own(btr_search_get_latch(index), RW_LOCK_SHARED));
ut_ad(!rw_lock_own(btr_search_get_latch(index), RW_LOCK_EX));
#endif /* UNIV_SYNC_DEBUG */
info = btr_search_get_info(index);
info->hash_analysis++;
if (info->hash_analysis < BTR_SEARCH_HASH_ANALYSIS) {
/* Do nothing */
return;
}
ut_ad(cursor->flag != BTR_CUR_HASH);
btr_search_info_update_slow(info, cursor);
}
2011-07-14 21:22:41 +02:00
2013-12-16 15:38:05 +01:00
/********************************************************************//**
Returns the adaptive hash index table for a given index key.
@return the adaptive hash index table for a given index key */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
hash_table_t*
2013-11-07 21:44:46 +01:00
btr_search_get_hash_table(
2011-07-14 21:22:41 +02:00
/*======================*/
2013-11-07 21:44:46 +01:00
const dict_index_t* index) /*!< in: index */
2011-07-14 21:22:41 +02:00
{
2013-11-07 21:44:46 +01:00
ut_ad(index);
ut_ad(index->search_table);
return(index->search_table);
2011-07-14 21:22:41 +02:00
}
2013-12-16 15:38:05 +01:00
/********************************************************************//**
Returns the adaptive hash index latch for a given index key.
@return the adaptive hash index latch for a given index key */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
2013-12-16 15:38:05 +01:00
prio_rw_lock_t*
2011-07-14 21:22:41 +02:00
btr_search_get_latch(
/*=================*/
2013-11-07 21:44:46 +01:00
const dict_index_t* index) /*!< in: index */
2011-07-14 21:22:41 +02:00
{
2013-11-07 21:44:46 +01:00
ut_ad(index);
ut_ad(index->search_latch >= btr_search_latch_arr &&
index->search_latch < btr_search_latch_arr +
btr_search_index_num);
return(index->search_latch);
2011-07-14 21:22:41 +02:00
}
2013-11-07 21:44:46 +01:00
/*********************************************************************//**
Returns the AHI partition number corresponding to a given index ID. */
UNIV_INLINE
ulint
btr_search_get_key(
/*===============*/
index_id_t index_id) /*!< in: index ID */
{
return(index_id % btr_search_index_num);
}
/*********************************************************************//**
Initializes AHI-related fields in a newly created index. */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
void
2013-11-07 21:44:46 +01:00
btr_search_index_init(
/*===============*/
dict_index_t* index) /*!< in: index */
2011-07-14 21:22:41 +02:00
{
2013-11-07 21:44:46 +01:00
ut_ad(index);
2011-07-14 21:22:41 +02:00
2013-11-07 21:44:46 +01:00
index->search_latch =
&btr_search_latch_arr[btr_search_get_key(index->id)];
index->search_table =
btr_search_sys->hash_tables[btr_search_get_key(index->id)];
2011-07-14 21:22:41 +02:00
}
2013-12-16 15:38:05 +01:00
/********************************************************************//**
Latches all adaptive hash index latches in exclusive mode. */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
void
2013-11-07 21:44:46 +01:00
btr_search_x_lock_all(void)
/*=======================*/
2011-07-14 21:22:41 +02:00
{
ulint i;
for (i = 0; i < btr_search_index_num; i++) {
2013-11-07 21:44:46 +01:00
rw_lock_x_lock(&btr_search_latch_arr[i]);
2011-07-14 21:22:41 +02:00
}
}
2013-12-16 15:38:05 +01:00
/********************************************************************//**
Unlatches all adaptive hash index latches in exclusive mode. */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
void
2013-11-07 21:44:46 +01:00
btr_search_x_unlock_all(void)
/*==========================*/
2011-07-14 21:22:41 +02:00
{
ulint i;
for (i = 0; i < btr_search_index_num; i++) {
2013-11-07 21:44:46 +01:00
rw_lock_x_unlock(&btr_search_latch_arr[i]);
2011-07-14 21:22:41 +02:00
}
}
2013-11-07 21:44:46 +01:00
#ifdef UNIV_SYNC_DEBUG
2013-12-16 15:38:05 +01:00
/******************************************************************//**
Checks if the thread has locked all the adaptive hash index latches in the
specified mode.
@return true if all latches are locked by the current thread, false
otherwise. */
UNIV_INLINE
bool
btr_search_own_all(
/*===============*/
ulint lock_type)
{
ulint i;
for (i = 0; i < btr_search_index_num; i++) {
if (!rw_lock_own(&btr_search_latch_arr[i], lock_type)) {
return(false);
}
}
return(true);
}
2013-11-07 21:44:46 +01:00
/********************************************************************//**
Checks if the thread owns any adaptive hash latches in either S or X mode.
2013-12-16 15:38:05 +01:00
@return true if the thread owns at least one latch in any mode. */
2011-07-14 21:22:41 +02:00
UNIV_INLINE
2013-12-16 15:38:05 +01:00
bool
2013-11-07 21:44:46 +01:00
btr_search_own_any(void)
/*====================*/
2011-07-14 21:22:41 +02:00
{
ulint i;
for (i = 0; i < btr_search_index_num; i++) {
2013-11-07 21:44:46 +01:00
if (rw_lock_own(&btr_search_latch_arr[i], RW_LOCK_SHARED) ||
rw_lock_own(&btr_search_latch_arr[i], RW_LOCK_EX)) {
2013-12-16 15:38:05 +01:00
return(true);
2013-11-07 21:44:46 +01:00
}
2011-07-14 21:22:41 +02:00
}
2013-12-16 15:38:05 +01:00
return(false);
2013-11-07 21:44:46 +01:00
}
2013-12-16 15:38:05 +01:00
#endif /* UNIV_SYNC_DEBUG */