mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-27 17:23:03 +01:00
146 lines
4.9 KiB
C++
146 lines
4.9 KiB
C++
/*
|
|
* PROGRAM: JRD Access Method
|
|
* MODULE: lck.h
|
|
* DESCRIPTION: Lock hander definitions (NOT lock manager)
|
|
*
|
|
* The contents of this file are subject to the Interbase Public
|
|
* License Version 1.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy
|
|
* of the License at http://www.Inprise.com/IPL.html
|
|
*
|
|
* Software distributed under the License is distributed on an
|
|
* "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
|
|
* or implied. See the License for the specific language governing
|
|
* rights and limitations under the License.
|
|
*
|
|
* The Original Code was created by Inprise Corporation
|
|
* and its predecessors. Portions created by Inprise Corporation are
|
|
* Copyright (C) Inprise Corporation.
|
|
*
|
|
* All Rights Reserved.
|
|
* Contributor(s): ______________________________________.
|
|
*/
|
|
|
|
#ifndef JRD_LCK_H
|
|
#define JRD_LCK_H
|
|
|
|
struct blk;
|
|
|
|
namespace Jrd {
|
|
|
|
class BlockingThread;
|
|
class Database;
|
|
class Attachment;
|
|
|
|
/* Lock types */
|
|
|
|
enum lck_t {
|
|
LCK_database = 1, /* Root of lock tree */
|
|
LCK_relation, /* Individual relation lock */
|
|
LCK_bdb, /* Individual buffer block */
|
|
LCK_tra, /* Individual transaction lock */
|
|
LCK_rel_exist, /* Relation existence lock */
|
|
LCK_idx_exist, /* Index existence lock */
|
|
LCK_attachment, /* Attachment lock */
|
|
LCK_shadow, /* Lock to synchronize addition of shadows */
|
|
LCK_sweep, /* Sweep lock for single sweeper */
|
|
LCK_file_extend, /* Lock to synchronize file extension */
|
|
LCK_retaining, /* Youngest commit retaining transaction */
|
|
LCK_expression, /* Expression index caching mechanism */
|
|
LCK_record_locking, /* Lock on existence of record locking for this database */
|
|
LCK_record, /* Record Lock */
|
|
LCK_prc_exist, /* Procedure existence lock */
|
|
LCK_range_relation_obsolete, // Relation refresh range lock, PC_ENGINE
|
|
LCK_update_shadow, /* shadow update sync lock */
|
|
LCK_backup_alloc, /* Lock for page allocation table in backup spare file */
|
|
LCK_backup_database, /* Lock to protect writing to database file */
|
|
LCK_backup_end, /* Lock to protect end_backup consistency */
|
|
LCK_rel_partners, /* Relation partners lock */
|
|
LCK_page_space, /* Page space ID lock */
|
|
LCK_dsql_cache, /* DSQL cache lock */
|
|
LCK_counter, /* Lock holding a cross-process counter */
|
|
LCK_monitor, /* Lock to dump the monitoring data */
|
|
LCK_instance, /* Lock to identify a dbb instance */
|
|
LCK_tt_exist, /* TextType existence lock */
|
|
LCK_cancel /* Cancellation lock */
|
|
};
|
|
|
|
/* Lock owner types */
|
|
|
|
enum lck_owner_t {
|
|
LCK_OWNER_process = 1, /* A process is the owner of the lock */
|
|
LCK_OWNER_database, /* A database is the owner of the lock */
|
|
LCK_OWNER_attachment, /* An attachment is the owner of the lock */
|
|
LCK_OWNER_transaction /* A transaction is the owner of the lock */
|
|
};
|
|
|
|
// This is defined in dbt.cpp and nobody calls it.
|
|
void MP_GDB_print(MemoryPool*);
|
|
|
|
class Lock : public pool_alloc_rpt<UCHAR, type_lck>
|
|
{
|
|
public:
|
|
Lock()
|
|
: lck_test_field(666),
|
|
lck_parent(0),
|
|
lck_next(0),
|
|
lck_att_next(0),
|
|
lck_prior(0),
|
|
lck_collision(0),
|
|
lck_identical(0),
|
|
lck_dbb(0),
|
|
lck_object(0),
|
|
lck_owner(0),
|
|
lck_compatible(0),
|
|
lck_compatible2(0),
|
|
lck_attachment(0),
|
|
lck_blocked_threads(0),
|
|
lck_ast(0),
|
|
lck_id(0),
|
|
lck_owner_handle(0),
|
|
lck_count(0),
|
|
lck_length(0),
|
|
lck_logical(0),
|
|
lck_physical(0),
|
|
lck_data(0)
|
|
{
|
|
lck_key.lck_long = 0;
|
|
lck_tail[0] = 0;
|
|
}
|
|
|
|
int lck_test_field;
|
|
Lock* lck_parent;
|
|
Lock* lck_next; /* lck_next and lck_prior form a doubly linked list of locks
|
|
bound to attachment. Used in MULTI_THREAD builds only */
|
|
Lock* lck_att_next; /* Next in chain owned by attachment (RLCK, currently unused) */
|
|
Lock* lck_prior;
|
|
Lock* lck_collision; /* collisions in compatibility table */
|
|
Lock* lck_identical; /* identical locks in compatibility table */
|
|
Database* lck_dbb; /* database object is contained in */
|
|
blk* lck_object; /* argument to be passed to ast */
|
|
blk* lck_owner; /* Logical owner block (transaction, etc.) */
|
|
blk* lck_compatible; /* Enter into internal_enqueue() and treat as compatible */
|
|
blk* lck_compatible2; /* Sub-level for internal compatibility */
|
|
Attachment* lck_attachment; /* Attachment that owns lock, set only using set_lock_attachment */
|
|
BlockingThread* lck_blocked_threads; /* Threads blocked by lock */
|
|
lock_ast_t lck_ast; /* Blocking AST routine */
|
|
SLONG lck_id; /* Lock id from lock manager */
|
|
SLONG lck_owner_handle; /* Lock owner handle from the lock manager's point of view */
|
|
USHORT lck_count; /* count of locks taken out by attachment */
|
|
SSHORT lck_length; /* Length of lock string */
|
|
UCHAR lck_logical; /* Logical lock level */
|
|
UCHAR lck_physical; /* Physical lock level */
|
|
SLONG lck_data; /* Data associated with a lock */
|
|
enum lck_t lck_type;
|
|
union {
|
|
UCHAR lck_string[1];
|
|
SLONG lck_long;
|
|
} lck_key;
|
|
UCHAR lck_tail[1]; /* Makes the allocator happy */
|
|
};
|
|
|
|
} //namespace Jrd
|
|
|
|
#endif // JRD_LCK_H
|
|
|