2005-04-16 15:20:36 -07:00
/*
2006-06-19 08:39:53 +10:00
* Copyright ( c ) 2000 - 2006 Silicon Graphics , Inc .
2005-11-02 14:58:39 +11:00
* All Rights Reserved .
2005-04-16 15:20:36 -07:00
*
2005-11-02 14:58:39 +11:00
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License as
2005-04-16 15:20:36 -07:00
* published by the Free Software Foundation .
*
2005-11-02 14:58:39 +11:00
* This program is distributed in the hope that it would be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
2005-04-16 15:20:36 -07:00
*
2005-11-02 14:58:39 +11:00
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write the Free Software Foundation ,
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA
2005-04-16 15:20:36 -07:00
*/
# ifndef __XFS_RW_H__
# define __XFS_RW_H__
struct xfs_buf ;
struct xfs_inode ;
struct xfs_mount ;
/*
* Convert the given file system block to a disk block .
* We have to treat it differently based on whether the
* file is a real time file or not , because the bmap code
* does .
*/
# define XFS_FSB_TO_DB(ip,fsb) xfs_fsb_to_db(ip,fsb)
2005-11-02 14:38:42 +11:00
static inline xfs_daddr_t
xfs_fsb_to_db ( struct xfs_inode * ip , xfs_fsblock_t fsb )
{
2007-11-23 16:29:42 +11:00
return ( XFS_IS_REALTIME_INODE ( ip ) ? \
2005-04-16 15:20:36 -07:00
( xfs_daddr_t ) XFS_FSB_TO_BB ( ( ip ) - > i_mount , ( fsb ) ) : \
2005-11-02 14:38:42 +11:00
XFS_FSB_TO_DADDR ( ( ip ) - > i_mount , ( fsb ) ) ) ;
}
2005-04-16 15:20:36 -07:00
2007-05-24 15:22:19 +10:00
/*
* Flags for xfs_free_eofblocks
*/
# define XFS_FREE_EOF_LOCK (1<<0)
# define XFS_FREE_EOF_NOLOCK (1<<1)
2007-06-18 16:50:37 +10:00
/*
* helper function to extract extent size hint from inode
*/
STATIC_INLINE xfs_extlen_t
xfs_get_extsz_hint (
xfs_inode_t * ip )
{
xfs_extlen_t extsz ;
2007-11-23 16:29:42 +11:00
if ( unlikely ( XFS_IS_REALTIME_INODE ( ip ) ) ) {
2007-06-18 16:50:37 +10:00
extsz = ( ip - > i_d . di_flags & XFS_DIFLAG_EXTSIZE )
? ip - > i_d . di_extsize
: ip - > i_mount - > m_sb . sb_rextsize ;
ASSERT ( extsz ) ;
} else {
extsz = ( ip - > i_d . di_flags & XFS_DIFLAG_EXTSIZE )
? ip - > i_d . di_extsize : 0 ;
}
return extsz ;
}
2005-04-16 15:20:36 -07:00
/*
* Prototypes for functions in xfs_rw . c .
*/
2005-11-02 14:38:42 +11:00
extern int xfs_write_clear_setuid ( struct xfs_inode * ip ) ;
2006-06-19 08:39:53 +10:00
extern int xfs_write_sync_logforce ( struct xfs_mount * mp , struct xfs_inode * ip ) ;
2005-11-02 14:38:42 +11:00
extern int xfs_bwrite ( struct xfs_mount * mp , struct xfs_buf * bp ) ;
extern int xfs_bioerror ( struct xfs_buf * bp ) ;
extern int xfs_bioerror_relse ( struct xfs_buf * bp ) ;
extern int xfs_read_buf ( struct xfs_mount * mp , xfs_buftarg_t * btp ,
xfs_daddr_t blkno , int len , uint flags ,
struct xfs_buf * * bpp ) ;
extern void xfs_ioerror_alert ( char * func , struct xfs_mount * mp ,
xfs_buf_t * bp , xfs_daddr_t blkno ) ;
2005-04-16 15:20:36 -07:00
/*
* Prototypes for functions in xfs_vnodeops . c .
*/
2007-05-24 15:22:19 +10:00
extern int xfs_free_eofblocks ( struct xfs_mount * mp , struct xfs_inode * ip ,
int flags ) ;
2005-04-16 15:20:36 -07:00
# endif /* __XFS_RW_H__ */