2018-06-06 05:42:14 +03:00
// SPDX-License-Identifier: GPL-2.0
2005-04-17 02:20:36 +04:00
/*
2005-11-02 06:58:39 +03:00
* Copyright ( c ) 2000 - 2003 , 2005 Silicon Graphics , Inc .
* All Rights Reserved .
2005-04-17 02:20:36 +04:00
*/
# ifndef __XFS_RTALLOC_H__
# define __XFS_RTALLOC_H__
2013-08-12 14:49:29 +04:00
/* kernel only definitions and functions */
2005-04-17 02:20:36 +04:00
struct xfs_mount ;
struct xfs_trans ;
2018-05-31 19:12:10 +03:00
/*
* XXX : Most of the realtime allocation functions deal in units of realtime
* extents , not realtime blocks . This looks funny when paired with the type
* name and screams for a larger cleanup .
*/
2017-03-29 00:56:36 +03:00
struct xfs_rtalloc_rec {
2018-05-31 19:12:10 +03:00
xfs_rtblock_t ar_startext ;
xfs_rtblock_t ar_extcount ;
2017-03-29 00:56:36 +03:00
} ;
typedef int ( * xfs_rtalloc_query_range_fn ) (
2021-08-11 03:02:16 +03:00
struct xfs_trans * tp ,
const struct xfs_rtalloc_rec * rec ,
void * priv ) ;
2017-03-29 00:56:36 +03:00
2005-04-17 02:20:36 +04:00
# ifdef CONFIG_XFS_RT
/*
* Function prototypes for exported functions .
*/
/*
* Allocate an extent in the realtime subvolume , with the usual allocation
* parameters . The length units are all in realtime extents , as is the
* result block number .
*/
int /* error */
xfs_rtallocate_extent (
struct xfs_trans * tp , /* transaction pointer */
xfs_rtblock_t bno , /* starting block number to allocate */
xfs_extlen_t minlen , /* minimum length to allocate */
xfs_extlen_t maxlen , /* maximum length to allocate */
xfs_extlen_t * len , /* out: actual length allocated */
int wasdel , /* was a delayed allocation extent */
xfs_extlen_t prod , /* extent product factor */
xfs_rtblock_t * rtblock ) ; /* out: start block allocated */
/*
* Free an extent in the realtime subvolume . Length is expressed in
* realtime extents , as is the block number .
*/
int /* error */
xfs_rtfree_extent (
struct xfs_trans * tp , /* transaction pointer */
xfs_rtblock_t bno , /* starting block number to free */
xfs_extlen_t len ) ; /* length of extent freed */
/*
* Initialize realtime fields in the mount structure .
*/
int /* error */
xfs_rtmount_init (
struct xfs_mount * mp ) ; /* file system mount structure */
2009-02-04 11:33:58 +03:00
void
xfs_rtunmount_inodes (
struct xfs_mount * mp ) ;
2005-04-17 02:20:36 +04:00
/*
* Get the bitmap and summary inodes into the mount structure
* at mount time .
*/
int /* error */
xfs_rtmount_inodes (
struct xfs_mount * mp ) ; /* file system mount structure */
/*
* Pick an extent for allocation at the start of a new realtime file .
* Use the sequence number stored in the atime field of the bitmap inode .
* Translate this to a fraction of the rtextents , and return the product
* of rtextents and the fraction .
* The fraction sequence is 0 , 1 / 2 , 1 / 4 , 3 / 4 , 1 / 8 , . . . , 7 / 8 , 1 / 16 , . . .
*/
int /* error */
xfs_rtpick_extent (
struct xfs_mount * mp , /* file system mount point */
struct xfs_trans * tp , /* transaction pointer */
xfs_extlen_t len , /* allocation length (rtextents) */
xfs_rtblock_t * pick ) ; /* result rt extent */
/*
* Grow the realtime area of the filesystem .
*/
int
xfs_growfs_rt (
struct xfs_mount * mp , /* file system mount structure */
xfs_growfs_rt_t * in ) ; /* user supplied growfs struct */
2013-10-15 02:17:56 +04:00
/*
* From xfs_rtbitmap . c
*/
2017-06-16 21:00:07 +03:00
int xfs_rtbuf_get ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t block , int issum , struct xfs_buf * * bpp ) ;
2013-10-15 02:17:56 +04:00
int xfs_rtcheck_range ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_extlen_t len , int val ,
xfs_rtblock_t * new , int * stat ) ;
int xfs_rtfind_back ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_rtblock_t limit ,
xfs_rtblock_t * rtblock ) ;
int xfs_rtfind_forw ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_rtblock_t limit ,
xfs_rtblock_t * rtblock ) ;
int xfs_rtmodify_range ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_extlen_t len , int val ) ;
2014-09-09 05:58:42 +04:00
int xfs_rtmodify_summary_int ( struct xfs_mount * mp , struct xfs_trans * tp ,
int log , xfs_rtblock_t bbno , int delta ,
2020-12-17 03:07:34 +03:00
struct xfs_buf * * rbpp , xfs_fsblock_t * rsb ,
2014-09-09 05:58:42 +04:00
xfs_suminfo_t * sum ) ;
2013-10-15 02:17:56 +04:00
int xfs_rtmodify_summary ( struct xfs_mount * mp , struct xfs_trans * tp , int log ,
2020-12-17 03:07:34 +03:00
xfs_rtblock_t bbno , int delta , struct xfs_buf * * rbpp ,
2013-10-15 02:17:56 +04:00
xfs_fsblock_t * rsb ) ;
int xfs_rtfree_range ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_extlen_t len ,
struct xfs_buf * * rbpp , xfs_fsblock_t * rsb ) ;
2017-03-29 00:56:36 +03:00
int xfs_rtalloc_query_range ( struct xfs_trans * tp ,
2021-08-11 03:00:30 +03:00
const struct xfs_rtalloc_rec * low_rec ,
const struct xfs_rtalloc_rec * high_rec ,
xfs_rtalloc_query_range_fn fn , void * priv ) ;
2017-03-29 00:56:36 +03:00
int xfs_rtalloc_query_all ( struct xfs_trans * tp ,
xfs_rtalloc_query_range_fn fn ,
void * priv ) ;
2017-10-18 07:37:32 +03:00
bool xfs_verify_rtbno ( struct xfs_mount * mp , xfs_rtblock_t rtbno ) ;
2018-01-17 05:53:10 +03:00
int xfs_rtalloc_extent_is_free ( struct xfs_mount * mp , struct xfs_trans * tp ,
xfs_rtblock_t start , xfs_extlen_t len ,
bool * is_free ) ;
2005-04-17 02:20:36 +04:00
# else
2017-02-17 19:21:06 +03:00
# define xfs_rtallocate_extent(t,b,min,max,l,f,p,rb) (ENOSYS)
2005-04-17 02:20:36 +04:00
# define xfs_rtfree_extent(t,b,l) (ENOSYS)
# define xfs_rtpick_extent(m,t,l,rb) (ENOSYS)
# define xfs_growfs_rt(mp,in) (ENOSYS)
2017-03-29 00:56:36 +03:00
# define xfs_rtalloc_query_range(t,l,h,f,p) (ENOSYS)
# define xfs_rtalloc_query_all(t,f,p) (ENOSYS)
2017-06-16 21:00:07 +03:00
# define xfs_rtbuf_get(m,t,b,i,p) (ENOSYS)
2017-10-18 07:37:32 +03:00
# define xfs_verify_rtbno(m, r) (false)
2018-01-17 05:53:10 +03:00
# define xfs_rtalloc_extent_is_free(m,t,s,l,i) (ENOSYS)
2010-04-30 20:43:48 +04:00
static inline int /* error */
xfs_rtmount_init (
xfs_mount_t * mp ) /* file system mount structure */
{
if ( mp - > m_sb . sb_rblocks = = 0 )
return 0 ;
2011-03-07 02:08:35 +03:00
xfs_warn ( mp , " Not built with CONFIG_XFS_RT " ) ;
2014-06-25 08:58:08 +04:00
return - ENOSYS ;
2010-04-30 20:43:48 +04:00
}
2005-04-17 02:20:36 +04:00
# define xfs_rtmount_inodes(m) (((mp)->m_sb.sb_rblocks == 0)? 0 : (ENOSYS))
2009-02-04 11:33:58 +03:00
# define xfs_rtunmount_inodes(m)
2005-04-17 02:20:36 +04:00
# endif /* CONFIG_XFS_RT */
# endif /* __XFS_RTALLOC_H__ */