diff options
Diffstat (limited to 'fs/xfs/xfs_alloc.h')
| -rw-r--r-- | fs/xfs/xfs_alloc.h | 54 | 
1 files changed, 40 insertions, 14 deletions
diff --git a/fs/xfs/xfs_alloc.h b/fs/xfs/xfs_alloc.h index 895009a9727..feacb061bab 100644 --- a/fs/xfs/xfs_alloc.h +++ b/fs/xfs/xfs_alloc.h @@ -19,10 +19,12 @@  #define	__XFS_ALLOC_H__  struct xfs_buf; +struct xfs_btree_cur;  struct xfs_mount;  struct xfs_perag;  struct xfs_trans; -struct xfs_busy_extent; + +extern struct workqueue_struct *xfs_alloc_wq;  /*   * Freespace allocation types.  Argument to xfs_alloc_[v]extent. @@ -74,6 +76,22 @@ typedef unsigned int xfs_alloctype_t;  #define XFS_ALLOC_SET_ASIDE(mp)  (4 + ((mp)->m_sb.sb_agcount * 4))  /* + * When deciding how much space to allocate out of an AG, we limit the + * allocation maximum size to the size the AG. However, we cannot use all the + * blocks in the AG - some are permanently used by metadata. These + * blocks are generally: + *	- the AG superblock, AGF, AGI and AGFL + *	- the AGF (bno and cnt) and AGI btree root blocks + *	- 4 blocks on the AGFL according to XFS_ALLOC_SET_ASIDE() limits + * + * The AG headers are sector sized, so the amount of space they take up is + * dependent on filesystem geometry. The others are all single blocks. + */ +#define XFS_ALLOC_AG_MAX_USABLE(mp)	\ +	((mp)->m_sb.sb_agblocks - XFS_BB_TO_FSB(mp, XFS_FSS_TO_BB(mp, 4)) - 7) + + +/*   * Argument structure for xfs_alloc routines.   * This is turned into a structure to avoid having 20 arguments passed   * down several levels of the stack. @@ -117,19 +135,6 @@ xfs_extlen_t  xfs_alloc_longest_free_extent(struct xfs_mount *mp,  		struct xfs_perag *pag); -#ifdef __KERNEL__ - -void -xfs_alloc_busy_insert(xfs_trans_t *tp, -		xfs_agnumber_t agno, -		xfs_agblock_t bno, -		xfs_extlen_t len); - -void -xfs_alloc_busy_clear(struct xfs_mount *mp, struct xfs_busy_extent *busyp); - -#endif	/* __KERNEL__ */ -  /*   * Compute and fill in value of m_ag_maxlevels.   */ @@ -205,4 +210,25 @@ xfs_free_extent(  	xfs_fsblock_t	bno,	/* starting block number of extent */  	xfs_extlen_t	len);	/* length of extent */ +int					/* error */ +xfs_alloc_lookup_le( +	struct xfs_btree_cur	*cur,	/* btree cursor */ +	xfs_agblock_t		bno,	/* starting block of extent */ +	xfs_extlen_t		len,	/* length of extent */ +	int			*stat);	/* success/failure */ + +int				/* error */ +xfs_alloc_lookup_ge( +	struct xfs_btree_cur	*cur,	/* btree cursor */ +	xfs_agblock_t		bno,	/* starting block of extent */ +	xfs_extlen_t		len,	/* length of extent */ +	int			*stat);	/* success/failure */ + +int					/* error */ +xfs_alloc_get_rec( +	struct xfs_btree_cur	*cur,	/* btree cursor */ +	xfs_agblock_t		*bno,	/* output: starting block of extent */ +	xfs_extlen_t		*len,	/* output: length of extent */ +	int			*stat);	/* output: success/failure */ +  #endif	/* __XFS_ALLOC_H__ */  | 
