[BACK]Return to xfs_log.h CVS log [TXT][DIR] Up to [Development] / xfs-linux-nodel

File: [Development] / xfs-linux-nodel / xfs_log.h (download)

Revision 1.12, Tue Jan 25 03:40:44 1994 UTC (23 years, 9 months ago) by miken
Branch: MAIN
Changes since 1.11: +2 -2 lines

1.  Change xfs_log_write() routine to return an extra argument, the starting
	lsn of a transaction.
2.  Change interface log_iovec structure to not include lsn.  The only one we
	need it provided in (1).
3.  Fix small logic bug where writes were happening to iclog incorrectly.

#ifndef	_XFS_LOG_H
#define _XFS_LOG_H

#define	XFS_LSN_CMP(x,y)	((x) - (y))
#define	XFS_LSN_DIFF(x,y)	((x) - (y))

/*
 * Macros, structures, prototypes for interface to the log manager.
 */

/*
 * Flags to xfs_log_mount
 */
#define XFS_LOG_RECOVER		0x1

/*
 * Flags to xfs_log_done()
 */
#define XFS_LOG_REL_PERM_RESERV	0x1


/*
 * Flags to xfs_log_reserve()
 *
 *	XFS_LOG_SLEEP:	 If space is not available, sleep
 *	XFS_LOG_NOSLEEP: If space is not available, return error
 *	XFS_LOG_PERM_RESERV: Permanent reservation.  When writes are
 *		performed against this type of reservation, the reservation
 *		is not decreased.  Long running transactions should use this.
 */
#define XFS_LOG_SLEEP		0x1
#define XFS_LOG_NOSLEEP		0x2
#define XFS_LOG_PERM_RESERV	0x4


/*
 * Flags to xfs_log_force()
 *
 *	XFS_LOG_SYNC:	Synchronous force in-core log to disk. (default)
 *	XFS_LOG_FORCE:	Start in-core log write now.
 *	XFS_LOG_URGE:	Start write within some window of time.
 */
#define XFS_LOG_SYNC		0x1
#define XFS_LOG_FORCE		0x2
#define XFS_LOG_URGE		0x4


/* Log Clients */
#define XFS_TRANSACTION_MANAGER	1
#define XFS_VOLUME_MANAGER	2


typedef struct xfs_log_iovec {
	caddr_t		i_addr;		/* beginning address of region */
	uint		i_len;		/* length in bytes of region */
} xfs_log_iovec_t;

typedef void* xfs_log_ticket_t;

/*
 * Structure used to pass callback function and the function's argument
 * to the log manager.
 */
typedef struct xfs_log_callback {
	struct xfs_log_callback	*cb_next;
	void			(*cb_func)(void *);
	void 			*cb_arg;
} xfs_log_callback_t;


/* Log manager interfaces */
struct xfs_mount;
xfs_lsn_t xfs_log_done(struct xfs_mount *mp, xfs_log_ticket_t ticket, uint flags);
int	  xfs_log_force(struct xfs_mount *mp, xfs_lsn_t lsn, uint flags);
int	  xfs_log_init();
int	  xfs_log_mount(struct xfs_mount *mp, dev_t log_dev, uint flags);
void	  xfs_log_notify(struct xfs_mount *mp, xfs_lsn_t lsn,
			 xfs_log_callback_t *callback_entry);
int	  xfs_log_reserve(struct xfs_mount *mp, uint length,
			  xfs_log_ticket_t *ticket, char clientid, uint flags);
int	  xfs_log_write(struct xfs_mount *mp, xfs_log_iovec_t region[],
			int nentries, xfs_log_ticket_t ticket,
			xfs_lsn_t *start_lsn);

/* Log manager utility interfaces */
void xfs_log_print(struct xfs_mount *mp, dev_t log_dev);

#define XFS_ERECOVER	4	/* Failure to recover log */
#define XFS_ELOGSTAT	2	/* Failure to stat log in user space */
#define XFS_ENOLOGSPACE	3	/* Reservation too large */
#define XFS_ENOTSUP	1
#define XFS_ENOLSN	5	/* Can't find the lsn you asked for */
#define XFS_ENOTFOUND	6

#endif	/* _XFS_LOG_H */