mirror of
https://github.com/MariaDB/server.git
synced 2025-01-23 23:34:34 +01:00
558 lines
14 KiB
C
558 lines
14 KiB
C
/*-
|
|
* See the file LICENSE for redistribution information.
|
|
*
|
|
* Copyright (c) 1996-2005
|
|
* Sleepycat Software. All rights reserved.
|
|
*
|
|
* $Id: lock_stat.c,v 12.11 2005/10/07 20:21:31 ubell Exp $
|
|
*/
|
|
|
|
#include "db_config.h"
|
|
|
|
#ifndef NO_SYSTEM_INCLUDES
|
|
#include <sys/types.h>
|
|
#include <string.h>
|
|
#if TIME_WITH_SYS_TIME
|
|
#include <sys/time.h>
|
|
#include <time.h>
|
|
#else
|
|
#if HAVE_SYS_TIME_H
|
|
#include <sys/time.h>
|
|
#else
|
|
#include <time.h>
|
|
#endif
|
|
#endif
|
|
|
|
#include <ctype.h>
|
|
#endif
|
|
|
|
#include "db_int.h"
|
|
#include "dbinc/db_shash.h"
|
|
#include "dbinc/db_page.h"
|
|
#include "dbinc/lock.h"
|
|
#include "dbinc/log.h"
|
|
#include "dbinc/db_am.h"
|
|
|
|
#ifdef HAVE_STATISTICS
|
|
static void __lock_dump_locker
|
|
__P((DB_ENV *, DB_MSGBUF *, DB_LOCKTAB *, DB_LOCKER *));
|
|
static void __lock_dump_object __P((DB_LOCKTAB *, DB_MSGBUF *, DB_LOCKOBJ *));
|
|
static int __lock_print_all __P((DB_ENV *, u_int32_t));
|
|
static int __lock_print_stats __P((DB_ENV *, u_int32_t));
|
|
static void __lock_print_header __P((DB_ENV *));
|
|
static int __lock_stat __P((DB_ENV *, DB_LOCK_STAT **, u_int32_t));
|
|
|
|
/*
|
|
* __lock_stat_pp --
|
|
* DB_ENV->lock_stat pre/post processing.
|
|
*
|
|
* PUBLIC: int __lock_stat_pp __P((DB_ENV *, DB_LOCK_STAT **, u_int32_t));
|
|
*/
|
|
int
|
|
__lock_stat_pp(dbenv, statp, flags)
|
|
DB_ENV *dbenv;
|
|
DB_LOCK_STAT **statp;
|
|
u_int32_t flags;
|
|
{
|
|
DB_THREAD_INFO *ip;
|
|
int ret;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
ENV_REQUIRES_CONFIG(dbenv,
|
|
dbenv->lk_handle, "DB_ENV->lock_stat", DB_INIT_LOCK);
|
|
|
|
if ((ret = __db_fchk(dbenv,
|
|
"DB_ENV->lock_stat", flags, DB_STAT_CLEAR)) != 0)
|
|
return (ret);
|
|
|
|
ENV_ENTER(dbenv, ip);
|
|
REPLICATION_WRAP(dbenv, (__lock_stat(dbenv, statp, flags)), ret);
|
|
ENV_LEAVE(dbenv, ip);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __lock_stat --
|
|
* DB_ENV->lock_stat.
|
|
*/
|
|
static int
|
|
__lock_stat(dbenv, statp, flags)
|
|
DB_ENV *dbenv;
|
|
DB_LOCK_STAT **statp;
|
|
u_int32_t flags;
|
|
{
|
|
DB_LOCKREGION *region;
|
|
DB_LOCKTAB *lt;
|
|
DB_LOCK_STAT *stats, tmp;
|
|
int ret;
|
|
|
|
*statp = NULL;
|
|
lt = dbenv->lk_handle;
|
|
|
|
if ((ret = __os_umalloc(dbenv, sizeof(*stats), &stats)) != 0)
|
|
return (ret);
|
|
|
|
/* Copy out the global statistics. */
|
|
LOCK_SYSTEM_LOCK(dbenv);
|
|
|
|
region = lt->reginfo.primary;
|
|
memcpy(stats, ®ion->stat, sizeof(*stats));
|
|
stats->st_locktimeout = region->lk_timeout;
|
|
stats->st_txntimeout = region->tx_timeout;
|
|
|
|
__mutex_set_wait_info(dbenv, region->mtx_region,
|
|
&stats->st_region_wait, &stats->st_region_nowait);
|
|
stats->st_regsize = lt->reginfo.rp->size;
|
|
if (LF_ISSET(DB_STAT_CLEAR)) {
|
|
tmp = region->stat;
|
|
memset(®ion->stat, 0, sizeof(region->stat));
|
|
__mutex_clear(dbenv, region->mtx_region);
|
|
|
|
region->stat.st_id = tmp.st_id;
|
|
region->stat.st_cur_maxid = tmp.st_cur_maxid;
|
|
region->stat.st_maxlocks = tmp.st_maxlocks;
|
|
region->stat.st_maxlockers = tmp.st_maxlockers;
|
|
region->stat.st_maxobjects = tmp.st_maxobjects;
|
|
region->stat.st_nlocks =
|
|
region->stat.st_maxnlocks = tmp.st_nlocks;
|
|
region->stat.st_nlockers =
|
|
region->stat.st_maxnlockers = tmp.st_nlockers;
|
|
region->stat.st_nobjects =
|
|
region->stat.st_maxnobjects = tmp.st_nobjects;
|
|
region->stat.st_nmodes = tmp.st_nmodes;
|
|
}
|
|
|
|
LOCK_SYSTEM_UNLOCK(dbenv);
|
|
|
|
*statp = stats;
|
|
return (0);
|
|
}
|
|
|
|
/*
|
|
* __lock_stat_print_pp --
|
|
* DB_ENV->lock_stat_print pre/post processing.
|
|
*
|
|
* PUBLIC: int __lock_stat_print_pp __P((DB_ENV *, u_int32_t));
|
|
*/
|
|
int
|
|
__lock_stat_print_pp(dbenv, flags)
|
|
DB_ENV *dbenv;
|
|
u_int32_t flags;
|
|
{
|
|
DB_THREAD_INFO *ip;
|
|
int ret;
|
|
|
|
PANIC_CHECK(dbenv);
|
|
ENV_REQUIRES_CONFIG(dbenv,
|
|
dbenv->lk_handle, "DB_ENV->lock_stat_print", DB_INIT_LOCK);
|
|
|
|
#define DB_STAT_LOCK_FLAGS \
|
|
(DB_STAT_ALL | DB_STAT_CLEAR | DB_STAT_LOCK_CONF | \
|
|
DB_STAT_LOCK_LOCKERS | DB_STAT_LOCK_OBJECTS | DB_STAT_LOCK_PARAMS)
|
|
if ((ret = __db_fchk(dbenv, "DB_ENV->lock_stat_print",
|
|
flags, DB_STAT_CLEAR | DB_STAT_LOCK_FLAGS)) != 0)
|
|
return (ret);
|
|
|
|
ENV_ENTER(dbenv, ip);
|
|
REPLICATION_WRAP(dbenv, (__lock_stat_print(dbenv, flags)), ret);
|
|
ENV_LEAVE(dbenv, ip);
|
|
return (ret);
|
|
}
|
|
|
|
/*
|
|
* __lock_stat_print --
|
|
* DB_ENV->lock_stat_print method.
|
|
*
|
|
* PUBLIC: int __lock_stat_print __P((DB_ENV *, u_int32_t));
|
|
*/
|
|
int
|
|
__lock_stat_print(dbenv, flags)
|
|
DB_ENV *dbenv;
|
|
u_int32_t flags;
|
|
{
|
|
u_int32_t orig_flags;
|
|
int ret;
|
|
|
|
orig_flags = flags;
|
|
LF_CLR(DB_STAT_CLEAR);
|
|
if (flags == 0 || LF_ISSET(DB_STAT_ALL)) {
|
|
ret = __lock_print_stats(dbenv, orig_flags);
|
|
if (flags == 0 || ret != 0)
|
|
return (ret);
|
|
}
|
|
|
|
if (LF_ISSET(DB_STAT_ALL | DB_STAT_LOCK_CONF | DB_STAT_LOCK_LOCKERS |
|
|
DB_STAT_LOCK_OBJECTS | DB_STAT_LOCK_PARAMS) &&
|
|
(ret = __lock_print_all(dbenv, orig_flags)) != 0)
|
|
return (ret);
|
|
|
|
return (0);
|
|
}
|
|
|
|
/*
|
|
* __lock_print_stats --
|
|
* Display default lock region statistics.
|
|
*/
|
|
static int
|
|
__lock_print_stats(dbenv, flags)
|
|
DB_ENV *dbenv;
|
|
u_int32_t flags;
|
|
{
|
|
DB_LOCK_STAT *sp;
|
|
int ret;
|
|
|
|
if ((ret = __lock_stat(dbenv, &sp, flags)) != 0)
|
|
return (ret);
|
|
|
|
if (LF_ISSET(DB_STAT_ALL))
|
|
__db_msg(dbenv, "Default locking region information:");
|
|
__db_dl(dbenv, "Last allocated locker ID", (u_long)sp->st_id);
|
|
__db_msg(dbenv, "%#lx\tCurrent maximum unused locker ID",
|
|
(u_long)sp->st_cur_maxid);
|
|
__db_dl(dbenv, "Number of lock modes", (u_long)sp->st_nmodes);
|
|
__db_dl(dbenv,
|
|
"Maximum number of locks possible", (u_long)sp->st_maxlocks);
|
|
__db_dl(dbenv,
|
|
"Maximum number of lockers possible", (u_long)sp->st_maxlockers);
|
|
__db_dl(dbenv, "Maximum number of lock objects possible",
|
|
(u_long)sp->st_maxobjects);
|
|
__db_dl(dbenv, "Number of current locks", (u_long)sp->st_nlocks);
|
|
__db_dl(dbenv, "Maximum number of locks at any one time",
|
|
(u_long)sp->st_maxnlocks);
|
|
__db_dl(dbenv, "Number of current lockers", (u_long)sp->st_nlockers);
|
|
__db_dl(dbenv, "Maximum number of lockers at any one time",
|
|
(u_long)sp->st_maxnlockers);
|
|
__db_dl(dbenv,
|
|
"Number of current lock objects", (u_long)sp->st_nobjects);
|
|
__db_dl(dbenv, "Maximum number of lock objects at any one time",
|
|
(u_long)sp->st_maxnobjects);
|
|
__db_dl(dbenv,
|
|
"Total number of locks requested", (u_long)sp->st_nrequests);
|
|
__db_dl(dbenv,
|
|
"Total number of locks released", (u_long)sp->st_nreleases);
|
|
__db_dl(dbenv,
|
|
"Total number of locks upgraded", (u_long)sp->st_nupgrade);
|
|
__db_dl(dbenv,
|
|
"Total number of locks downgraded", (u_long)sp->st_ndowngrade);
|
|
__db_dl(dbenv,
|
|
"Lock requests not available due to conflicts, for which we waited",
|
|
(u_long)sp->st_lock_wait);
|
|
__db_dl(dbenv,
|
|
"Lock requests not available due to conflicts, for which we did not wait",
|
|
(u_long)sp->st_lock_nowait);
|
|
__db_dl(dbenv, "Number of deadlocks", (u_long)sp->st_ndeadlocks);
|
|
__db_dl(dbenv, "Lock timeout value", (u_long)sp->st_locktimeout);
|
|
__db_dl(dbenv, "Number of locks that have timed out",
|
|
(u_long)sp->st_nlocktimeouts);
|
|
__db_dl(dbenv,
|
|
"Transaction timeout value", (u_long)sp->st_txntimeout);
|
|
__db_dl(dbenv, "Number of transactions that have timed out",
|
|
(u_long)sp->st_ntxntimeouts);
|
|
|
|
__db_dlbytes(dbenv, "The size of the lock region",
|
|
(u_long)0, (u_long)0, (u_long)sp->st_regsize);
|
|
__db_dl_pct(dbenv,
|
|
"The number of region locks that required waiting",
|
|
(u_long)sp->st_region_wait, DB_PCT(sp->st_region_wait,
|
|
sp->st_region_wait + sp->st_region_nowait), NULL);
|
|
|
|
__os_ufree(dbenv, sp);
|
|
|
|
return (0);
|
|
}
|
|
|
|
/*
|
|
* __lock_print_all --
|
|
* Display debugging lock region statistics.
|
|
*/
|
|
static int
|
|
__lock_print_all(dbenv, flags)
|
|
DB_ENV *dbenv;
|
|
u_int32_t flags;
|
|
{
|
|
DB_LOCKER *lip;
|
|
DB_LOCKOBJ *op;
|
|
DB_LOCKREGION *lrp;
|
|
DB_LOCKTAB *lt;
|
|
DB_MSGBUF mb;
|
|
int i, j;
|
|
u_int32_t k;
|
|
char buf[64];
|
|
|
|
lt = dbenv->lk_handle;
|
|
lrp = lt->reginfo.primary;
|
|
DB_MSGBUF_INIT(&mb);
|
|
|
|
LOCK_SYSTEM_LOCK(dbenv);
|
|
|
|
__db_print_reginfo(dbenv, <->reginfo, "Lock");
|
|
|
|
if (LF_ISSET(DB_STAT_ALL | DB_STAT_LOCK_PARAMS)) {
|
|
__db_msg(dbenv, "%s", DB_GLOBAL(db_line));
|
|
__db_msg(dbenv, "Lock region parameters:");
|
|
__mutex_print_debug_single(dbenv,
|
|
"Lock region region mutex", lrp->mtx_region, flags);
|
|
STAT_ULONG("locker table size", lrp->locker_t_size);
|
|
STAT_ULONG("object table size", lrp->object_t_size);
|
|
STAT_ULONG("obj_off", lrp->obj_off);
|
|
STAT_ULONG("locker_off", lrp->locker_off);
|
|
STAT_ULONG("need_dd", lrp->need_dd);
|
|
if (LOCK_TIME_ISVALID(&lrp->next_timeout) &&
|
|
strftime(buf, sizeof(buf), "%m-%d-%H:%M:%S",
|
|
localtime((time_t*)&lrp->next_timeout.tv_sec)) != 0)
|
|
__db_msg(dbenv, "next_timeout: %s.%lu",
|
|
buf, (u_long)lrp->next_timeout.tv_usec);
|
|
}
|
|
|
|
if (LF_ISSET(DB_STAT_ALL | DB_STAT_LOCK_CONF)) {
|
|
__db_msg(dbenv, "%s", DB_GLOBAL(db_line));
|
|
__db_msg(dbenv, "Lock conflict matrix:");
|
|
for (i = 0; i < lrp->stat.st_nmodes; i++) {
|
|
for (j = 0; j < lrp->stat.st_nmodes; j++)
|
|
__db_msgadd(dbenv, &mb, "%lu\t", (u_long)
|
|
lt->conflicts[i * lrp->stat.st_nmodes + j]);
|
|
DB_MSGBUF_FLUSH(dbenv, &mb);
|
|
}
|
|
}
|
|
|
|
if (LF_ISSET(DB_STAT_ALL | DB_STAT_LOCK_LOCKERS)) {
|
|
__db_msg(dbenv, "%s", DB_GLOBAL(db_line));
|
|
__db_msg(dbenv, "Locks grouped by lockers:");
|
|
__lock_print_header(dbenv);
|
|
for (k = 0; k < lrp->locker_t_size; k++)
|
|
for (lip =
|
|
SH_TAILQ_FIRST(<->locker_tab[k], __db_locker);
|
|
lip != NULL;
|
|
lip = SH_TAILQ_NEXT(lip, links, __db_locker)) {
|
|
__lock_dump_locker(dbenv, &mb, lt, lip);
|
|
}
|
|
}
|
|
|
|
if (LF_ISSET(DB_STAT_ALL | DB_STAT_LOCK_OBJECTS)) {
|
|
__db_msg(dbenv, "%s", DB_GLOBAL(db_line));
|
|
__db_msg(dbenv, "Locks grouped by object:");
|
|
__lock_print_header(dbenv);
|
|
for (k = 0; k < lrp->object_t_size; k++) {
|
|
for (op = SH_TAILQ_FIRST(<->obj_tab[k], __db_lockobj);
|
|
op != NULL;
|
|
op = SH_TAILQ_NEXT(op, links, __db_lockobj)) {
|
|
__lock_dump_object(lt, &mb, op);
|
|
__db_msg(dbenv, "%s", "");
|
|
}
|
|
}
|
|
}
|
|
LOCK_SYSTEM_UNLOCK(dbenv);
|
|
|
|
return (0);
|
|
}
|
|
|
|
static void
|
|
__lock_dump_locker(dbenv, mbp, lt, lip)
|
|
DB_ENV *dbenv;
|
|
DB_MSGBUF *mbp;
|
|
DB_LOCKTAB *lt;
|
|
DB_LOCKER *lip;
|
|
{
|
|
struct __db_lock *lp;
|
|
time_t s;
|
|
char buf[DB_THREADID_STRLEN];
|
|
|
|
__db_msgadd(dbenv,
|
|
mbp, "%8lx dd=%2ld locks held %-4d write locks %-4d pid/thread %s",
|
|
(u_long)lip->id, (long)lip->dd_id, lip->nlocks, lip->nwrites,
|
|
dbenv->thread_id_string(dbenv, lip->pid, lip->tid, buf));
|
|
__db_msgadd(
|
|
dbenv, mbp, "%s", F_ISSET(lip, DB_LOCKER_DELETED) ? "(D)" : " ");
|
|
if (LOCK_TIME_ISVALID(&lip->tx_expire)) {
|
|
s = (time_t)lip->tx_expire.tv_sec;
|
|
if (strftime(buf,
|
|
sizeof(buf), "%m-%d-%H:%M:%S", localtime(&s)) != 0)
|
|
__db_msgadd(dbenv, mbp, "expires %s.%lu",
|
|
buf, (u_long)lip->tx_expire.tv_usec);
|
|
}
|
|
if (F_ISSET(lip, DB_LOCKER_TIMEOUT))
|
|
__db_msgadd(dbenv, mbp, " lk timeout %u", lip->lk_timeout);
|
|
if (LOCK_TIME_ISVALID(&lip->lk_expire)) {
|
|
s = (time_t)lip->lk_expire.tv_sec;
|
|
if (strftime(buf,
|
|
sizeof(buf), "%m-%d-%H:%M:%S", localtime(&s)) != 0)
|
|
__db_msgadd(dbenv, mbp, " lk expires %s.%lu",
|
|
buf, (u_long)lip->lk_expire.tv_usec);
|
|
}
|
|
DB_MSGBUF_FLUSH(dbenv, mbp);
|
|
|
|
for (lp = SH_LIST_FIRST(&lip->heldby, __db_lock);
|
|
lp != NULL; lp = SH_LIST_NEXT(lp, locker_links, __db_lock))
|
|
__lock_printlock(lt, mbp, lp, 1);
|
|
}
|
|
|
|
static void
|
|
__lock_dump_object(lt, mbp, op)
|
|
DB_LOCKTAB *lt;
|
|
DB_MSGBUF *mbp;
|
|
DB_LOCKOBJ *op;
|
|
{
|
|
struct __db_lock *lp;
|
|
|
|
for (lp =
|
|
SH_TAILQ_FIRST(&op->holders, __db_lock);
|
|
lp != NULL;
|
|
lp = SH_TAILQ_NEXT(lp, links, __db_lock))
|
|
__lock_printlock(lt, mbp, lp, 1);
|
|
for (lp =
|
|
SH_TAILQ_FIRST(&op->waiters, __db_lock);
|
|
lp != NULL;
|
|
lp = SH_TAILQ_NEXT(lp, links, __db_lock))
|
|
__lock_printlock(lt, mbp, lp, 1);
|
|
}
|
|
|
|
/*
|
|
* __lock_print_header --
|
|
*/
|
|
static void
|
|
__lock_print_header(dbenv)
|
|
DB_ENV *dbenv;
|
|
{
|
|
__db_msg(dbenv, "%-8s %-10s%-4s %-7s %s",
|
|
"Locker", "Mode",
|
|
"Count", "Status", "----------------- Object ---------------");
|
|
}
|
|
|
|
/*
|
|
* __lock_printlock --
|
|
*
|
|
* PUBLIC: void __lock_printlock
|
|
* PUBLIC: __P((DB_LOCKTAB *, DB_MSGBUF *mbp, struct __db_lock *, int));
|
|
*/
|
|
void
|
|
__lock_printlock(lt, mbp, lp, ispgno)
|
|
DB_LOCKTAB *lt;
|
|
DB_MSGBUF *mbp;
|
|
struct __db_lock *lp;
|
|
int ispgno;
|
|
{
|
|
DB_ENV *dbenv;
|
|
DB_LOCKOBJ *lockobj;
|
|
DB_MSGBUF mb;
|
|
db_pgno_t pgno;
|
|
u_int32_t *fidp, type;
|
|
u_int8_t *ptr;
|
|
char *namep;
|
|
const char *mode, *status;
|
|
|
|
dbenv = lt->dbenv;
|
|
|
|
if (mbp == NULL) {
|
|
DB_MSGBUF_INIT(&mb);
|
|
mbp = &mb;
|
|
}
|
|
|
|
switch (lp->mode) {
|
|
case DB_LOCK_IREAD:
|
|
mode = "IREAD";
|
|
break;
|
|
case DB_LOCK_IWR:
|
|
mode = "IWR";
|
|
break;
|
|
case DB_LOCK_IWRITE:
|
|
mode = "IWRITE";
|
|
break;
|
|
case DB_LOCK_NG:
|
|
mode = "NG";
|
|
break;
|
|
case DB_LOCK_READ:
|
|
mode = "READ";
|
|
break;
|
|
case DB_LOCK_READ_UNCOMMITTED:
|
|
mode = "READ_UNCOMMITTED";
|
|
break;
|
|
case DB_LOCK_WRITE:
|
|
mode = "WRITE";
|
|
break;
|
|
case DB_LOCK_WWRITE:
|
|
mode = "WAS_WRITE";
|
|
break;
|
|
case DB_LOCK_WAIT:
|
|
mode = "WAIT";
|
|
break;
|
|
default:
|
|
mode = "UNKNOWN";
|
|
break;
|
|
}
|
|
switch (lp->status) {
|
|
case DB_LSTAT_ABORTED:
|
|
status = "ABORT";
|
|
break;
|
|
case DB_LSTAT_EXPIRED:
|
|
status = "EXPIRED";
|
|
break;
|
|
case DB_LSTAT_FREE:
|
|
status = "FREE";
|
|
break;
|
|
case DB_LSTAT_HELD:
|
|
status = "HELD";
|
|
break;
|
|
case DB_LSTAT_PENDING:
|
|
status = "PENDING";
|
|
break;
|
|
case DB_LSTAT_WAITING:
|
|
status = "WAIT";
|
|
break;
|
|
default:
|
|
status = "UNKNOWN";
|
|
break;
|
|
}
|
|
__db_msgadd(dbenv, mbp, "%8lx %-10s %4lu %-7s ",
|
|
(u_long)lp->holder, mode, (u_long)lp->refcount, status);
|
|
|
|
lockobj = (DB_LOCKOBJ *)((u_int8_t *)lp + lp->obj);
|
|
ptr = SH_DBT_PTR(&lockobj->lockobj);
|
|
if (ispgno && lockobj->lockobj.size == sizeof(struct __db_ilock)) {
|
|
/* Assume this is a DBT lock. */
|
|
memcpy(&pgno, ptr, sizeof(db_pgno_t));
|
|
fidp = (u_int32_t *)(ptr + sizeof(db_pgno_t));
|
|
type = *(u_int32_t *)(ptr + sizeof(db_pgno_t) + DB_FILE_ID_LEN);
|
|
if (__dbreg_get_name(lt->dbenv, (u_int8_t *)fidp, &namep) != 0)
|
|
namep = NULL;
|
|
if (namep == NULL)
|
|
__db_msgadd(dbenv, mbp, "(%lx %lx %lx %lx %lx) ",
|
|
(u_long)fidp[0], (u_long)fidp[1], (u_long)fidp[2],
|
|
(u_long)fidp[3], (u_long)fidp[4]);
|
|
else
|
|
__db_msgadd(dbenv, mbp, "%-25s ", namep);
|
|
__db_msgadd(dbenv, mbp, "%-7s %7lu",
|
|
type == DB_PAGE_LOCK ? "page" :
|
|
type == DB_RECORD_LOCK ? "record" : "handle",
|
|
(u_long)pgno);
|
|
} else {
|
|
__db_msgadd(dbenv, mbp, "0x%lx ",
|
|
(u_long)R_OFFSET(<->reginfo, lockobj));
|
|
__db_pr(dbenv, mbp, ptr, lockobj->lockobj.size);
|
|
}
|
|
DB_MSGBUF_FLUSH(dbenv, mbp);
|
|
}
|
|
|
|
#else /* !HAVE_STATISTICS */
|
|
|
|
int
|
|
__lock_stat_pp(dbenv, statp, flags)
|
|
DB_ENV *dbenv;
|
|
DB_LOCK_STAT **statp;
|
|
u_int32_t flags;
|
|
{
|
|
COMPQUIET(statp, NULL);
|
|
COMPQUIET(flags, 0);
|
|
|
|
return (__db_stat_not_built(dbenv));
|
|
}
|
|
|
|
int
|
|
__lock_stat_print_pp(dbenv, flags)
|
|
DB_ENV *dbenv;
|
|
u_int32_t flags;
|
|
{
|
|
COMPQUIET(flags, 0);
|
|
|
|
return (__db_stat_not_built(dbenv));
|
|
}
|
|
#endif
|