2006-01-16 16:50:04 +00:00
/*
* Copyright ( C ) Sistina Software , Inc . 1997 - 2003 All rights reserved .
2006-05-18 15:09:15 -04:00
* Copyright ( C ) 2004 - 2006 Red Hat , Inc . All rights reserved .
2006-01-16 16:50:04 +00:00
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2006-09-01 11:05:15 -04:00
* of the GNU General Public License version 2.
2006-01-16 16:50:04 +00:00
*/
# ifndef __INODE_DOT_H__
# define __INODE_DOT_H__
2008-10-14 16:05:55 +01:00
# include <linux/fs.h>
2009-05-22 10:01:55 +01:00
# include <linux/buffer_head.h>
# include <linux/mm.h>
2008-02-12 14:17:27 +00:00
# include "util.h"
2009-05-22 10:01:55 +01:00
extern int gfs2_releasepage ( struct page * page , gfp_t gfp_mask ) ;
extern int gfs2_internal_read ( struct gfs2_inode * ip ,
struct file_ra_state * ra_state ,
char * buf , loff_t * pos , unsigned size ) ;
extern void gfs2_set_aops ( struct inode * inode ) ;
2007-05-15 15:37:50 +01:00
static inline int gfs2_is_stuffed ( const struct gfs2_inode * ip )
2006-01-16 16:50:04 +00:00
{
2008-01-28 10:37:35 +00:00
return ! ip - > i_height ;
2006-01-16 16:50:04 +00:00
}
2007-05-15 15:37:50 +01:00
static inline int gfs2_is_jdata ( const struct gfs2_inode * ip )
2006-01-16 16:50:04 +00:00
{
2008-11-04 10:05:22 +00:00
return ip - > i_diskflags & GFS2_DIF_JDATA ;
2006-01-16 16:50:04 +00:00
}
2007-10-17 08:35:19 +01:00
static inline int gfs2_is_writeback ( const struct gfs2_inode * ip )
{
const struct gfs2_sbd * sdp = GFS2_SB ( & ip - > i_inode ) ;
return ( sdp - > sd_args . ar_data = = GFS2_DATA_WRITEBACK ) & & ! gfs2_is_jdata ( ip ) ;
}
2007-10-17 08:47:38 +01:00
static inline int gfs2_is_ordered ( const struct gfs2_inode * ip )
{
const struct gfs2_sbd * sdp = GFS2_SB ( & ip - > i_inode ) ;
return ( sdp - > sd_args . ar_data = = GFS2_DATA_ORDERED ) & & ! gfs2_is_jdata ( ip ) ;
}
2007-05-15 15:37:50 +01:00
static inline int gfs2_is_dir ( const struct gfs2_inode * ip )
2006-02-08 11:50:51 +00:00
{
2006-11-01 12:22:46 -05:00
return S_ISDIR ( ip - > i_inode . i_mode ) ;
2006-02-08 11:50:51 +00:00
}
2008-02-12 14:17:27 +00:00
static inline void gfs2_set_inode_blocks ( struct inode * inode , u64 blocks )
{
inode - > i_blocks = blocks < <
( GFS2_SB ( inode ) - > sd_sb . sb_bsize_shift - GFS2_BASIC_BLOCK_SHIFT ) ;
}
static inline u64 gfs2_get_inode_blocks ( const struct inode * inode )
2006-11-08 15:45:46 -05:00
{
2008-02-12 14:17:27 +00:00
return inode - > i_blocks > >
2006-11-08 15:45:46 -05:00
( GFS2_SB ( inode ) - > sd_sb . sb_bsize_shift - GFS2_BASIC_BLOCK_SHIFT ) ;
}
2008-02-12 14:17:27 +00:00
static inline void gfs2_add_inode_blocks ( struct inode * inode , s64 change )
{
gfs2_assert ( GFS2_SB ( inode ) , ( change > = 0 | | inode - > i_blocks > - change ) ) ;
change * = ( GFS2_SB ( inode ) - > sd_sb . sb_bsize / GFS2_BASIC_BLOCK ) ;
inode - > i_blocks + = change ;
}
2007-05-15 15:37:50 +01:00
static inline int gfs2_check_inum ( const struct gfs2_inode * ip , u64 no_addr ,
u64 no_formal_ino )
{
return ip - > i_no_addr = = no_addr & & ip - > i_no_formal_ino = = no_formal_ino ;
}
2007-06-01 14:11:58 +01:00
static inline void gfs2_inum_out ( const struct gfs2_inode * ip ,
struct gfs2_dirent * dent )
{
dent - > de_inum . no_formal_ino = cpu_to_be64 ( ip - > i_no_formal_ino ) ;
dent - > de_inum . no_addr = cpu_to_be64 ( ip - > i_no_addr ) ;
}
2009-05-22 10:01:55 +01:00
extern void gfs2_set_iop ( struct inode * inode ) ;
extern struct inode * gfs2_inode_lookup ( struct super_block * sb , unsigned type ,
u64 no_addr , u64 no_formal_ino ,
int skip_freeing ) ;
extern struct inode * gfs2_ilookup ( struct super_block * sb , u64 no_addr ) ;
extern int gfs2_inode_refresh ( struct gfs2_inode * ip ) ;
extern int gfs2_dinode_dealloc ( struct gfs2_inode * inode ) ;
extern int gfs2_change_nlink ( struct gfs2_inode * ip , int diff ) ;
extern struct inode * gfs2_lookupi ( struct inode * dir , const struct qstr * name ,
int is_root ) ;
extern struct inode * gfs2_createi ( struct gfs2_holder * ghs ,
const struct qstr * name ,
unsigned int mode , dev_t dev ) ;
extern int gfs2_unlink_ok ( struct gfs2_inode * dip , const struct qstr * name ,
const struct gfs2_inode * ip ) ;
extern int gfs2_permission ( struct inode * inode , int mask ) ;
extern int gfs2_readlinki ( struct gfs2_inode * ip , char * * buf , unsigned int * len ) ;
extern int gfs2_setattr_simple ( struct gfs2_inode * ip , struct iattr * attr ) ;
extern struct inode * gfs2_lookup_simple ( struct inode * dip , const char * name ) ;
extern void gfs2_dinode_out ( const struct gfs2_inode * ip , void * buf ) ;
extern void gfs2_dinode_print ( const struct gfs2_inode * ip ) ;
2006-01-16 16:50:04 +00:00
2008-10-14 16:05:55 +01:00
extern const struct inode_operations gfs2_file_iops ;
extern const struct inode_operations gfs2_dir_iops ;
extern const struct inode_operations gfs2_symlink_iops ;
2009-04-07 19:42:17 +02:00
extern const struct file_operations gfs2_file_fops_nolock ;
extern const struct file_operations gfs2_dir_fops_nolock ;
2008-10-14 16:05:55 +01:00
extern void gfs2_set_inode_flags ( struct inode * inode ) ;
2009-01-12 10:43:39 +00:00
# ifdef CONFIG_GFS2_FS_LOCKING_DLM
2009-04-07 19:42:17 +02:00
extern const struct file_operations gfs2_file_fops ;
extern const struct file_operations gfs2_dir_fops ;
2009-01-12 10:43:39 +00:00
static inline int gfs2_localflocks ( const struct gfs2_sbd * sdp )
{
return sdp - > sd_args . ar_localflocks ;
}
# else /* Single node only */
2009-04-07 19:42:17 +02:00
# define gfs2_file_fops gfs2_file_fops_nolock
# define gfs2_dir_fops gfs2_dir_fops_nolock
2009-01-12 10:43:39 +00:00
static inline int gfs2_localflocks ( const struct gfs2_sbd * sdp )
{
return 1 ;
}
# endif /* CONFIG_GFS2_FS_LOCKING_DLM */
2008-10-14 16:05:55 +01:00
2006-01-16 16:50:04 +00:00
# endif /* __INODE_DOT_H__ */