mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
2e814d4702
Contains also MDEV-10547: Test multi_update_innodb fails with InnoDB 5.7 The failure happened because 5.7 has changed the signature of the bool handler::primary_key_is_clustered() const virtual function ("const" was added). InnoDB was using the old signature which caused the function not to be used. MDEV-10550: Parallel replication lock waits/deadlock handling does not work with InnoDB 5.7 Fixed mutexing problem on lock_trx_handle_wait. Note that rpl_parallel and rpl_optimistic_parallel tests still fail. MDEV-10156 : Group commit tests fail on 10.2 InnoDB (branch bb-10.2-jan) Reason: incorrect merge MDEV-10550: Parallel replication can't sync with master in InnoDB 5.7 (branch bb-10.2-jan) Reason: incorrect merge
96 lines
2.5 KiB
Text
96 lines
2.5 KiB
Text
/*****************************************************************************
|
|
|
|
Copyright (c) 1996, 2013, Oracle and/or its affiliates. All Rights Reserved.
|
|
|
|
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
|
|
this program; if not, write to the Free Software Foundation, Inc.,
|
|
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA
|
|
|
|
*****************************************************************************/
|
|
|
|
/**************************************************//**
|
|
@file include/dict0boot.ic
|
|
Data dictionary creation and booting
|
|
|
|
Created 4/18/1996 Heikki Tuuri
|
|
*******************************************************/
|
|
|
|
/**********************************************************************//**
|
|
Returns a new row id.
|
|
@return the new id */
|
|
UNIV_INLINE
|
|
row_id_t
|
|
dict_sys_get_new_row_id(void)
|
|
/*=========================*/
|
|
{
|
|
row_id_t id;
|
|
|
|
mutex_enter(&dict_sys->mutex);
|
|
|
|
id = dict_sys->row_id;
|
|
|
|
if (0 == (id % DICT_HDR_ROW_ID_WRITE_MARGIN)) {
|
|
|
|
dict_hdr_flush_row_id();
|
|
}
|
|
|
|
dict_sys->row_id++;
|
|
|
|
mutex_exit(&dict_sys->mutex);
|
|
|
|
return(id);
|
|
}
|
|
|
|
/**********************************************************************//**
|
|
Reads a row id from a record or other 6-byte stored form.
|
|
@return row id */
|
|
UNIV_INLINE
|
|
row_id_t
|
|
dict_sys_read_row_id(
|
|
/*=================*/
|
|
const byte* field) /*!< in: record field */
|
|
{
|
|
#if DATA_ROW_ID_LEN != 6
|
|
# error "DATA_ROW_ID_LEN != 6"
|
|
#endif
|
|
|
|
return(mach_read_from_6(field));
|
|
}
|
|
|
|
/**********************************************************************//**
|
|
Writes a row id to a record or other 6-byte stored form. */
|
|
UNIV_INLINE
|
|
void
|
|
dict_sys_write_row_id(
|
|
/*==================*/
|
|
byte* field, /*!< in: record field */
|
|
row_id_t row_id) /*!< in: row id */
|
|
{
|
|
#if DATA_ROW_ID_LEN != 6
|
|
# error "DATA_ROW_ID_LEN != 6"
|
|
#endif
|
|
|
|
mach_write_to_6(field, row_id);
|
|
}
|
|
|
|
/*********************************************************************//**
|
|
Check if a table id belongs to system table.
|
|
@return true if the table id belongs to a system table. */
|
|
UNIV_INLINE
|
|
bool
|
|
dict_is_sys_table(
|
|
/*==============*/
|
|
table_id_t id) /*!< in: table id to check */
|
|
{
|
|
return(id < DICT_HDR_FIRST_ID);
|
|
}
|
|
|
|
|