view usr/src/cmd/fm/fmd/common/fmd_log.h @ 12979:ab9ae749152f

PSARC/2009/617 Software Events Notification Parameters CLI PSARC/2009/618 snmp-notify: SNMP Notification Daemon for Software Events PSARC/2009/619 smtp-notify: Email Notification Daemon for Software Events PSARC/2010/225 fmd for non-global Solaris zones PSARC/2010/226 Solaris Instance UUID PSARC/2010/227 nvlist_nvflag(3NVPAIR) PSARC/2010/228 libfmevent additions PSARC/2010/257 sysevent_evc_setpropnvl and sysevent_evc_getpropnvl PSARC/2010/265 FMRI and FMA Event Stabilty, 'ireport' category 1 event class, and the 'sw' FMRI scheme PSARC/2010/278 FMA/SMF integration: instance state transitions PSARC/2010/279 Modelling panics within FMA PSARC/2010/290 logadm.conf upgrade 6392476 fmdump needs to pretty-print 6393375 userland ereport/ireport event generation interfaces 6445732 Add email notification agent for FMA and software events 6804168 RFE: Allow an efficient means to monitor SMF services status changes 6866661 scf_values_destroy(3SCF) will segfault if is passed NULL 6884709 Add snmp notification agent for FMA and software events 6884712 Add private interface to tap into libfmd_msg macro expansion capabilities 6897919 fmd to run in a non-global zone 6897937 fmd use of non-private doors is not safe 6900081 add a UUID to Solaris kernel image for use in crashdump identification 6914884 model panic events as a defect diagnosis in FMA 6944862 fmd_case_open_uuid, fmd_case_uuisresolved, fmd_nvl_create_defect 6944866 log legacy sysevents in fmd 6944867 enumerate svc scheme in topo 6944868 software-diagnosis and software-response fmd modules 6944870 model SMF maintenance state as a defect diagnosis in FMA 6944876 savecore runs in foreground for systems with zfs root and dedicated dump 6965796 Implement notification parameters for SMF state transitions and FMA events 6968287 SUN-FM-MIB.mib needs to be updated to reflect Oracle information 6972331 logadm.conf upgrade PSARC/2010/290
author Gavin Maltby <gavin.maltby@oracle.com>
date Fri, 30 Jul 2010 17:04:17 +1000
parents e784a8fa27da
children
line wrap: on
line source

/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */
/*
 * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
 */

#ifndef	_FMD_LOG_H
#define	_FMD_LOG_H

#include <sys/types.h>
#include <sys/stat.h>
#include <pthread.h>
#include <exacct.h>

#ifdef	__cplusplus
extern "C" {
#endif

#include <fmd_api.h>

typedef struct fmd_log {
	char *log_name;			/* file pathname */
	char *log_tag;			/* file content tag */
	int log_fd;			/* file descriptor */
	struct stat64 log_stat;		/* status of file at log_open() time */
	ea_file_t log_ea;		/* exacct file structure */
	pthread_mutex_t log_lock;	/* lock for flags, refs, off, append */
	pthread_cond_t log_cv;		/* condition variable for waiters */
	int log_flags;			/* file flags (see below) */
	uint_t log_refs;		/* file reference count */
	uint_t log_pending;		/* number of pending log commits */
	off64_t log_toc;		/* offset of table of contents */
	off64_t log_beg;		/* offset of first data record */
	off64_t log_off;		/* offset at which to append */
	off64_t log_skip;		/* offset to skip to for replay */
	uint64_t log_minfree;		/* minimum free bytes for filesystem */
	char *log_uuid;			/* uuid string for this log file */
	uint_t log_uuidlen;		/* length of log_uuid (not incl. \0) */
} fmd_log_t;

#define	FMD_LF_EAOPEN	0x1		/* log_ea is open and valid */
#define	FMD_LF_REPLAY	0x2		/* log records should use replay tag */
#define	FMD_LF_DIRTY	0x4		/* log toc should be updated */
#define	FMD_LF_BUSY	0x8		/* log is busy; skip updates */

typedef void fmd_log_f(fmd_log_t *, fmd_event_t *, void *);

#define	FMD_LOG_ERROR	"error"		/* tag for error log files */
#define	FMD_LOG_FAULT	"fault"		/* tag for fault log files */
#define	FMD_LOG_ASRU	"asru"		/* tag for asru log files */
#define	FMD_LOG_XPRT	"xprt"		/* tag for transport log files */
#define	FMD_LOG_INFO	"info"		/* tag for info event log files */

extern fmd_log_t *fmd_log_tryopen(const char *, const char *, const char *);
extern fmd_log_t *fmd_log_open(const char *, const char *, const char *);
extern void fmd_log_close(fmd_log_t *);

extern void fmd_log_hold_pending(fmd_log_t *);
extern void fmd_log_hold(fmd_log_t *);
extern void fmd_log_rele(fmd_log_t *);

extern void fmd_log_append(fmd_log_t *, fmd_event_t *, fmd_case_t *);
extern void fmd_log_commit(fmd_log_t *, fmd_event_t *);
extern void fmd_log_decommit(fmd_log_t *, fmd_event_t *);
extern void fmd_log_replay(fmd_log_t *, fmd_log_f *, void *);
extern void fmd_log_update(fmd_log_t *);
extern fmd_log_t *fmd_log_rotate(fmd_log_t *);

#ifdef	__cplusplus
}
#endif

#endif	/* _FMD_LOG_H */