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

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

Revision 1.11, Wed Sep 28 15:11:07 1994 UTC (23 years ago) by ajs
Branch: MAIN
Changes since 1.10: +8 -1 lines

Add a flags field to the buf log format structure
in which we can set the new XFS_BLI_INODE_BUF flag.

#ifndef	_XFS_BUF_ITEM_H
#define	_XFS_BUF_ITEM_H

/*
 * This is the structure used to lay out a buf log item in the
 * log.  The data map describes which 128 byte chunks of the buffer
 * have been logged.
 */
typedef struct xfs_buf_log_format {
	unsigned short	blf_type;	/* buf log item type indicator */
	unsigned short	blf_size;	/* size of this item */
	daddr_t		blf_blkno;	/* starting blkno of this buf */
	ushort		blf_flags;	/* misc state */
	ushort		blf_len;	/* number of blocks in this buf */
	unsigned int	blf_map_size;	/* size of data bitmap in words */
	unsigned int	blf_data_map[1];/* variable size bitmap of */
					/*   regions of buffer in this item */
} xfs_buf_log_format_t;

/*
 * This flag indicates that the buffer contains on disk inodes
 * and requires special recovery handling.
 */
#define	XFS_BLI_INODE_BUF	0x1

#define	XFS_BLI_CHUNK		128
#define	XFS_BLI_SHIFT		7
#define	BIT_TO_WORD_SHIFT	5
#define	NBWORD			(NBBY * sizeof(unsigned int))

struct ktrace;
/*
 * This is the in core log item structure used to track information
 * needed to log buffers.  It tracks how many times the lock has been
 * locked, and which 128 byte chunks of the buffer are dirty.
 */
typedef struct xfs_buf_log_item {
	xfs_log_item_t		bli_item;	/* common item structure */
	buf_t			*bli_buf;	/* real buffer pointer */
	unsigned int		bli_flags;	/* misc flags */
	unsigned int		bli_recur;	/* lock recursion count */
	unsigned int		bli_refcount;	/* cnt of tp refs */
	struct ktrace		*bli_trace;	/* event trace buf */
#ifdef DEBUG
	char			*bli_orig;	/* original buffer copy */
	char			*bli_logged;	/* bytes to be logged */
#endif
	xfs_buf_log_format_t	bli_format;	/* in-log header */
} xfs_buf_log_item_t;

/*
 * buf log item flags
 */
#define	XFS_BLI_HOLD	0x1
#define	XFS_BLI_DIRTY	0x2
#define	XFS_BLI_STALE	0x4
#define	XFS_BLI_LOGGED	0x8

/*
 * This lock guards the bli_refcount fields of the buf items.
 */
extern lock_t	xfs_bli_reflock;

#define	XFS_BLI_TRACE_SIZE	32
#if	(defined(DEBUG) && !defined(SIM))
void	xfs_buf_item_trace(char *, xfs_buf_log_item_t *);
#else
#define	xfs_buf_item_trace(id, bip)
#endif

void	xfs_buf_item_init(buf_t *, struct xfs_mount *);
void	xfs_buf_item_relse(buf_t *);
void	xfs_buf_item_log(xfs_buf_log_item_t *, uint, uint);
uint	xfs_buf_item_dirty(xfs_buf_log_item_t *);
int	xfs_buf_item_bits(uint *, uint, uint);
int	xfs_buf_item_contig_bits(uint *, uint, uint);
int	xfs_buf_item_next_bit(uint *, uint, uint);
void	xfs_buf_attach_iodone(buf_t *, void(*)(buf_t*, xfs_log_item_t *),
			      xfs_log_item_t *);
void	xfs_buf_iodone_callbacks(buf_t *);
void	xfs_buf_iodone(buf_t *, xfs_buf_log_item_t *);

#endif	/* _XFS_BUF_ITEM_H */