xref: /linux/fs/xfs/xfs_buf_item.h (revision 0b61f8a4079d904b1b1d47946cca898313de8c26)
1*0b61f8a4SDave Chinner // SPDX-License-Identifier: GPL-2.0
21da177e4SLinus Torvalds /*
37b718769SNathan Scott  * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
47b718769SNathan Scott  * All Rights Reserved.
51da177e4SLinus Torvalds  */
61da177e4SLinus Torvalds #ifndef	__XFS_BUF_ITEM_H__
71da177e4SLinus Torvalds #define	__XFS_BUF_ITEM_H__
81da177e4SLinus Torvalds 
9a8da0da2SDave Chinner /* kernel only definitions */
10a8272ce0SDavid Chinner 
11a8da0da2SDave Chinner /* buf log item flags */
121da177e4SLinus Torvalds #define	XFS_BLI_HOLD		0x01
131da177e4SLinus Torvalds #define	XFS_BLI_DIRTY		0x02
141da177e4SLinus Torvalds #define	XFS_BLI_STALE		0x04
151da177e4SLinus Torvalds #define	XFS_BLI_LOGGED		0x08
161da177e4SLinus Torvalds #define	XFS_BLI_INODE_ALLOC_BUF	0x10
171da177e4SLinus Torvalds #define XFS_BLI_STALE_INODE	0x20
18ccf7c23fSDave Chinner #define	XFS_BLI_INODE_BUF	0x40
195f6bed76SDave Chinner #define	XFS_BLI_ORDERED		0x80
201da177e4SLinus Torvalds 
210b1b213fSChristoph Hellwig #define XFS_BLI_FLAGS \
220b1b213fSChristoph Hellwig 	{ XFS_BLI_HOLD,		"HOLD" }, \
230b1b213fSChristoph Hellwig 	{ XFS_BLI_DIRTY,	"DIRTY" }, \
240b1b213fSChristoph Hellwig 	{ XFS_BLI_STALE,	"STALE" }, \
250b1b213fSChristoph Hellwig 	{ XFS_BLI_LOGGED,	"LOGGED" }, \
260b1b213fSChristoph Hellwig 	{ XFS_BLI_INODE_ALLOC_BUF, "INODE_ALLOC" }, \
27ccf7c23fSDave Chinner 	{ XFS_BLI_STALE_INODE,	"STALE_INODE" }, \
285f6bed76SDave Chinner 	{ XFS_BLI_INODE_BUF,	"INODE_BUF" }, \
295f6bed76SDave Chinner 	{ XFS_BLI_ORDERED,	"ORDERED" }
300b1b213fSChristoph Hellwig 
311da177e4SLinus Torvalds 
321da177e4SLinus Torvalds struct xfs_buf;
331da177e4SLinus Torvalds struct xfs_mount;
341da177e4SLinus Torvalds struct xfs_buf_log_item;
351da177e4SLinus Torvalds 
361da177e4SLinus Torvalds /*
371da177e4SLinus Torvalds  * This is the in core log item structure used to track information
381da177e4SLinus Torvalds  * needed to log buffers.  It tracks how many times the lock has been
391da177e4SLinus Torvalds  * locked, and which 128 byte chunks of the buffer are dirty.
401da177e4SLinus Torvalds  */
4170a20655SCarlos Maiolino struct xfs_buf_log_item {
421da177e4SLinus Torvalds 	xfs_log_item_t		bli_item;	/* common item structure */
431da177e4SLinus Torvalds 	struct xfs_buf		*bli_buf;	/* real buffer pointer */
441da177e4SLinus Torvalds 	unsigned int		bli_flags;	/* misc flags */
451da177e4SLinus Torvalds 	unsigned int		bli_recur;	/* lock recursion count */
461da177e4SLinus Torvalds 	atomic_t		bli_refcount;	/* cnt of tp refs */
47372cc85eSDave Chinner 	int			bli_format_count;	/* count of headers */
48372cc85eSDave Chinner 	struct xfs_buf_log_format *bli_formats;	/* array of in-log header ptrs */
49b9438173SMark Tinguely 	struct xfs_buf_log_format __bli_format;	/* embedded in-log header */
5070a20655SCarlos Maiolino };
511da177e4SLinus Torvalds 
52f79af0b9SDave Chinner int	xfs_buf_item_init(struct xfs_buf *, struct xfs_mount *);
531da177e4SLinus Torvalds void	xfs_buf_item_relse(struct xfs_buf *);
5470a20655SCarlos Maiolino void	xfs_buf_item_log(struct xfs_buf_log_item *, uint, uint);
556453c65dSBrian Foster bool	xfs_buf_item_dirty_format(struct xfs_buf_log_item *);
561da177e4SLinus Torvalds void	xfs_buf_attach_iodone(struct xfs_buf *,
571da177e4SLinus Torvalds 			      void(*)(struct xfs_buf *, xfs_log_item_t *),
581da177e4SLinus Torvalds 			      xfs_log_item_t *);
591da177e4SLinus Torvalds void	xfs_buf_iodone_callbacks(struct xfs_buf *);
60ca30b2a7SChristoph Hellwig void	xfs_buf_iodone(struct xfs_buf *, struct xfs_log_item *);
61d3a304b6SCarlos Maiolino bool	xfs_buf_resubmit_failed_buffers(struct xfs_buf *,
62d3a304b6SCarlos Maiolino 					struct list_head *);
631da177e4SLinus Torvalds 
64a8da0da2SDave Chinner extern kmem_zone_t	*xfs_buf_item_zone;
651da177e4SLinus Torvalds 
661da177e4SLinus Torvalds #endif	/* __XFS_BUF_ITEM_H__ */
67