/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License, Version 1.0 only
 * (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 2005 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

#ifndef	_FMD_LOG_H
#define	_FMD_LOG_H

#pragma ident	"%Z%%M%	%I%	%E% SMI"

#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 */

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 */