8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 06:03:02 +01:00

-Correct parameter type (page_type)

-Macro cleaning
This commit is contained in:
brodsom 2004-05-14 17:03:20 +00:00
parent 3c0bed8e04
commit dc6303c8c6
2 changed files with 127 additions and 116 deletions

View File

@ -129,7 +129,7 @@ static void down_grade(thread_db*, BufferDesc*);
static void expand_buffers(thread_db*, ULONG); static void expand_buffers(thread_db*, ULONG);
static BufferDesc* get_buffer(thread_db*, SLONG, LATCH, SSHORT); static BufferDesc* get_buffer(thread_db*, SLONG, LATCH, SSHORT);
static SSHORT latch_bdb(thread_db*, LATCH, BufferDesc*, SLONG, SSHORT); static SSHORT latch_bdb(thread_db*, LATCH, BufferDesc*, SLONG, SSHORT);
static SSHORT lock_buffer(thread_db*, BufferDesc*, SSHORT, SSHORT); static SSHORT lock_buffer(thread_db*, BufferDesc*, SSHORT, SCHAR);
static ULONG memory_init(thread_db*, BufferControl*, ULONG); static ULONG memory_init(thread_db*, BufferControl*, ULONG);
static void page_validation_error(thread_db*, win*, SSHORT); static void page_validation_error(thread_db*, win*, SSHORT);
#ifdef CACHE_READER #ifdef CACHE_READER
@ -158,17 +158,19 @@ const SLONG MIN_BUFFER_SEGMENT = 65536L;
#endif #endif
#endif #endif
#define BCB_MUTEX_ACQUIRE //
#define BCB_MUTEX_RELEASE //#define BCB_MUTEX_ACQUIRE
//#define BCB_MUTEX_RELEASE
#define PRE_MUTEX_ACQUIRE //
#define PRE_MUTEX_RELEASE //#define PRE_MUTEX_ACQUIRE
//#define PRE_MUTEX_RELEASE
#define BTC_MUTEX_ACQUIRE //
#define BTC_MUTEX_RELEASE //#define BTC_MUTEX_ACQUIRE
//#define BTC_MUTEX_RELEASE
#define LATCH_MUTEX_ACQUIRE //
#define LATCH_MUTEX_RELEASE //#define LATCH_MUTEX_ACQUIRE
//#define LATCH_MUTEX_RELEASE
//
const int JOURNAL_PAGE = -1; const int JOURNAL_PAGE = -1;
const int SHADOW_PAGE = -2; const int SHADOW_PAGE = -2;
@ -276,7 +278,7 @@ void CCH_flush_database(thread_db* tdbb)
// Redirect pages to the difference file // Redirect pages to the difference file
// Need to reconsider this protection for possible deadlocks when MT-safety is implemented // Need to reconsider this protection for possible deadlocks when MT-safety is implemented
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
for (ULONG i = 0; (bcb = dbb->dbb_bcb) && i < bcb->bcb_count; i++) { for (ULONG i = 0; (bcb = dbb->dbb_bcb) && i < bcb->bcb_count; i++) {
BufferDesc* bdb = bcb->bcb_rpt[i].bcb_bdb; BufferDesc* bdb = bcb->bcb_rpt[i].bcb_bdb;
if (bdb->bdb_write_direction != BDB_write_normal && if (bdb->bdb_write_direction != BDB_write_normal &&
@ -287,7 +289,7 @@ void CCH_flush_database(thread_db* tdbb)
NBAK_TRACE(("Redirect page=%d use=%d flags=%d", bdb->bdb_page, bdb->bdb_use_count, bdb->bdb_flags)); NBAK_TRACE(("Redirect page=%d use=%d flags=%d", bdb->bdb_page, bdb->bdb_use_count, bdb->bdb_flags));
update_write_direction(tdbb, bdb); update_write_direction(tdbb, bdb);
} }
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
#else #else
/* Do some fancy footwork to make sure that pages are /* Do some fancy footwork to make sure that pages are
not removed from the btc tree at AST level. Then not removed from the btc tree at AST level. Then
@ -694,9 +696,9 @@ void CCH_expand(thread_db* tdbb, ULONG number)
**************************************/ **************************************/
SET_TDBB(tdbb); SET_TDBB(tdbb);
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
expand_buffers(tdbb, number); expand_buffers(tdbb, number);
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
} }
@ -782,11 +784,14 @@ pag* CCH_fake(thread_db* tdbb, WIN * window, SSHORT latch_wait)
} }
pag* CCH_fetch(thread_db* tdbb, pag* CCH_fetch(
WIN* window, thread_db* tdbb,
USHORT lock_type, WIN* window,
SSHORT page_type, USHORT lock_type,
SSHORT checksum, SSHORT latch_wait, bool read_shadow) SCHAR page_type,
SSHORT checksum,
SSHORT latch_wait,
bool read_shadow)
{ {
/************************************** /**************************************
* *
@ -864,7 +869,7 @@ pag* CCH_fetch(thread_db* tdbb,
/* Validate the fetched page matches the expected type */ /* Validate the fetched page matches the expected type */
if (bdb->bdb_buffer->pag_type != (SCHAR) page_type && if (bdb->bdb_buffer->pag_type != page_type &&
page_type != pag_undefined) page_type != pag_undefined)
{ {
page_validation_error(tdbb, window, page_type); page_validation_error(tdbb, window, page_type);
@ -874,10 +879,13 @@ pag* CCH_fetch(thread_db* tdbb,
} }
SSHORT CCH_fetch_lock(thread_db* tdbb, SSHORT CCH_fetch_lock(
WIN * window, thread_db* tdbb,
USHORT lock_type, WIN * window,
SSHORT wait, SSHORT latch_wait, SSHORT page_type) USHORT lock_type,
SSHORT wait,
SSHORT latch_wait,
SCHAR page_type)
{ {
/************************************** /**************************************
* *
@ -1195,7 +1203,7 @@ void CCH_fini(thread_db* tdbb)
} }
} }
else { else {
CCH_flush(tdbb, (USHORT) FLUSH_FINI, (SLONG) 0); CCH_flush(tdbb, FLUSH_FINI, (SLONG) 0);
} }
} }
@ -1493,13 +1501,14 @@ SLONG CCH_get_incarnation(WIN * window)
} }
pag* CCH_handoff(thread_db* tdbb, pag* CCH_handoff(
WIN* window, thread_db* tdbb,
SLONG page, WIN* window,
SSHORT lock, SLONG page,
SSHORT page_type, SSHORT lock,
SSHORT latch_wait, SCHAR page_type,
SSHORT release_tail) SSHORT latch_wait,
SSHORT release_tail)
{ {
/************************************** /**************************************
* *
@ -1603,7 +1612,7 @@ pag* CCH_handoff(thread_db* tdbb,
/* Validate the fetched page matches the expected type */ /* Validate the fetched page matches the expected type */
if (bdb->bdb_buffer->pag_type != (SCHAR) page_type && if (bdb->bdb_buffer->pag_type != page_type &&
page_type != pag_undefined) page_type != pag_undefined)
{ {
page_validation_error(tdbb, window, page_type); page_validation_error(tdbb, window, page_type);
@ -2771,7 +2780,7 @@ static void btc_flush(
/* Pick starting place at leftmost node */ /* Pick starting place at leftmost node */
BTC_MUTEX_ACQUIRE; // BTC_MUTEX_ACQUIRE;
BufferDesc* next = dbb->dbb_bcb->bcb_btree; BufferDesc* next = dbb->dbb_bcb->bcb_btree;
while (next && next->bdb_left) { while (next && next->bdb_left) {
next = next->bdb_left; next = next->bdb_left;
@ -2832,9 +2841,9 @@ static void btc_flush(
as a dependency while we were walking the tree */ as a dependency while we were walking the tree */
if (!(bdb->bdb_flags & BDB_dirty)) { if (!(bdb->bdb_flags & BDB_dirty)) {
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
btc_remove(bdb); btc_remove(bdb);
BTC_MUTEX_ACQUIRE; // BTC_MUTEX_ACQUIRE;
continue; continue;
} }
@ -2842,7 +2851,7 @@ static void btc_flush(
changes should be made in both places */ changes should be made in both places */
const SLONG page = bdb->bdb_page; const SLONG page = bdb->bdb_page;
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
#ifndef SUPERSERVER #ifndef SUPERSERVER
if (bdb->bdb_use_count) if (bdb->bdb_use_count)
@ -2867,10 +2876,10 @@ static void btc_flush(
{ {
PAGE_LOCK_RE_POST(bdb->bdb_lock); PAGE_LOCK_RE_POST(bdb->bdb_lock);
} }
BTC_MUTEX_ACQUIRE; // BTC_MUTEX_ACQUIRE;
} }
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
} }
@ -2901,11 +2910,11 @@ static void btc_insert(Database* dbb, BufferDesc* bdb)
/* if the tree is empty, this is now the tree */ /* if the tree is empty, this is now the tree */
BTC_MUTEX_ACQUIRE; // BTC_MUTEX_ACQUIRE;
BufferDesc* node = dbb->dbb_bcb->bcb_btree; BufferDesc* node = dbb->dbb_bcb->bcb_btree;
if (!node) { if (!node) {
dbb->dbb_bcb->bcb_btree = bdb; dbb->dbb_bcb->bcb_btree = bdb;
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
return; return;
} }
@ -2940,7 +2949,7 @@ static void btc_insert(Database* dbb, BufferDesc* bdb)
} }
} }
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
} }
@ -2967,7 +2976,7 @@ static void btc_remove(BufferDesc* bdb)
/* engage in a little defensive programming to make /* engage in a little defensive programming to make
sure the node is actually in the tree */ sure the node is actually in the tree */
BTC_MUTEX_ACQUIRE; // BTC_MUTEX_ACQUIRE;
BufferControl* bcb = dbb->dbb_bcb; BufferControl* bcb = dbb->dbb_bcb;
if ((!bcb->bcb_btree) || if ((!bcb->bcb_btree) ||
(!bdb->bdb_parent && (!bdb->bdb_parent &&
@ -2976,7 +2985,7 @@ static void btc_remove(BufferDesc* bdb)
if ((bdb->bdb_flags & BDB_must_write) || !(bdb->bdb_flags & BDB_dirty)) if ((bdb->bdb_flags & BDB_must_write) || !(bdb->bdb_flags & BDB_dirty))
{ {
/* Must writes aren't worth the effort */ /* Must writes aren't worth the effort */
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
return; return;
} }
else { else {
@ -3022,7 +3031,7 @@ static void btc_remove(BufferDesc* bdb)
/* initialize the node for next usage */ /* initialize the node for next usage */
bdb->bdb_left = bdb->bdb_right = bdb->bdb_parent = NULL; bdb->bdb_left = bdb->bdb_right = bdb->bdb_parent = NULL;
BTC_MUTEX_RELEASE; // BTC_MUTEX_RELEASE;
} }
@ -3411,8 +3420,8 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
/* Start by finding the buffer containing the high priority page */ /* Start by finding the buffer containing the high priority page */
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
BufferControl* bcb = dbb->dbb_bcb; BufferControl* bcb = dbb->dbb_bcb;
QUE mod_que = &bcb->bcb_rpt[page % bcb->bcb_count].bcb_page_mod; QUE mod_que = &bcb->bcb_rpt[page % bcb->bcb_count].bcb_page_mod;
@ -3424,9 +3433,9 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
} }
} }
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
if (que_inst == mod_que) { if (que_inst == mod_que) {
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
return; return;
} }
@ -3436,7 +3445,7 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
if (!(high->bdb_flags & BDB_dirty) if (!(high->bdb_flags & BDB_dirty)
|| (high->bdb_page == window->win_page)) || (high->bdb_page == window->win_page))
{ {
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
return; return;
} }
@ -3452,12 +3461,12 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
if (QUE_NOT_EMPTY(high->bdb_lower)) { if (QUE_NOT_EMPTY(high->bdb_lower)) {
const SSHORT relationship = related(low, high, PRE_SEARCH_LIMIT); const SSHORT relationship = related(low, high, PRE_SEARCH_LIMIT);
if (relationship == PRE_EXISTS) { if (relationship == PRE_EXISTS) {
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
return; return;
} }
else if (relationship == PRE_UNKNOWN) { else if (relationship == PRE_UNKNOWN) {
const SLONG high_page = high->bdb_page; const SLONG high_page = high->bdb_page;
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
if (!write_buffer if (!write_buffer
(tdbb, high, high_page, false, tdbb->tdbb_status_vector, true)) (tdbb, high, high_page, false, tdbb->tdbb_status_vector, true))
{ {
@ -3476,13 +3485,13 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
const SSHORT relationship = related(high, low, PRE_SEARCH_LIMIT); const SSHORT relationship = related(high, low, PRE_SEARCH_LIMIT);
if (relationship == PRE_EXISTS || relationship == PRE_UNKNOWN) { if (relationship == PRE_EXISTS || relationship == PRE_UNKNOWN) {
const SLONG low_page = low->bdb_page; const SLONG low_page = low->bdb_page;
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
if (!write_buffer if (!write_buffer
(tdbb, low, low_page, false, tdbb->tdbb_status_vector, true)) (tdbb, low, low_page, false, tdbb->tdbb_status_vector, true))
{ {
CCH_unwind(tdbb, true); CCH_unwind(tdbb, true);
} }
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
} }
} }
@ -3504,7 +3513,7 @@ static void check_precedence(thread_db* tdbb, WIN * window, SLONG page)
precedence->pre_flags = 0; precedence->pre_flags = 0;
QUE_INSERT(low->bdb_higher, precedence->pre_higher); QUE_INSERT(low->bdb_higher, precedence->pre_higher);
QUE_INSERT(high->bdb_lower, precedence->pre_lower); QUE_INSERT(high->bdb_lower, precedence->pre_lower);
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
} }
@ -3523,7 +3532,7 @@ static void clear_precedence(Database* dbb, BufferDesc* bdb)
**************************************/ **************************************/
SET_DBB(dbb); SET_DBB(dbb);
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
BufferControl* bcb = dbb->dbb_bcb; BufferControl* bcb = dbb->dbb_bcb;
/* Loop thru lower precedence buffers. If any can be downgraded, /* Loop thru lower precedence buffers. If any can be downgraded,
@ -3545,7 +3554,7 @@ static void clear_precedence(Database* dbb, BufferDesc* bdb)
} }
} }
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
} }
@ -3895,7 +3904,7 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
Database* dbb = tdbb->tdbb_database; Database* dbb = tdbb->tdbb_database;
SSHORT walk = dbb->dbb_bcb->bcb_free_minimum; SSHORT walk = dbb->dbb_bcb->bcb_free_minimum;
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
while (true) { while (true) {
find_page: find_page:
@ -3914,14 +3923,14 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
if (page != HEADER_PAGE) if (page != HEADER_PAGE)
#endif #endif
QUE_MOST_RECENTLY_USED(bdb->bdb_in_use); QUE_MOST_RECENTLY_USED(bdb->bdb_in_use);
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
const SSHORT latch_return = const SSHORT latch_return =
latch_bdb(tdbb, latch, bdb, page, latch_wait); latch_bdb(tdbb, latch, bdb, page, latch_wait);
if (latch_return) { if (latch_return) {
if (latch_return == 1) { if (latch_return == 1) {
return NULL; /* permitted timeout happened */ return NULL; /* permitted timeout happened */
} }
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
goto find_page; goto find_page;
} }
else { else {
@ -3951,7 +3960,7 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
} }
if (bdb->bdb_flags & BDB_db_dirty) { if (bdb->bdb_flags & BDB_db_dirty) {
THREAD_ENTER; THREAD_ENTER;
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
return bdb; return bdb;
} }
if (!--walk) { if (!--walk) {
@ -3963,14 +3972,14 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
if (bdb->bdb_flags & BDB_checkpoint) { if (bdb->bdb_flags & BDB_checkpoint) {
THREAD_ENTER; THREAD_ENTER;
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
return bdb; return bdb;
} }
} }
} }
THREAD_ENTER; THREAD_ENTER;
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
return NULL; return NULL;
} }
#endif #endif
@ -4027,7 +4036,7 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
} }
#endif #endif
//bdb->bdb_sequence = dbb->dbb_fetches++; //bdb->bdb_sequence = dbb->dbb_fetches++;
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
return bdb; return bdb;
} }
@ -4039,12 +4048,12 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
} }
BufferDesc* oldest = BLOCK(que_inst, BufferDesc*, bdb_in_use); BufferDesc* oldest = BLOCK(que_inst, BufferDesc*, bdb_in_use);
LATCH_MUTEX_ACQUIRE; // LATCH_MUTEX_ACQUIRE;
if (oldest->bdb_use_count if (oldest->bdb_use_count
|| (oldest->bdb_flags & BDB_free_pending) || (oldest->bdb_flags & BDB_free_pending)
|| !writeable(oldest)) || !writeable(oldest))
{ {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
continue; continue;
} }
@ -4056,11 +4065,11 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
oldest->bdb_flags &= ~BDB_prefetch; oldest->bdb_flags &= ~BDB_prefetch;
que_inst = que_inst->que_forward; que_inst = que_inst->que_forward;
QUE_MOST_RECENTLY_USED(oldest->bdb_in_use); QUE_MOST_RECENTLY_USED(oldest->bdb_in_use);
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
continue; continue;
} }
#endif #endif
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
#ifdef CACHE_WRITER #ifdef CACHE_WRITER
if (oldest->bdb_flags & (BDB_dirty | BDB_db_dirty)) { if (oldest->bdb_flags & (BDB_dirty | BDB_db_dirty)) {
bcb->bcb_flags |= BCB_free_pending; bcb->bcb_flags |= BCB_free_pending;
@ -4089,7 +4098,7 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
/* If the buffer selected is dirty, arrange to have it written. */ /* If the buffer selected is dirty, arrange to have it written. */
if (bdb->bdb_flags & (BDB_dirty | BDB_db_dirty)) { if (bdb->bdb_flags & (BDB_dirty | BDB_db_dirty)) {
BCB_MUTEX_RELEASE; // BCB_MUTEX_RELEASE;
#ifdef SUPERSERVER #ifdef SUPERSERVER
if (!write_buffer if (!write_buffer
(tdbb, bdb, bdb->bdb_page, true, tdbb->tdbb_status_vector, (tdbb, bdb, bdb->bdb_page, true, tdbb->tdbb_status_vector,
@ -4126,7 +4135,7 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
screwed up, the only precedence blocks that can still be hanging screwed up, the only precedence blocks that can still be hanging
around are ones cleared at AST level. */ around are ones cleared at AST level. */
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
while (QUE_NOT_EMPTY(bdb->bdb_higher)) { while (QUE_NOT_EMPTY(bdb->bdb_higher)) {
QUE que2 = bdb->bdb_higher.que_forward; QUE que2 = bdb->bdb_higher.que_forward;
Precedence* precedence = BLOCK(que2, Precedence*, pre_higher); Precedence* precedence = BLOCK(que2, Precedence*, pre_higher);
@ -4135,14 +4144,14 @@ static BufferDesc* get_buffer(thread_db* tdbb, SLONG page, LATCH latch, SSHORT l
precedence->pre_hi = (BufferDesc*) bcb->bcb_free; precedence->pre_hi = (BufferDesc*) bcb->bcb_free;
bcb->bcb_free = precedence; bcb->bcb_free = precedence;
} }
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
clear_precedence(dbb, bdb); clear_precedence(dbb, bdb);
/* remove the buffer from the "mod" queue and place it /* remove the buffer from the "mod" queue and place it
in it's new spot, provided it's not a negative (scratch) page */ in it's new spot, provided it's not a negative (scratch) page */
BCB_MUTEX_ACQUIRE; // BCB_MUTEX_ACQUIRE;
if (bdb->bdb_page >= 0) { if (bdb->bdb_page >= 0) {
QUE_DELETE(bdb->bdb_que); QUE_DELETE(bdb->bdb_que);
} }
@ -4202,7 +4211,7 @@ static SSHORT latch_bdb(
return -1; return -1;
} }
LATCH_MUTEX_ACQUIRE; // LATCH_MUTEX_ACQUIRE;
/* Handle the easy case first, no users of the buffer. */ /* Handle the easy case first, no users of the buffer. */
@ -4226,7 +4235,7 @@ static SSHORT latch_bdb(
case LATCH_none: case LATCH_none:
break; break;
} }
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
} }
@ -4248,7 +4257,7 @@ static SSHORT latch_bdb(
switch (type) { switch (type) {
case LATCH_none: case LATCH_none:
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
case LATCH_shared: case LATCH_shared:
@ -4286,7 +4295,7 @@ static SSHORT latch_bdb(
} }
++bdb->bdb_use_count; ++bdb->bdb_use_count;
bdb->bdb_shared[i] = tdbb; bdb->bdb_shared[i] = tdbb;
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
case LATCH_io: case LATCH_io:
@ -4298,7 +4307,7 @@ static SSHORT latch_bdb(
} }
++bdb->bdb_use_count; ++bdb->bdb_use_count;
bdb->bdb_io = tdbb; bdb->bdb_io = tdbb;
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
case LATCH_exclusive: case LATCH_exclusive:
@ -4315,7 +4324,7 @@ static SSHORT latch_bdb(
} }
++bdb->bdb_use_count; ++bdb->bdb_use_count;
bdb->bdb_exclusive = tdbb; bdb->bdb_exclusive = tdbb;
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
case LATCH_mark: case LATCH_mark:
@ -4327,7 +4336,7 @@ static SSHORT latch_bdb(
break; break;
} }
bdb->bdb_io = tdbb; bdb->bdb_io = tdbb;
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
default: default:
@ -4336,7 +4345,7 @@ static SSHORT latch_bdb(
/* If the caller doesn't want to wait for this latch, then return now. */ /* If the caller doesn't want to wait for this latch, then return now. */
if (latch_wait == 0) { if (latch_wait == 0) {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 1; return 1;
} }
@ -4380,7 +4389,7 @@ static SSHORT latch_bdb(
((lwt->lwt_flags & LWT_pending) && !timeout_occurred); ((lwt->lwt_flags & LWT_pending) && !timeout_occurred);
count = ISC_event_clear(event)) count = ISC_event_clear(event))
{ {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
THREAD_EXIT; THREAD_EXIT;
if (latch_wait == 1) { if (latch_wait == 1) {
timeout_occurred = timeout_occurred =
@ -4392,7 +4401,7 @@ static SSHORT latch_bdb(
NULL, event); NULL, event);
} }
THREAD_ENTER; THREAD_ENTER;
LATCH_MUTEX_ACQUIRE; // LATCH_MUTEX_ACQUIRE;
} }
bcb = dbb->dbb_bcb; /* Re-initialize */ bcb = dbb->dbb_bcb; /* Re-initialize */
@ -4401,7 +4410,7 @@ static SSHORT latch_bdb(
/* If the latch is not granted then a timeout must have occurred. */ /* If the latch is not granted then a timeout must have occurred. */
if ((lwt->lwt_flags & LWT_pending) && timeout_occurred) { if ((lwt->lwt_flags & LWT_pending) && timeout_occurred) {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
if (latch_wait == 1) { if (latch_wait == 1) {
IBERR_build_status(tdbb->tdbb_status_vector, isc_deadlock, 0); IBERR_build_status(tdbb->tdbb_status_vector, isc_deadlock, 0);
CCH_unwind(tdbb, true); CCH_unwind(tdbb, true);
@ -4412,12 +4421,12 @@ static SSHORT latch_bdb(
} }
if (bdb->bdb_page != page) { if (bdb->bdb_page != page) {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
release_bdb(tdbb, bdb, true, false, false); release_bdb(tdbb, bdb, true, false, false);
return -1; return -1;
} }
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return 0; return 0;
} }
@ -4463,8 +4472,10 @@ static SSHORT latch_bdb(
static SSHORT lock_buffer( static SSHORT lock_buffer(
thread_db* tdbb, thread_db* tdbb,
BufferDesc* bdb, SSHORT wait, SSHORT page_type) BufferDesc* bdb,
SSHORT wait,
SCHAR page_type)
{ {
/************************************** /**************************************
* *
@ -5034,7 +5045,7 @@ static void release_bdb(
**************************************/ **************************************/
SSHORT i; SSHORT i;
LATCH_MUTEX_ACQUIRE; // LATCH_MUTEX_ACQUIRE;
QUE wait_que = &bdb->bdb_waiters; QUE wait_que = &bdb->bdb_waiters;
@ -5060,7 +5071,7 @@ static void release_bdb(
bdb->bdb_shared[i] = tdbb; bdb->bdb_shared[i] = tdbb;
} }
else { else {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return; return;
} }
} }
@ -5128,7 +5139,7 @@ static void release_bdb(
switch (lwt->lwt_latch) { switch (lwt->lwt_latch) {
case LATCH_exclusive: case LATCH_exclusive:
if (bdb->bdb_use_count) { if (bdb->bdb_use_count) {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return; return;
} }
else { else {
@ -5136,7 +5147,7 @@ static void release_bdb(
bdb->bdb_exclusive = lwt->lwt_tdbb; bdb->bdb_exclusive = lwt->lwt_tdbb;
lwt->lwt_flags &= ~LWT_pending; lwt->lwt_flags &= ~LWT_pending;
ISC_event_post(&lwt->lwt_event); ISC_event_post(&lwt->lwt_event);
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return; return;
} }
@ -5196,11 +5207,11 @@ static void release_bdb(
} }
if (bdb->bdb_use_count || !repost) { if (bdb->bdb_use_count || !repost) {
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
return; return;
} }
LATCH_MUTEX_RELEASE; // LATCH_MUTEX_RELEASE;
if (bdb->bdb_ast_flags & BDB_blocking) if (bdb->bdb_ast_flags & BDB_blocking)
{ {
@ -5374,7 +5385,7 @@ static int write_buffer(
/* If there are buffers that must be written first, write them now. */ /* If there are buffers that must be written first, write them now. */
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
while (QUE_NOT_EMPTY(bdb->bdb_higher)) { while (QUE_NOT_EMPTY(bdb->bdb_higher)) {
BufferControl* bcb = dbb->dbb_bcb; /* Re-initialize in the loop */ BufferControl* bcb = dbb->dbb_bcb; /* Re-initialize in the loop */
@ -5389,7 +5400,7 @@ static int write_buffer(
else { else {
BufferDesc* hi_bdb = precedence->pre_hi; BufferDesc* hi_bdb = precedence->pre_hi;
const SLONG hi_page = hi_bdb->bdb_page; const SLONG hi_page = hi_bdb->bdb_page;
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
release_bdb(tdbb, bdb, false, false, false); release_bdb(tdbb, bdb, false, false, false);
const int write_status = const int write_status =
write_buffer(tdbb, hi_bdb, hi_page, write_thru, status, write_buffer(tdbb, hi_bdb, hi_page, write_thru, status,
@ -5406,11 +5417,11 @@ static int write_buffer(
if (latch_bdb(tdbb, LATCH_io, bdb, page, 1) == -1) { if (latch_bdb(tdbb, LATCH_io, bdb, page, 1) == -1) {
return 1; /* cache buffer reassigned, return 'write successful' */ return 1; /* cache buffer reassigned, return 'write successful' */
} }
PRE_MUTEX_ACQUIRE; // PRE_MUTEX_ACQUIRE;
} }
} }
PRE_MUTEX_RELEASE; // PRE_MUTEX_RELEASE;
#ifdef SUPERSERVER_V2 #ifdef SUPERSERVER_V2
/* Header page I/O is deferred until a dirty page, which was modified by a /* Header page I/O is deferred until a dirty page, which was modified by a

View File

@ -36,14 +36,14 @@ bool CCH_exclusive(Jrd::thread_db*, USHORT, SSHORT);
bool CCH_exclusive_attachment(Jrd::thread_db*, USHORT, SSHORT); bool CCH_exclusive_attachment(Jrd::thread_db*, USHORT, SSHORT);
void CCH_expand(Jrd::thread_db*, ULONG); void CCH_expand(Jrd::thread_db*, ULONG);
Ods::pag* CCH_fake(Jrd::thread_db*, Jrd::win*, SSHORT); Ods::pag* CCH_fake(Jrd::thread_db*, Jrd::win*, SSHORT);
Ods::pag* CCH_fetch(Jrd::thread_db*, Jrd::win*, USHORT, SSHORT, SSHORT, SSHORT, bool); Ods::pag* CCH_fetch(Jrd::thread_db*, Jrd::win*, USHORT, SCHAR, SSHORT, SSHORT, bool);
SSHORT CCH_fetch_lock(Jrd::thread_db*, Jrd::win*, USHORT, SSHORT, SSHORT, SSHORT); SSHORT CCH_fetch_lock(Jrd::thread_db*, Jrd::win*, USHORT, SSHORT, SSHORT, SCHAR);
void CCH_fetch_page(Jrd::thread_db*, Jrd::win*, SSHORT, bool); void CCH_fetch_page(Jrd::thread_db*, Jrd::win*, SSHORT, bool);
void CCH_fini(Jrd::thread_db*); void CCH_fini(Jrd::thread_db*);
void CCH_flush(Jrd::thread_db*, USHORT, SLONG); void CCH_flush(Jrd::thread_db*, USHORT, SLONG);
bool CCH_free_page(Jrd::thread_db*); bool CCH_free_page(Jrd::thread_db*);
SLONG CCH_get_incarnation(Jrd::win*); SLONG CCH_get_incarnation(Jrd::win*);
Ods::pag* CCH_handoff(Jrd::thread_db*, Jrd::win*, SLONG, SSHORT, SSHORT, SSHORT, SSHORT); Ods::pag* CCH_handoff(Jrd::thread_db*, Jrd::win*, SLONG, SSHORT, SCHAR, SSHORT, SSHORT);
void CCH_init(Jrd::thread_db*, ULONG); void CCH_init(Jrd::thread_db*, ULONG);
void CCH_mark(Jrd::thread_db*, Jrd::win*, USHORT); void CCH_mark(Jrd::thread_db*, Jrd::win*, USHORT);
void CCH_mark_must_write(Jrd::thread_db*, Jrd::win*); void CCH_mark_must_write(Jrd::thread_db*, Jrd::win*);
@ -64,27 +64,27 @@ bool CCH_write_all_shadows(Jrd::thread_db*, Jrd::Shadow*, Jrd::BufferDesc*,
/* macros for dealing with cache pages */ /* macros for dealing with cache pages */
inline Ods::pag* CCH_FETCH(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SSHORT page_type) inline Ods::pag* CCH_FETCH(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SCHAR page_type)
{ {
return CCH_fetch (tdbb, window, lock_type, page_type, 1, 1, true); return CCH_fetch (tdbb, window, lock_type, page_type, 1, 1, true);
} }
inline Ods::pag* CCH_FETCH_NO_SHADOW(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SSHORT page_type) inline Ods::pag* CCH_FETCH_NO_SHADOW(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SCHAR page_type)
{ {
return CCH_fetch (tdbb, window, lock_type, page_type, 1, 1, false); return CCH_fetch (tdbb, window, lock_type, page_type, 1, 1, false);
} }
inline Ods::pag* CCH_FETCH_NO_CHECKSUM(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SSHORT page_type) inline Ods::pag* CCH_FETCH_NO_CHECKSUM(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SCHAR page_type)
{ {
return CCH_fetch (tdbb, window, lock_type, page_type, 0, 1, true); return CCH_fetch (tdbb, window, lock_type, page_type, 0, 1, true);
} }
inline Ods::pag* CCH_FETCH_TIMEOUT(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SSHORT page_type, SSHORT latch_wait) inline Ods::pag* CCH_FETCH_TIMEOUT(Jrd::thread_db* tdbb, Jrd::win* window, USHORT lock_type, SCHAR page_type, SSHORT latch_wait)
{ {
return CCH_fetch (tdbb, window, lock_type, page_type, 0, latch_wait, true); return CCH_fetch (tdbb, window, lock_type, page_type, 0, latch_wait, true);
} }
inline SSHORT CCH_FETCH_LOCK(Jrd::thread_db* tdbb, Jrd::win * window, USHORT lock_type, SSHORT wait, SSHORT latch_wait, SSHORT page_type) inline SSHORT CCH_FETCH_LOCK(Jrd::thread_db* tdbb, Jrd::win * window, USHORT lock_type, SSHORT wait, SSHORT latch_wait, SCHAR page_type)
{ {
return CCH_fetch_lock(tdbb, window, lock_type, wait, latch_wait, page_type); return CCH_fetch_lock(tdbb, window, lock_type, wait, latch_wait, page_type);
} }
@ -114,17 +114,17 @@ inline void CCH_MARK_SYSTEM(Jrd::thread_db* tdbb, Jrd::win * window)
CCH_mark (tdbb, window, 1); CCH_mark (tdbb, window, 1);
} }
inline Ods::pag* CCH_HANDOFF(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SSHORT page_type) inline Ods::pag* CCH_HANDOFF(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SCHAR page_type)
{ {
return CCH_handoff (tdbb, window, page, lock, page_type, 1, 0); return CCH_handoff (tdbb, window, page, lock, page_type, 1, 0);
} }
inline Ods::pag* CCH_HANDOFF_TIMEOUT(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SSHORT page_type, SSHORT latch_wait) inline Ods::pag* CCH_HANDOFF_TIMEOUT(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SCHAR page_type, SSHORT latch_wait)
{ {
return CCH_handoff (tdbb, window, page, lock, page_type, latch_wait, 0); return CCH_handoff (tdbb, window, page, lock, page_type, latch_wait, 0);
} }
inline Ods::pag* CCH_HANDOFF_TAIL(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SSHORT page_type) inline Ods::pag* CCH_HANDOFF_TAIL(Jrd::thread_db* tdbb, Jrd::win* window, SLONG page, SSHORT lock, SCHAR page_type)
{ {
return CCH_handoff (tdbb, window, page, lock, page_type, 1, 1); return CCH_handoff (tdbb, window, page, lock, page_type, 1, 1);
} }
@ -157,12 +157,12 @@ inline void CCH_PREFETCH(Jrd::thread_db* tdbb, SLONG * pages, SSHORT count)
/* Flush flags */ /* Flush flags */
const int FLUSH_ALL = 1; /* flush all dirty buffers in cache */ const USHORT FLUSH_ALL = 1; /* flush all dirty buffers in cache */
const int FLUSH_RLSE = 2; /* release page locks after flush */ const USHORT FLUSH_RLSE = 2; /* release page locks after flush */
const int FLUSH_TRAN = 4; /* flush transaction dirty buffers from dirty btree */ const USHORT FLUSH_TRAN = 4; /* flush transaction dirty buffers from dirty btree */
const int FLUSH_SWEEP = 8; /* flush dirty buffers from garbage collection */ const USHORT FLUSH_SWEEP = 8; /* flush dirty buffers from garbage collection */
const int FLUSH_SYSTEM = 16; /* flush system transaction only from dirty btree */ const USHORT FLUSH_SYSTEM = 16; /* flush system transaction only from dirty btree */
const int FLUSH_FINI = (FLUSH_ALL | FLUSH_RLSE); const USHORT FLUSH_FINI = (FLUSH_ALL | FLUSH_RLSE);
#endif /* JRD_CCH_PROTO_H */ #endif /* JRD_CCH_PROTO_H */