2018-06-05 19:42:14 -07:00
// SPDX-License-Identifier: GPL-2.0
2013-08-12 20:49:33 +10:00
/*
* Copyright ( c ) 2000 - 2003 , 2005 Silicon Graphics , Inc .
* All Rights Reserved .
*/
# ifndef __XFS_INODE_FORK_H__
# define __XFS_INODE_FORK_H__
struct xfs_inode_log_item ;
2013-10-23 10:51:50 +11:00
struct xfs_dinode ;
2013-08-12 20:49:33 +10:00
/*
* File incore extent information , present for each of data & attr forks .
*/
2018-07-17 16:51:50 -07:00
struct xfs_ifork {
2013-08-12 20:49:33 +10:00
int if_bytes ; /* bytes in if_u1 */
2019-02-01 09:14:22 -08:00
unsigned int if_seq ; /* fork mod counter */
2013-08-12 20:49:33 +10:00
struct xfs_btree_block * if_broot ; /* file's incore btree root */
short if_broot_bytes ; /* bytes allocated for root */
unsigned char if_flags ; /* per-fork flags */
2017-11-03 10:34:46 -07:00
int if_height ; /* height of the extent tree */
2013-08-12 20:49:33 +10:00
union {
2017-11-03 10:34:46 -07:00
void * if_root ; /* extent tree root */
2013-08-12 20:49:33 +10:00
char * if_data ; /* inline file data */
} if_u1 ;
2018-07-17 16:51:50 -07:00
} ;
2013-08-12 20:49:33 +10:00
/*
* Per - fork incore inode flags .
*/
# define XFS_IFINLINE 0x01 /* Inline data is read in */
# define XFS_IFEXTENTS 0x02 /* All extent pointers are read in */
# define XFS_IFBROOT 0x04 /* i_broot points to the bmap b-tree root */
/*
* Fork handling .
*/
# define XFS_IFORK_Q(ip) ((ip)->i_d.di_forkoff != 0)
# define XFS_IFORK_BOFF(ip) ((int)((ip)->i_d.di_forkoff << 3))
# define XFS_IFORK_PTR(ip,w) \
( ( w ) = = XFS_DATA_FORK ? \
& ( ip ) - > i_df : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
( ip ) - > i_afp : \
( ip ) - > i_cowfp ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_DSIZE(ip) \
( XFS_IFORK_Q ( ip ) ? \
XFS_IFORK_BOFF ( ip ) : \
XFS_LITINO ( ( ip ) - > i_mount , ( ip ) - > i_d . di_version ) )
# define XFS_IFORK_ASIZE(ip) \
( XFS_IFORK_Q ( ip ) ? \
XFS_LITINO ( ( ip ) - > i_mount , ( ip ) - > i_d . di_version ) - \
XFS_IFORK_BOFF ( ip ) : \
0 )
# define XFS_IFORK_SIZE(ip,w) \
( ( w ) = = XFS_DATA_FORK ? \
XFS_IFORK_DSIZE ( ip ) : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
XFS_IFORK_ASIZE ( ip ) : \
0 ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_FORMAT(ip,w) \
( ( w ) = = XFS_DATA_FORK ? \
( ip ) - > i_d . di_format : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
( ip ) - > i_d . di_aformat : \
( ip ) - > i_cformat ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_FMT_SET(ip,w,n) \
( ( w ) = = XFS_DATA_FORK ? \
( ( ip ) - > i_d . di_format = ( n ) ) : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
( ( ip ) - > i_d . di_aformat = ( n ) ) : \
( ( ip ) - > i_cformat = ( n ) ) ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_NEXTENTS(ip,w) \
( ( w ) = = XFS_DATA_FORK ? \
( ip ) - > i_d . di_nextents : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
( ip ) - > i_d . di_anextents : \
( ip ) - > i_cnextents ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_NEXT_SET(ip,w,n) \
( ( w ) = = XFS_DATA_FORK ? \
( ( ip ) - > i_d . di_nextents = ( n ) ) : \
2016-10-03 09:11:32 -07:00
( ( w ) = = XFS_ATTR_FORK ? \
( ( ip ) - > i_d . di_anextents = ( n ) ) : \
( ( ip ) - > i_cnextents = ( n ) ) ) )
2013-08-12 20:49:33 +10:00
# define XFS_IFORK_MAXEXT(ip, w) \
( XFS_IFORK_SIZE ( ip , w ) / sizeof ( xfs_bmbt_rec_t ) )
2016-10-03 09:11:32 -07:00
struct xfs_ifork * xfs_iext_state_to_fork ( struct xfs_inode * ip , int state ) ;
2013-08-12 20:49:33 +10:00
int xfs_iformat_fork ( struct xfs_inode * , struct xfs_dinode * ) ;
2017-04-03 12:22:20 -07:00
void xfs_iflush_fork ( struct xfs_inode * , struct xfs_dinode * ,
2014-04-14 19:04:46 +10:00
struct xfs_inode_log_item * , int ) ;
2013-08-12 20:49:33 +10:00
void xfs_idestroy_fork ( struct xfs_inode * , int ) ;
void xfs_idata_realloc ( struct xfs_inode * , int , int ) ;
void xfs_iroot_realloc ( struct xfs_inode * , int , int ) ;
int xfs_iread_extents ( struct xfs_trans * , struct xfs_inode * , int ) ;
int xfs_iextents_copy ( struct xfs_inode * , struct xfs_bmbt_rec * ,
int ) ;
2016-04-06 07:41:43 +10:00
void xfs_init_local_fork ( struct xfs_inode * , int , const void * , int ) ;
2013-08-12 20:49:33 +10:00
2017-11-03 10:34:46 -07:00
xfs_extnum_t xfs_iext_count ( struct xfs_ifork * ifp ) ;
2017-11-03 10:34:43 -07:00
void xfs_iext_insert ( struct xfs_inode * , struct xfs_iext_cursor * cur ,
2017-11-03 10:34:46 -07:00
struct xfs_bmbt_irec * , int ) ;
2017-11-03 10:34:43 -07:00
void xfs_iext_remove ( struct xfs_inode * , struct xfs_iext_cursor * ,
2017-11-03 10:34:47 -07:00
int ) ;
2013-08-12 20:49:33 +10:00
void xfs_iext_destroy ( struct xfs_ifork * ) ;
2016-11-24 11:39:32 +11:00
bool xfs_iext_lookup_extent ( struct xfs_inode * ip ,
struct xfs_ifork * ifp , xfs_fileoff_t bno ,
2017-11-03 10:34:43 -07:00
struct xfs_iext_cursor * cur ,
struct xfs_bmbt_irec * gotp ) ;
2017-10-23 16:32:39 -07:00
bool xfs_iext_lookup_extent_before ( struct xfs_inode * ip ,
struct xfs_ifork * ifp , xfs_fileoff_t * end ,
2017-11-03 10:34:43 -07:00
struct xfs_iext_cursor * cur ,
struct xfs_bmbt_irec * gotp ) ;
bool xfs_iext_get_extent ( struct xfs_ifork * ifp ,
struct xfs_iext_cursor * cur ,
2016-11-24 11:39:32 +11:00
struct xfs_bmbt_irec * gotp ) ;
2017-10-19 11:04:44 -07:00
void xfs_iext_update_extent ( struct xfs_inode * ip , int state ,
2017-11-03 10:34:43 -07:00
struct xfs_iext_cursor * cur ,
struct xfs_bmbt_irec * gotp ) ;
2017-11-03 10:34:46 -07:00
void xfs_iext_first ( struct xfs_ifork * , struct xfs_iext_cursor * ) ;
void xfs_iext_last ( struct xfs_ifork * , struct xfs_iext_cursor * ) ;
void xfs_iext_next ( struct xfs_ifork * , struct xfs_iext_cursor * ) ;
void xfs_iext_prev ( struct xfs_ifork * , struct xfs_iext_cursor * ) ;
2017-11-03 10:34:43 -07:00
static inline bool xfs_iext_next_extent ( struct xfs_ifork * ifp ,
struct xfs_iext_cursor * cur , struct xfs_bmbt_irec * gotp )
{
xfs_iext_next ( ifp , cur ) ;
return xfs_iext_get_extent ( ifp , cur , gotp ) ;
}
static inline bool xfs_iext_prev_extent ( struct xfs_ifork * ifp ,
struct xfs_iext_cursor * cur , struct xfs_bmbt_irec * gotp )
{
xfs_iext_prev ( ifp , cur ) ;
return xfs_iext_get_extent ( ifp , cur , gotp ) ;
}
/*
* Return the extent after cur in gotp without updating the cursor .
*/
static inline bool xfs_iext_peek_next_extent ( struct xfs_ifork * ifp ,
struct xfs_iext_cursor * cur , struct xfs_bmbt_irec * gotp )
{
struct xfs_iext_cursor ncur = * cur ;
xfs_iext_next ( ifp , & ncur ) ;
return xfs_iext_get_extent ( ifp , & ncur , gotp ) ;
}
/*
* Return the extent before cur in gotp without updating the cursor .
*/
static inline bool xfs_iext_peek_prev_extent ( struct xfs_ifork * ifp ,
struct xfs_iext_cursor * cur , struct xfs_bmbt_irec * gotp )
{
struct xfs_iext_cursor ncur = * cur ;
xfs_iext_prev ( ifp , & ncur ) ;
return xfs_iext_get_extent ( ifp , & ncur , gotp ) ;
}
# define for_each_xfs_iext(ifp, ext, got) \
for ( xfs_iext_first ( ( ifp ) , ( ext ) ) ; \
xfs_iext_get_extent ( ( ifp ) , ( ext ) , ( got ) ) ; \
xfs_iext_next ( ( ifp ) , ( ext ) ) )
2016-11-24 11:39:32 +11:00
2013-08-12 20:49:33 +10:00
extern struct kmem_zone * xfs_ifork_zone ;
2016-10-03 09:11:32 -07:00
extern void xfs_ifork_init_cow ( struct xfs_inode * ip ) ;
2018-01-08 10:51:06 -08:00
typedef xfs_failaddr_t ( * xfs_ifork_verifier_t ) ( struct xfs_inode * ) ;
struct xfs_ifork_ops {
xfs_ifork_verifier_t verify_symlink ;
xfs_ifork_verifier_t verify_dir ;
xfs_ifork_verifier_t verify_attr ;
} ;
extern struct xfs_ifork_ops xfs_default_ifork_ops ;
xfs_failaddr_t xfs_ifork_verify_data ( struct xfs_inode * ip ,
struct xfs_ifork_ops * ops ) ;
xfs_failaddr_t xfs_ifork_verify_attr ( struct xfs_inode * ip ,
struct xfs_ifork_ops * ops ) ;
2013-08-12 20:49:33 +10:00
# endif /* __XFS_INODE_FORK_H__ */