blob: 990ab3891971730d3bfe2e060191d4e14ecaa9f0 [file] [log] [blame]
Dave Chinner0b61f8a2018-06-05 19:42:14 -07001// SPDX-License-Identifier: GPL-2.0
Dave Chinnerefc27b52012-04-29 10:39:43 +00002/*
3 * Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
4 * Copyright (c) 2010 David Chinner.
5 * Copyright (c) 2011 Christoph Hellwig.
6 * All Rights Reserved.
Dave Chinnerefc27b52012-04-29 10:39:43 +00007 */
8#ifndef __XFS_EXTENT_BUSY_H__
9#define __XFS_EXTENT_BUSY_H__
10
Dave Chinnera4fbe6a2013-10-23 10:51:50 +110011struct xfs_mount;
12struct xfs_trans;
13struct xfs_alloc_arg;
14
Dave Chinnerefc27b52012-04-29 10:39:43 +000015/*
16 * Busy block/extent entry. Indexed by a rbtree in perag to mark blocks that
17 * have been freed but whose transactions aren't committed to disk yet.
18 *
19 * Note that we use the transaction ID to record the transaction, not the
20 * transaction structure itself. See xfs_extent_busy_insert() for details.
21 */
Dave Chinner4ecbfe62012-04-29 10:41:10 +000022struct xfs_extent_busy {
Dave Chinnerefc27b52012-04-29 10:39:43 +000023 struct rb_node rb_node; /* ag by-bno indexed search tree */
24 struct list_head list; /* transaction busy extent list */
25 xfs_agnumber_t agno;
26 xfs_agblock_t bno;
27 xfs_extlen_t length;
28 unsigned int flags;
Dave Chinner4ecbfe62012-04-29 10:41:10 +000029#define XFS_EXTENT_BUSY_DISCARDED 0x01 /* undergoing a discard op. */
30#define XFS_EXTENT_BUSY_SKIP_DISCARD 0x02 /* do not discard */
Dave Chinnerefc27b52012-04-29 10:39:43 +000031};
32
33void
Dave Chinner4ecbfe62012-04-29 10:41:10 +000034xfs_extent_busy_insert(struct xfs_trans *tp, xfs_agnumber_t agno,
Dave Chinnerefc27b52012-04-29 10:39:43 +000035 xfs_agblock_t bno, xfs_extlen_t len, unsigned int flags);
36
37void
Dave Chinner4ecbfe62012-04-29 10:41:10 +000038xfs_extent_busy_clear(struct xfs_mount *mp, struct list_head *list,
Dave Chinnerefc27b52012-04-29 10:39:43 +000039 bool do_discard);
40
41int
Dave Chinner4ecbfe62012-04-29 10:41:10 +000042xfs_extent_busy_search(struct xfs_mount *mp, xfs_agnumber_t agno,
Dave Chinnerefc27b52012-04-29 10:39:43 +000043 xfs_agblock_t bno, xfs_extlen_t len);
44
45void
Dave Chinner4ecbfe62012-04-29 10:41:10 +000046xfs_extent_busy_reuse(struct xfs_mount *mp, xfs_agnumber_t agno,
Dave Chinnerefc27b52012-04-29 10:39:43 +000047 xfs_agblock_t fbno, xfs_extlen_t flen, bool userdata);
48
Christoph Hellwigebf55872017-02-07 14:06:57 -080049bool
50xfs_extent_busy_trim(struct xfs_alloc_arg *args, xfs_agblock_t *bno,
51 xfs_extlen_t *len, unsigned *busy_gen);
52
Ben Myerse700a062012-05-10 13:55:33 -050053void
Christoph Hellwigebf55872017-02-07 14:06:57 -080054xfs_extent_busy_flush(struct xfs_mount *mp, struct xfs_perag *pag,
55 unsigned busy_gen);
56
57void
58xfs_extent_busy_wait_all(struct xfs_mount *mp);
Ben Myerse700a062012-05-10 13:55:33 -050059
Dave Chinnerefc27b52012-04-29 10:39:43 +000060int
Dave Chinner4ecbfe62012-04-29 10:41:10 +000061xfs_extent_busy_ag_cmp(void *priv, struct list_head *a, struct list_head *b);
Dave Chinnerefc27b52012-04-29 10:39:43 +000062
Dave Chinner4ecbfe62012-04-29 10:41:10 +000063static inline void xfs_extent_busy_sort(struct list_head *list)
Dave Chinnerefc27b52012-04-29 10:39:43 +000064{
Dave Chinner4ecbfe62012-04-29 10:41:10 +000065 list_sort(NULL, list, xfs_extent_busy_ag_cmp);
Dave Chinnerefc27b52012-04-29 10:39:43 +000066}
67
68#endif /* __XFS_EXTENT_BUSY_H__ */