mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
8eba777c2b
Changes: - Initalize Aria early to allow it to load mysql.plugin table with --help - Don't print 'aborting' when doing --help - Don't write 'loose' error messages on log_warning < 2 (2 is default) - Don't write warnings about disabled plugings when doing --help - Don't write aria_log_control or aria log files when doing --help - When using --help, open all Aria tables in read only mode (safety) - If aria_init() fails, do a cleanup(). (Frees used memory) - If aria_log_control is locked with --help, then don't wait 30 seconds but instead return at once without initialzing Aria plugin.
73 lines
2.3 KiB
C
73 lines
2.3 KiB
C
/* Copyright (C) 2006-2008 MySQL AB, 2008-2009 Sun Microsystems, Inc.
|
|
|
|
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, Fifth Floor, Boston, MA 02110-1335 USA */
|
|
|
|
#ifndef _trnman_h
|
|
#define _trnman_h
|
|
|
|
C_MODE_START
|
|
|
|
#include <lf.h>
|
|
#include "trnman_public.h"
|
|
#include "ma_loghandler_lsn.h"
|
|
|
|
/**
|
|
trid - 6 uchar transaction identifier. Assigned when a transaction
|
|
is created. Transaction can always be identified by its trid,
|
|
even after transaction has ended.
|
|
|
|
short_id - 2-byte transaction identifier, identifies a running
|
|
transaction, is reassigned when transaction ends.
|
|
|
|
when short_id is 0, TRN is not initialized, for all practical purposes
|
|
it could be considered unused.
|
|
|
|
when commit_trid is MAX_TRID the transaction is running, otherwise it's
|
|
committed.
|
|
|
|
state_lock mutex protects the state of a TRN, that is whether a TRN
|
|
is committed/running/unused. Meaning that modifications of short_id and
|
|
commit_trid happen under this mutex.
|
|
*/
|
|
|
|
struct st_ma_transaction
|
|
{
|
|
LF_PINS *pins;
|
|
WT_THD *wt;
|
|
mysql_mutex_t state_lock;
|
|
void *used_tables; /**< Table shares used by transaction */
|
|
void *used_instances; /* table files used by transaction */
|
|
TRN *next, *prev;
|
|
TrID trid, min_read_from, commit_trid;
|
|
LSN rec_lsn, undo_lsn;
|
|
LSN_WITH_FLAGS first_undo_lsn;
|
|
uint locked_tables;
|
|
uint16 short_id;
|
|
uint16 flags; /**< Various flags */
|
|
};
|
|
|
|
#define TRANSACTION_LOGGED_LONG_ID 0x8000000000000000ULL
|
|
#define MAX_TRID (~(TrID)0)
|
|
#define MAX_INTERNAL_TRID 0xffffffffffffLL
|
|
|
|
extern WT_RESOURCE_TYPE ma_rc_dup_unique;
|
|
|
|
#ifdef HAVE_PSI_INTERFACE
|
|
extern PSI_mutex_key key_LOCK_trn_list, key_TRN_state_lock;
|
|
#endif
|
|
|
|
C_MODE_END
|
|
|
|
#endif
|
|
|