xref: /openbmc/linux/fs/xfs/xfs_extent_busy.h (revision 4f0f586b)
10b61f8a4SDave Chinner // SPDX-License-Identifier: GPL-2.0
2efc27b52SDave Chinner /*
3efc27b52SDave Chinner  * Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
4efc27b52SDave Chinner  * Copyright (c) 2010 David Chinner.
5efc27b52SDave Chinner  * Copyright (c) 2011 Christoph Hellwig.
6efc27b52SDave Chinner  * All Rights Reserved.
7efc27b52SDave Chinner  */
8efc27b52SDave Chinner #ifndef __XFS_EXTENT_BUSY_H__
9efc27b52SDave Chinner #define	__XFS_EXTENT_BUSY_H__
10efc27b52SDave Chinner 
11a4fbe6abSDave Chinner struct xfs_mount;
12a4fbe6abSDave Chinner struct xfs_trans;
13a4fbe6abSDave Chinner struct xfs_alloc_arg;
14a4fbe6abSDave Chinner 
15efc27b52SDave Chinner /*
16efc27b52SDave Chinner  * Busy block/extent entry.  Indexed by a rbtree in perag to mark blocks that
17efc27b52SDave Chinner  * have been freed but whose transactions aren't committed to disk yet.
18efc27b52SDave Chinner  *
19efc27b52SDave Chinner  * Note that we use the transaction ID to record the transaction, not the
20efc27b52SDave Chinner  * transaction structure itself. See xfs_extent_busy_insert() for details.
21efc27b52SDave Chinner  */
224ecbfe63SDave Chinner struct xfs_extent_busy {
23efc27b52SDave Chinner 	struct rb_node	rb_node;	/* ag by-bno indexed search tree */
24efc27b52SDave Chinner 	struct list_head list;		/* transaction busy extent list */
25efc27b52SDave Chinner 	xfs_agnumber_t	agno;
26efc27b52SDave Chinner 	xfs_agblock_t	bno;
27efc27b52SDave Chinner 	xfs_extlen_t	length;
28efc27b52SDave Chinner 	unsigned int	flags;
294ecbfe63SDave Chinner #define XFS_EXTENT_BUSY_DISCARDED	0x01	/* undergoing a discard op. */
304ecbfe63SDave Chinner #define XFS_EXTENT_BUSY_SKIP_DISCARD	0x02	/* do not discard */
31efc27b52SDave Chinner };
32efc27b52SDave Chinner 
33efc27b52SDave Chinner void
344ecbfe63SDave Chinner xfs_extent_busy_insert(struct xfs_trans *tp, xfs_agnumber_t agno,
35efc27b52SDave Chinner 	xfs_agblock_t bno, xfs_extlen_t len, unsigned int flags);
36efc27b52SDave Chinner 
37efc27b52SDave Chinner void
384ecbfe63SDave Chinner xfs_extent_busy_clear(struct xfs_mount *mp, struct list_head *list,
39efc27b52SDave Chinner 	bool do_discard);
40efc27b52SDave Chinner 
41efc27b52SDave Chinner int
424ecbfe63SDave Chinner xfs_extent_busy_search(struct xfs_mount *mp, xfs_agnumber_t agno,
43efc27b52SDave Chinner 	xfs_agblock_t bno, xfs_extlen_t len);
44efc27b52SDave Chinner 
45efc27b52SDave Chinner void
464ecbfe63SDave Chinner xfs_extent_busy_reuse(struct xfs_mount *mp, xfs_agnumber_t agno,
47efc27b52SDave Chinner 	xfs_agblock_t fbno, xfs_extlen_t flen, bool userdata);
48efc27b52SDave Chinner 
49ebf55872SChristoph Hellwig bool
50ebf55872SChristoph Hellwig xfs_extent_busy_trim(struct xfs_alloc_arg *args, xfs_agblock_t *bno,
51ebf55872SChristoph Hellwig 		xfs_extlen_t *len, unsigned *busy_gen);
52ebf55872SChristoph Hellwig 
53e700a06cSBen Myers void
54ebf55872SChristoph Hellwig xfs_extent_busy_flush(struct xfs_mount *mp, struct xfs_perag *pag,
55ebf55872SChristoph Hellwig 	unsigned busy_gen);
56ebf55872SChristoph Hellwig 
57ebf55872SChristoph Hellwig void
58ebf55872SChristoph Hellwig xfs_extent_busy_wait_all(struct xfs_mount *mp);
59e700a06cSBen Myers 
60efc27b52SDave Chinner int
61*4f0f586bSSami Tolvanen xfs_extent_busy_ag_cmp(void *priv, const struct list_head *a,
62*4f0f586bSSami Tolvanen 	const struct list_head *b);
63efc27b52SDave Chinner 
644ecbfe63SDave Chinner static inline void xfs_extent_busy_sort(struct list_head *list)
65efc27b52SDave Chinner {
664ecbfe63SDave Chinner 	list_sort(NULL, list, xfs_extent_busy_ag_cmp);
67efc27b52SDave Chinner }
68efc27b52SDave Chinner 
69efc27b52SDave Chinner #endif /* __XFS_EXTENT_BUSY_H__ */
70