2001-05-23 15:26:42 +02:00
|
|
|
/*
|
|
|
|
* PROGRAM: JRD Access Method
|
2003-11-07 09:06:35 +01:00
|
|
|
* MODULE: dbt.cpp
|
2001-05-23 15:26:42 +02:00
|
|
|
* DESCRIPTION: Debugging routines
|
|
|
|
*
|
|
|
|
* 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): ______________________________________.
|
|
|
|
*/
|
|
|
|
|
2001-07-29 19:42:23 +02:00
|
|
|
#include "firebird.h"
|
2004-04-29 00:43:34 +02:00
|
|
|
#include <stdio.h>
|
2001-05-23 15:26:42 +02:00
|
|
|
#include "../jrd/ibase.h"
|
2003-09-15 18:32:22 +02:00
|
|
|
// Those includes until the END comment comes from everything.h and was moved
|
|
|
|
// here when the file was removed.
|
|
|
|
// Most probably only a few of the includes are needed
|
|
|
|
#include "../jrd/common.h"
|
|
|
|
#include "../jrd/isc.h"
|
|
|
|
#include "../jrd/jrd.h"
|
|
|
|
#include "../jrd/lck.h"
|
|
|
|
#include "../jrd/ods.h"
|
|
|
|
#include "../jrd/cch.h"
|
|
|
|
#include "../jrd/all.h"
|
|
|
|
#include "../jrd/os/pio.h"
|
|
|
|
#include "../jrd/pag.h"
|
|
|
|
#include "../jrd/val.h"
|
|
|
|
#include "../jrd/exe.h"
|
|
|
|
#include "../jrd/req.h"
|
|
|
|
#include "../jrd/lls.h"
|
|
|
|
#include "../jrd/rse.h"
|
|
|
|
#include "../jrd/sbm.h"
|
|
|
|
#include "../jrd/tra.h"
|
|
|
|
#include "../jrd/sqz.h"
|
|
|
|
#include "../jrd/blb.h"
|
|
|
|
#include "../jrd/btr.h"
|
|
|
|
#include "../jrd/scl.h"
|
|
|
|
#include "../jrd/ext.h"
|
|
|
|
#include "../jrd/met.h"
|
|
|
|
#include "../jrd/sdw.h"
|
|
|
|
#include "../jrd/log.h"
|
|
|
|
#include "../jrd/intl.h"
|
|
|
|
#include "../jrd/intl_classes.h"
|
|
|
|
#include "../jrd/fil.h"
|
|
|
|
#include "../jrd/tpc.h"
|
|
|
|
#include "../jrd/rng.h"
|
|
|
|
#include "../jrd/svc.h"
|
|
|
|
#include "../jrd/blob_filter.h"
|
|
|
|
// END
|
2001-05-23 15:26:42 +02:00
|
|
|
#include "../jrd/dbg.h"
|
|
|
|
|
2003-09-01 09:58:04 +02:00
|
|
|
#define FLD(struct, string, field) string, (SCHAR*) OFFSET (struct, field), (SCHAR*) sizeof (((struct) NULL)->field)
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
|
2004-03-11 06:04:26 +01:00
|
|
|
typedef SCHAR* TEXT_PTR;
|
2001-05-23 15:26:42 +02:00
|
|
|
|
2004-03-11 06:04:26 +01:00
|
|
|
int* ptr;
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
TEXT_PTR dbt_window[] = {
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(WIN*, "Page: %ld", win_page),
|
|
|
|
FLD(WIN*, "Buffer: %x", win_buffer),
|
|
|
|
FLD(WIN*, "BufferDesc: %x", win_bdb),
|
|
|
|
FLD(WIN*, "Scans: %d", win_scans),
|
|
|
|
FLD(WIN*, "Flags: %x", win_flags),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
dbt_record_param[] = {
|
|
|
|
FLD(record_param*, "Relation %x", rpb_relation),
|
|
|
|
FLD(record_param*, "Number %ld", rpb_number),
|
|
|
|
FLD(record_param*, "Trans %ld", rpb_transaction_nr),
|
|
|
|
FLD(record_param*, "Page %ld", rpb_page),
|
|
|
|
FLD(record_param*, "Line %x", rpb_line),
|
|
|
|
FLD(record_param*, "Back page %ld", rpb_b_page),
|
|
|
|
FLD(record_param*, "Line %x", rpb_b_line),
|
|
|
|
FLD(record_param*, "Fragment page %ld", rpb_f_page),
|
|
|
|
FLD(record_param*, "Line %x", rpb_f_line),
|
|
|
|
FLD(record_param*, "Format %x", rpb_format_number),
|
|
|
|
FLD(record_param*, "Address: %x ", rpb_address),
|
|
|
|
FLD(record_param*, "Length %x", rpb_length),
|
|
|
|
FLD(record_param*, "Record %x", rpb_record),
|
|
|
|
FLD(record_param*, "Flags %x", rpb_flags),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
static TEXT_PTR dbb_stuff[] = {
|
|
|
|
"DATABASE",
|
2004-03-11 06:04:26 +01:00
|
|
|
FLD(Database*, "BCB: %x", dbb_bcb),
|
|
|
|
FLD(Database*, "Relations: %x", dbb_relations),
|
|
|
|
FLD(Database*, "Lock: %x", dbb_lock),
|
|
|
|
FLD(Database*, "File: %x", dbb_file),
|
|
|
|
FLD(Database*, "Permanent: %x", dbb_permanent),
|
|
|
|
FLD(Database*, "Pools: %x", dbb_pools),
|
|
|
|
FLD(Database*, "Page_size: %d", dbb_page_size),
|
|
|
|
FLD(Database*, "dp_per_pp: %d", dbb_dp_per_pp),
|
2001-05-23 15:26:42 +02:00
|
|
|
0
|
2001-12-24 03:51:06 +01:00
|
|
|
},
|
|
|
|
vec[] = {
|
2002-02-16 04:05:21 +01:00
|
|
|
"VECTOR",
|
2001-12-24 03:51:06 +01:00
|
|
|
// TMN: FIXFIX! John?
|
|
|
|
// FLD(VEC, "Count %d", vec_count),
|
|
|
|
"Count %d", (SCHAR*)4, (SCHAR*)4,
|
|
|
|
0
|
|
|
|
},
|
|
|
|
vcl[] = {
|
|
|
|
"VECTOR OF ULONGS",
|
|
|
|
// TMN: FIXFIX! John?
|
|
|
|
// FLD(VCL, "Count %d", vcl_count),
|
|
|
|
"Count %d", (SCHAR*)4, (SCHAR*)4,
|
|
|
|
0
|
|
|
|
};
|
|
|
|
/*frb[] = {
|
|
|
|
"FREE",
|
|
|
|
// TMN: FIXFIX! John?
|
|
|
|
// FLD(FRB, "Next %x", frb_next),
|
|
|
|
"Next %x", (SCHAR*)4, (SCHAR*)4,
|
|
|
|
0
|
|
|
|
};*/
|
|
|
|
/*static TEXT_PTR hnk[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"HUNK",
|
|
|
|
FLD(HNK, "Addr: %x", hnk_address),
|
|
|
|
FLD(HNK, "Len: %d", hnk_length),
|
2001-12-24 03:51:06 +01:00
|
|
|
FLD(HNK, "Next: %x", hnk_next),
|
|
|
|
0
|
|
|
|
};
|
|
|
|
*/
|
|
|
|
/*static TEXT_PTR plb[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"POOL",
|
|
|
|
FLD(PLB, "Id: %d", plb_pool_id),
|
|
|
|
FLD(PLB, "Free: %x", plb_free),
|
2001-12-24 03:51:06 +01:00
|
|
|
FLD(PLB, "Hunk: %x", plb_hunks),
|
|
|
|
0
|
|
|
|
};*/
|
|
|
|
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR BufferControl[] = {
|
2001-12-24 03:51:06 +01:00
|
|
|
"BUFFER CONTROL",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(BufferControl*, "Count: %x", bcb_count),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
BufferDesc[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"BUFFER DESCRIPTOR",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(BufferDesc*, "Page: %ld", bdb_page),
|
|
|
|
FLD(BufferDesc*, "Lock: %x", bdb_lock),
|
|
|
|
FLD(BufferDesc*, "Buffer: %x", bdb_buffer),
|
|
|
|
FLD(BufferDesc*, "Use count: %x", bdb_use_count),
|
|
|
|
FLD(BufferDesc*, "Flags: %x", bdb_flags),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
Precedence[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"PRECEDENCE",
|
2004-02-20 07:43:27 +01:00
|
|
|
FLD(Precedence*, "Flags: %x", pre_flags),
|
|
|
|
FLD(Precedence*, "Low: %x", pre_low),
|
|
|
|
FLD(Precedence*, "High: %x", pre_hi),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
Lock[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"LOCK",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(Lock*, "Parent: %x", lck_parent),
|
|
|
|
FLD(Lock*, "Object: %x", lck_object),
|
|
|
|
FLD(Lock*, "Type: %x", lck_type),
|
|
|
|
FLD(Lock*, "Physical: %x", lck_physical),
|
|
|
|
FLD(Lock*, "Logical: %x", lck_logical),
|
|
|
|
FLD(Lock*, "Length: %x", lck_length),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-02-20 07:43:27 +01:00
|
|
|
jrd_file[] = {
|
2001-12-24 03:51:06 +01:00
|
|
|
"FILE",
|
2004-02-20 07:43:27 +01:00
|
|
|
FLD(jrd_file*, "File desc: %x", fil_desc),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-19 07:14:53 +01:00
|
|
|
PageControl[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"PAGE CONTROL",
|
2004-03-19 07:14:53 +01:00
|
|
|
FLD(PageControl*, "High water: %d", pgc_high_water),
|
|
|
|
FLD(PageControl*, "Pages/PIP: %x", pgc_ppp),
|
|
|
|
FLD(PageControl*, "First PIP: %x", pgc_pip),
|
|
|
|
FLD(PageControl*, "Bytes/PIP: %x", pgc_bytes),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2003-02-14 00:01:56 +01:00
|
|
|
|
|
|
|
jrd_rel[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"RELATION",
|
2004-01-03 11:59:52 +01:00
|
|
|
FLD(jrd_rel*, "%s", rel_name),
|
|
|
|
FLD(jrd_rel*, "Id: %d", rel_id),
|
|
|
|
FLD(jrd_rel*, "Current format: %x", rel_current_format),
|
|
|
|
FLD(jrd_rel*, "Formats: %x", rel_formats),
|
|
|
|
FLD(jrd_rel*, "Pages: %x", rel_pages),
|
|
|
|
FLD(jrd_rel*, "Root: %ld", rel_index_root),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-30 06:10:52 +02:00
|
|
|
Format[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"FORMAT",
|
2004-03-30 06:10:52 +02:00
|
|
|
FLD(Format*, "Count: %d", fmt_count),
|
|
|
|
FLD(Format*, "Length: %d", fmt_length),
|
|
|
|
FLD(Format*, "Version: %d", fmt_version),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2003-02-14 00:01:56 +01:00
|
|
|
jrd_req[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"REQUEST",
|
2004-01-03 11:59:52 +01:00
|
|
|
FLD(jrd_req*, "COUNT: %x", req_count),
|
|
|
|
FLD(jrd_req*, "Impure: %x", req_impure_size),
|
|
|
|
FLD(jrd_req*, "Incarn: %x", req_incarnation),
|
|
|
|
FLD(jrd_req*, "Pool: %x", req_pool),
|
|
|
|
FLD(jrd_req*, "Sub req: %x", req_sub_requests),
|
|
|
|
FLD(jrd_req*, "Trans: %x", req_transaction),
|
|
|
|
FLD(jrd_req*, "Next req: %x", req_request),
|
|
|
|
FLD(jrd_req*, "Msg: %x", req_message),
|
|
|
|
FLD(jrd_req*, "Length: %x", req_length),
|
|
|
|
FLD(jrd_req*, "#msgs: %x", req_nmsgs),
|
|
|
|
FLD(jrd_req*, "Max send: %x", req_msend),
|
|
|
|
FLD(jrd_req*, "Max receive: %x", req_mreceive),
|
|
|
|
FLD(jrd_req*, "Top: %x", req_top_node),
|
|
|
|
FLD(jrd_req*, "Next: %x", req_next),
|
|
|
|
FLD(jrd_req*, "Label: %x", req_label),
|
|
|
|
FLD(jrd_req*, "Op: %x", req_operation),
|
|
|
|
FLD(jrd_req*, "Flags: %x", req_flags),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2003-02-14 00:01:56 +01:00
|
|
|
jrd_tra[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"TRANSACTION",
|
2004-01-03 11:59:52 +01:00
|
|
|
FLD(jrd_tra*, "Number: %ld", tra_number),
|
|
|
|
FLD(jrd_tra*, "Oldest: %ld", tra_oldest),
|
|
|
|
FLD(jrd_tra*, "Next: %x", tra_next),
|
|
|
|
FLD(jrd_tra*, "Pool: %x", tra_pool),
|
|
|
|
FLD(jrd_tra*, "Lock: %x", tra_lock),
|
|
|
|
FLD(jrd_tra*, "Locks: %x", tra_relation_locks),
|
|
|
|
FLD(jrd_tra*, "Flags: %x", tra_flags),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2003-02-14 00:01:56 +01:00
|
|
|
jrd_nod[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"NODE",
|
2004-01-13 10:52:19 +01:00
|
|
|
FLD(jrd_nod*, "Type: %x", nod_type),
|
|
|
|
FLD(jrd_nod*, "Impure: %x", nod_impure),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
|
|
|
lls[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"LINKED LIST STACK",
|
|
|
|
FLD(LLS, "Object: %x", lls_object),
|
2001-12-24 03:51:06 +01:00
|
|
|
FLD(LLS, "Next: %x", lls_next),
|
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
VerbAction[] = {
|
2001-12-24 03:51:06 +01:00
|
|
|
"RECORD",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(Record*, "Format: %x", rec_format),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-28 11:10:30 +02:00
|
|
|
RecordSource[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"RECORD SOURCE BLOCK",
|
2004-03-28 11:10:30 +02:00
|
|
|
FLD(RecordSource*, "Type: %x", rsb_type),
|
|
|
|
FLD(RecordSource*, "Stream: %x", rsb_stream),
|
|
|
|
FLD(RecordSource*, "Relation: %x", rsb_relation),
|
|
|
|
FLD(RecordSource*, "Next: %x", rsb_next),
|
|
|
|
FLD(RecordSource*, "Count: %x", rsb_count),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-28 11:10:30 +02:00
|
|
|
OptimizerBlk[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"OPTIMIZER",
|
2004-03-28 11:10:30 +02:00
|
|
|
FLD(OptimizerBlk*, "CompilerScratch*: %x", opt_csb),
|
|
|
|
FLD(OptimizerBlk*, "Cnt: %x", opt_count),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
BitmapSegment[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"BIT MAP SEGMENT",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(BitmapSegment*, "Min: %x", bms_min),
|
|
|
|
FLD(BitmapSegment*, "Max: %x", bms_max),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
DeferredWork[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"DEFERRED WORK BLOCK",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(DeferredWork*, "type: %d", dfw_type),
|
|
|
|
FLD(DeferredWork*, "next: %x", dfw_next),
|
|
|
|
FLD(DeferredWork*, "name: %s", dfw_name),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-19 07:14:53 +01:00
|
|
|
TemporaryField[] = {
|
2004-03-11 06:04:26 +01:00
|
|
|
"TEMPORARY FIELD BLOCK",
|
2004-03-19 07:14:53 +01:00
|
|
|
FLD(TemporaryField*, "id: %d", tfb_id),
|
|
|
|
FLD(TemporaryField*, "dtype: %d", tfb_desc.dsc_dtype),
|
|
|
|
FLD(TemporaryField*, "scale: %d", tfb_desc.dsc_scale),
|
|
|
|
FLD(TemporaryField*, "len: %d", tfb_desc.dsc_length),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
|
|
|
str[] = {
|
|
|
|
"string",
|
|
|
|
FLD(STR, "length: %d", str_length),
|
|
|
|
0
|
|
|
|
},
|
2004-03-28 11:10:30 +02:00
|
|
|
DataComprControl[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"DATA COMPRESSION CONTROL",
|
2004-03-28 11:10:30 +02:00
|
|
|
FLD(DataComprControl*, "next: %x", dcc_next),
|
|
|
|
FLD(DataComprControl*, "end: %x", dcc_end),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
SparseBitmap[] = {
|
|
|
|
"SPARSE BIT MAP",
|
|
|
|
FLD(SparseBitmap*, "state: %d", sbm_state),
|
|
|
|
FLD(SparseBitmap*, "count: %d", sbm_count),
|
|
|
|
FLD(SparseBitmap*, "used: %d", sbm_used),
|
|
|
|
FLD(SparseBitmap*, "high water: %d", sbm_high_water),
|
|
|
|
FLD(SparseBitmap*, "number: %d", sbm_number),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-18 06:56:06 +01:00
|
|
|
SortMap[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"SORT MAP",
|
2004-03-18 06:56:06 +01:00
|
|
|
FLD(SortMap*, "count: %d", smb_count),
|
|
|
|
FLD(SortMap*, "keys: %d", smb_keys),
|
|
|
|
FLD(SortMap*, "length: %d", smb_length),
|
|
|
|
FLD(SortMap*, "sort key: %x", smb_key_desc),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
|
|
|
blb[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"BLOB",
|
2004-02-20 07:43:27 +01:00
|
|
|
FLD(blb*, "Relation: %x", blb_relation),
|
|
|
|
FLD(blb*, "Count: %d", blb_count),
|
|
|
|
FLD(blb*, "Length: %d", blb_length),
|
|
|
|
FLD(blb*, "Max seg: %d", blb_max_segment),
|
|
|
|
FLD(blb*, "Flags: %x", blb_flags),
|
|
|
|
FLD(blb*, "Trans: %x", blb_transaction),
|
|
|
|
FLD(blb*, "Next: %x", blb_segment),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-19 07:14:53 +01:00
|
|
|
IndexRetrieval[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
"INDEX RETRIEVAL",
|
2004-03-19 07:14:53 +01:00
|
|
|
FLD(IndexRetrieval*, "index: %d", irb_index),
|
|
|
|
FLD(IndexRetrieval*, "relation: %x", irb_relation),
|
|
|
|
FLD(IndexRetrieval*, "lower bounds: %d", irb_lower_count),
|
|
|
|
FLD(IndexRetrieval*, "upper boudns: %d", irb_upper_count),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
},
|
2004-03-19 07:14:53 +01:00
|
|
|
BlobControl[] = {
|
2001-12-24 03:51:06 +01:00
|
|
|
"BLOB CONTROL", 0
|
|
|
|
};
|
|
|
|
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR SecurityClass[] = { "SECURITY CLASS", 0};
|
|
|
|
static TEXT_PTR jrd_fld[] = { "FIELD", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR ExternalFile[] = { "EXTERNAL FILE", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR merge_file[] = { "MERGE EQUIVALENCE FILE BLOCK", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR River[] = { "SORT MERGE RIVER", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR UserId[] = { "USER IDENTIFICATION BLOCK ", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR Attachment[] = { "ATTACHMENT BLOCK", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR Symbol[] = { "SYMBOL", 0};
|
2004-03-30 06:10:52 +02:00
|
|
|
static TEXT_PTR UserFunction[] = { "FUNCTION", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR IndexedRelationship[] = { "INDEXED RELATIONSHIP", 0};
|
|
|
|
static TEXT_PTR AccessItem[] = { "ACCESS", 0};
|
2004-02-20 07:43:27 +01:00
|
|
|
static TEXT_PTR Resource[] = { "RESOURCE", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR IndexLock[] = { "INDEX LOCK", 0};
|
2004-02-20 07:43:27 +01:00
|
|
|
static TEXT_PTR Shadow[] = { "SHADOW", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR Savepoint[] = { "SAVE POINT", 0};
|
|
|
|
static TEXT_PTR VerbAction[] = { "VERB", 0};
|
|
|
|
static TEXT_PTR BlockingThread[] = { "BLOCKED THREAD", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR BlobFilter[] = { "BLOB FILTER", 0};
|
|
|
|
static TEXT_PTR ArrayField[] = { "ARRAY DESCRIPTION", 0};
|
2004-02-20 07:43:27 +01:00
|
|
|
static TEXT_PTR blb_map[] = { "MAP BLOCK", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR fblog[] = { "LOG BLOCK", 0};
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR dir_list[] = { "DIR LIST BLOCK", 0};
|
2004-03-11 06:04:26 +01:00
|
|
|
static TEXT_PTR jrd_prc[] =
|
|
|
|
{
|
2001-12-24 03:51:06 +01:00
|
|
|
"PROCEDURE",
|
2004-01-03 11:59:52 +01:00
|
|
|
FLD(jrd_prc*, "%s", prc_name),
|
2004-03-11 06:04:26 +01:00
|
|
|
FLD(jrd_prc*, "Id: %d", prc_id), 0
|
|
|
|
};
|
2001-12-24 03:51:06 +01:00
|
|
|
static TEXT_PTR prm[] = { "PARAMETER", FLD(PRM, "%s", prm_name), 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR IndexBlock[] = { "INDEX BLOCK", 0};
|
|
|
|
static TEXT_PTR Bookmark[] = { "BOOKMARK BLOCK", 0};
|
|
|
|
static TEXT_PTR RefreshRange[] = { "REFRESH RANGE BLOCK", 0};
|
|
|
|
static TEXT_PTR TxPageCache[] = { "TIP CACHE BLOCK", 0};
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR PsqlException[] = { "EXCEPTION LIST BLOCK", 0};
|
|
|
|
static TEXT_PTR OptimizerBlk[] = { "OPTIMIZATION BLOCK", 0};
|
2004-02-20 07:43:27 +01:00
|
|
|
static TEXT_PTR Prefetch[] = { "PRF", 0};
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR RecordSelExpr[] = { "RECORD SELECTION EXPRESSION", 0};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR Literal[] = { "LITERAL", 0};
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR AggregateSort[] = { "AggregateSort", 0};
|
|
|
|
//static TEXT_PTR srl[] = { "SRL", 0}; // Obsolete.
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
/* xxx
|
|
|
|
x [] = {
|
|
|
|
"x",
|
|
|
|
FLD (x, "x: %x", x),
|
|
|
|
0},
|
|
|
|
*/
|
2004-03-28 11:10:30 +02:00
|
|
|
static TEXT_PTR CompilerScratch[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
"COMPILE SCRATCH BLOCK",
|
2004-03-28 11:10:30 +02:00
|
|
|
FLD(CompilerScratch*, "Count: %x", csb_count),
|
|
|
|
FLD(CompilerScratch*, "Node: %x", csb_node),
|
|
|
|
FLD(CompilerScratch*, "Streams: %x", csb_n_stream),
|
|
|
|
FLD(CompilerScratch*, "Running: %x", csb_running),
|
|
|
|
FLD(CompilerScratch*, "BLR: %x", csb_blr),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
2002-06-04 21:56:16 +02:00
|
|
|
|
2001-12-24 03:51:06 +01:00
|
|
|
static TEXT_PTR texttype[] = {
|
2002-06-04 21:56:16 +02:00
|
|
|
/* "INTL TEXT OBJECT",
|
2001-05-23 15:26:42 +02:00
|
|
|
FLD(TEXTTYPE, "Name: %s", texttype_name),
|
|
|
|
FLD(TEXTTYPE, "Vers: %d", texttype_version),
|
|
|
|
FLD(TEXTTYPE, "ID: %d", texttype_type),
|
|
|
|
FLD(TEXTTYPE, "CS: %d", texttype_character_set),
|
|
|
|
FLD(TEXTTYPE, "Cntry:%d", texttype_country),
|
2002-06-04 21:56:16 +02:00
|
|
|
FLD(TEXTTYPE, "Flags:%d", texttype_flags),*/
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
|
|
|
static TEXT_PTR charset[] = {
|
2002-06-04 21:56:16 +02:00
|
|
|
/* "INTL Character Set",
|
2004-03-11 06:04:26 +01:00
|
|
|
FLD(charset*, "Name: %s", charset_name),
|
|
|
|
FLD(charset*, "Vers: %d", charset_version),
|
|
|
|
FLD(charset*, "ID: %d", charset_id),
|
|
|
|
FLD(charset*, "B/Ch: %d", charset_max_bytes_per_char),
|
|
|
|
FLD(charset*, "B/Ch: %d", charset_min_bytes_per_char),
|
|
|
|
FLD(charset*, "Flags:%d", charset_flags), */
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
|
|
|
static TEXT_PTR csconvert[] = {
|
2002-06-04 21:56:16 +02:00
|
|
|
/* "INTL Character set converter",
|
2004-03-11 06:04:26 +01:00
|
|
|
FLD(csconvert*, "Name: %s", csconvert_name),
|
|
|
|
FLD(csconvert*, "from: %d", csconvert_from),
|
|
|
|
FLD(csconvert*, "to: %d", csconvert_to), */
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
2004-03-11 06:04:26 +01:00
|
|
|
static TEXT_PTR thread_db[] = {
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
"THREAD DATA BLOCK",
|
2004-03-11 06:04:26 +01:00
|
|
|
FLD(thread_db*, "Status vec: %x", tdbb_status_vector),
|
|
|
|
FLD(thread_db*, "Default: %x", tdbb_default),
|
2001-12-24 03:51:06 +01:00
|
|
|
0
|
|
|
|
};
|
2004-03-18 06:56:06 +01:00
|
|
|
static TEXT_PTR Service[] = { "SERVICE MANAGER BLOCK", 0};
|
|
|
|
static TEXT_PTR LatchWait[] = { "LATCH WAIT BLOCK", 0};
|
|
|
|
static TEXT_PTR ViewContext[] = { "VIEW CONTEXT BLOCK", 0};
|
2004-03-19 07:14:53 +01:00
|
|
|
static TEXT_PTR SaveRecordParam[] = { "RPB BLOCK", 0};
|
2001-12-24 03:51:06 +01:00
|
|
|
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
static int (*dbg_all) (), (*dbg_block) (), (*dbg_examine) (), (*dbg_eval) (),
|
|
|
|
(*dbg_open) (), (*dbg_close) (), (*dbg_pool) (), (*dbg_pretty) (),
|
|
|
|
(*dbg_window) (), (*dbg_rpb) (), (*dbg_bdbs) (), (*dbg_analyze) (),
|
|
|
|
(*dbg_check) (), (*dmp_page) (), (*dmp_active) (), (*dmp_dirty) (),
|
|
|
|
(*dbg_verify) ();
|
2004-03-19 07:14:53 +01:00
|
|
|
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
struct symb dbt_symbols[] = {
|
2001-07-29 19:42:23 +02:00
|
|
|
{"blk", &dbg_block, symb_printer, sizeof(int)},
|
|
|
|
{"ev", &dbg_eval, symb_printer, sizeof(int)},
|
|
|
|
{"ex", &dbg_examine, symb_printer, sizeof(int)},
|
|
|
|
{"dump", &dmp_page, symb_printer, sizeof(SLONG)},
|
|
|
|
{"pool", &dbg_pool, symb_printer, 0},
|
|
|
|
{"pretty", &dbg_pretty, symb_printer, 0},
|
|
|
|
{"analyze", &dbg_analyze, symb_printer, 0},
|
|
|
|
{"window", &dbg_window, symb_printer, 0},
|
|
|
|
{"rpb", &dbg_rpb, symb_printer, 0},
|
|
|
|
{"check", &dbg_check, symb_printer, 0},
|
|
|
|
|
|
|
|
{"dirty", &dmp_dirty, symb_routine, 0},
|
|
|
|
{"active", &dmp_active, symb_routine, 0},
|
|
|
|
{"all", &dbg_all, symb_routine, 0},
|
|
|
|
{"open", &dbg_open, symb_routine, 0},
|
|
|
|
{"close", &dbg_close, symb_routine, 0},
|
|
|
|
{"bdbs", &dbg_bdbs, symb_routine, 0},
|
|
|
|
{"verify", &dbg_verify, symb_routine, 0},
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
/*
|
2004-03-19 07:14:53 +01:00
|
|
|
#define SYM(struct, name) "name", OFFSET (struct, name), 0, symb_offset, sizeof (((struct) NULL)->name),
|
2004-03-11 06:04:26 +01:00
|
|
|
"Database", &Database, symb_absolute, sizeof(Database),
|
|
|
|
SYM (Database*, dbb_bcb)
|
|
|
|
SYM (Database*, dbb_relations)
|
|
|
|
SYM (Database*, dbb_pools)
|
|
|
|
SYM (Database*, dbb_requests)
|
2001-05-23 15:26:42 +02:00
|
|
|
SYM (REL, rel_formats)
|
|
|
|
SYM (REL, rel_pages)
|
2004-01-03 11:59:52 +01:00
|
|
|
SYM (jrd_req*, req_top_node)
|
|
|
|
SYM (jrd_req*, req_next)
|
2001-05-23 15:26:42 +02:00
|
|
|
*/
|
2003-09-01 09:58:04 +02:00
|
|
|
{NULL, 0, symb_routine, 0}
|
2001-05-23 15:26:42 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#define BLKDEF(type, name, tail) (TEXT*) name,
|
|
|
|
|
2004-03-11 06:04:26 +01:00
|
|
|
#define Database dbb_stuff
|
2001-05-23 15:26:42 +02:00
|
|
|
|
2004-03-11 06:04:26 +01:00
|
|
|
TEXT* dbt_blocks[] =
|
|
|
|
{
|
|
|
|
0,
|
2001-05-23 15:26:42 +02:00
|
|
|
#include "../jrd/blk.h"
|
|
|
|
0
|
|
|
|
};
|
2001-12-24 03:51:06 +01:00
|
|
|
#undef BLKDEF
|
2001-05-23 15:26:42 +02:00
|
|
|
|
|
|
|
|
2001-12-24 03:51:06 +01:00
|
|
|
|
|
|
|
const char* DBT_jrd_type_map(int type)
|
|
|
|
{
|
|
|
|
#define BLKDEF(enum_c, str_c, ext) case enum_c: return str_c[0];
|
2004-02-20 07:43:27 +01:00
|
|
|
switch (type)
|
2001-12-24 03:51:06 +01:00
|
|
|
{
|
|
|
|
#include "../jrd/blk.h"
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
#undef BLKDEF
|
|
|
|
return "Uknown Jrd Obj";
|
|
|
|
}
|
|
|
|
|
|
|
|
void MP_GDB_print(MemoryPool *p)
|
|
|
|
{
|
|
|
|
p->print_contents(stdout, DBT_jrd_type_map);
|
|
|
|
}
|
|
|
|
|