Files
Arquivotheca.Solaris-2.5/cmd/fs.d/cachefs/common/stats.h
seta75D 7c4988eac0 Init
2021-10-11 19:38:01 -03:00

201 lines
5.3 KiB
C
Executable File

#ifndef cachefs_lib_stats_h
#define cachefs_lib_stats_h
#pragma ident "@(#)stats.h 1.15 94/11/11 SMI"
/*
* Copyright (c) 1994, by Sun Microsystems, Inc.
* All Rights Reserved.
*/
#include <stdio.h>
#include <sys/types.h>
#include <sys/ioctl.h>
#include <rpc/types.h>
#include <rpc/xdr.h>
#include <sys/fs/cachefs_fs.h>
#include <sys/fs/cachefs_log.h>
#include <kstat.h>
#include <ndbm.h>
#ifndef DEBUG
#define NDEBUG
#endif /* DEBUG */
#define STATS_MAGIC 54545
typedef struct stats_cookie {
int st_magic;
char *st_progname;
u_long st_flags; /* misc. flags */
int st_fsid; /* id # for kstat `cachefs.#.stat' */
FILE *st_logstream; /* stream for logfile */
XDR st_logxdr;
struct cachefs_log_logfile_header st_loghead;
char st_asciirec[BUFSIZ];
DBM *st_dbm;
char st_dbm_name[MAXPATHLEN];
int st_ws_init;
int st_ws_current;
int st_ws_high;
int st_ws_expensive;
char st_errorstr[BUFSIZ];
int st_errno;
kstat_ctl_t *st_kstat_cookie;
} stats_cookie_t;
/*
* error types for the API (given by stats_errno())
*/
enum stats_error {
SE_NOERROR, /* placeholder so no errors == 0 */
SE_INVAL, /* invalid use of the API */
SE_NOMEM, /* ran out of memory */
SE_FILE, /* trouble with file i/o */
SE_CORRUPT, /* trouble with a corrupt file */
SE_KERNEL /* trouble coming from communication with the kernel */
};
/*
* flags in cookie->st_flags
*/
#define ST_VALID 0x0001 /* initialized completely */
#define ST_BOUND 0x0002 /* bound to a particular filesystem or cache */
#define ST_ERROR 0x0004 /* an error has occured */
#define ST_LFOPEN 0x0008 /* logstream is open */
#define ST_DBMOPEN 0x0010 /* dbm descriptor is open */
#define ST_WSCOMP 0x0020 /* working set size computed */
/*
* flags for logfile-to-workingset
*/
#define GRI_ADD 0x01 /* we may have added to the alloc map */
#define GRI_TRUNC 0x02 /* we may have truncated the alloc map */
#define GRI_MODIFY 0x04 /* we modified this file */
#define GRI_METADATA 0x08 /* we created metadata */
#define GRI_EXPENSIVE 0x10 /* record indicates `expensive' logging */
/*
* structures for logfile-to-workingset
*/
#define FI_METADATA 0x01 /* this file has metadata */
typedef struct fid_info {
int fi_magic;
u_int fi_flags;
caddr_t fi_vfsp;
u_int fi_ent_n;
struct fid_info_allocent {
off_t offset;
size_t len;
} fi_ent[C_MAX_ALLOCINFO_SLOTS];
u_int fi_total;
} fid_info;
#define FI_MAGIC (3748321)
typedef struct mount_info {
int mi_magic;
u_int mi_mounted:1;
u_int mi_used:1;
u_int mi_current;
u_int mi_high;
u_int mi_flags;
u_int mi_filegrp_size;
char mi_path[2];
} mount_info;
#define MI_MAGIC (837492)
typedef struct filegrp_info {
int fg_magic;
u_int fg_count; /* high-water known # of attrcache entries */
u_int fg_bcount; /* # of bits set in fg_bits */
u_char fg_bits[DEF_FILEGRP_SIZE / NBBY];
size_t fg_size; /* high-water attrcache size (MAXBSIZE ceiling) */
} fg_info;
#define FG_MAGIC (673492)
/*
* the cachefs stats (stats_*) API.
*/
/* stats_create.c */
stats_cookie_t * stats_create_mountpath(char *, char *);
stats_cookie_t * stats_create_unbound(char *);
cachefs_kstat_key_t *stats_next(stats_cookie_t *);
cachefs_kstat_key_t *stats_getkey(stats_cookie_t *);
void stats_destroy(stats_cookie_t *);
int stats_good(stats_cookie_t *);
char *stats_errorstr(stats_cookie_t *);
int stats_errno(stats_cookie_t *);
int stats_inerror(stats_cookie_t *);
void stats_perror(stats_cookie_t *, int, char *, ...);
/* stats_log.c */
int stats_log_kernel_setname(stats_cookie_t *, char *);
int stats_log_which(stats_cookie_t *, int, int);
char *stats_log_kernel_getname(stats_cookie_t *);
int stats_log_logfile_open(stats_cookie_t *, char *);
void *stats_log_logfile_read(stats_cookie_t *, int *);
char *stats_log_record_toascii(stats_cookie_t *, void *);
u_long stats_log_get_record_info(stats_cookie_t *,
void *, caddr_t *, fid_t **, u_long *, off_t *, size_t *);
void stats_log_fi_add(stats_cookie_t *, fid_info *, off_t, size_t);
void stats_log_fi_trunc(stats_cookie_t *, fid_info *, off_t, size_t);
struct cachefs_log_logfile_header *stats_log_getheader(stats_cookie_t *);
void stats_log_compute_wssize(stats_cookie_t *);
int stats_log_wssize_init(stats_cookie_t *);
int stats_log_wssize_current(stats_cookie_t *);
int stats_log_wssize_high(stats_cookie_t *);
int stats_log_wssize_expensive(stats_cookie_t *);
/* stats_stats.c */
u_int stats_hits(stats_cookie_t *);
u_int stats_misses(stats_cookie_t *);
u_int stats_passes(stats_cookie_t *);
u_int stats_fails(stats_cookie_t *);
u_int stats_modifies(stats_cookie_t *);
u_int stats_gc_count(stats_cookie_t *);
time_t stats_gc_time(stats_cookie_t *);
time_t stats_gc_before(stats_cookie_t *);
time_t stats_gc_after(stats_cookie_t *);
int stats_zero_stats(stats_cookie_t *);
/* stats_dbm.c */
void stats_dbm_open(stats_cookie_t *);
void stats_dbm_rm(stats_cookie_t *);
void stats_dbm_close(stats_cookie_t *);
fid_info *stats_dbm_fetch_byfid(stats_cookie_t *, fid_t *);
void stats_dbm_store_byfid(stats_cookie_t *, fid_t *, fid_info *);
mount_info *stats_dbm_fetch_byvfsp(stats_cookie_t *, caddr_t);
void stats_dbm_store_byvfsp(stats_cookie_t *, caddr_t, mount_info *);
void stats_dbm_delete_byvfsp(stats_cookie_t *, caddr_t);
size_t stats_dbm_attrcache_addsize(stats_cookie_t *, mount_info *,
u_long, u_int);
datum stats_dbm_firstkey(stats_cookie_t *);
datum stats_dbm_nextkey(stats_cookie_t *);
#endif /* cachefs_lib_stats_h */