2019-05-31 01:09:56 -07:00
/* SPDX-License-Identifier: GPL-2.0-only */
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
*/
# 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"
2022-04-30 23:49:17 -04:00
bool gfs2_release_folio ( struct folio * folio , gfp_t gfp_mask ) ;
2023-10-09 18:49:31 +02:00
ssize_t gfs2_internal_read ( struct gfs2_inode * ip ,
char * buf , loff_t * pos , size_t size ) ;
void gfs2_set_aops ( struct inode * inode ) ;
2009-05-22 10:01:55 +01:00
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
}
2018-10-12 20:07:27 +02:00
static inline bool gfs2_is_ordered ( const struct gfs2_sbd * sdp )
2007-10-17 08:35:19 +01:00
{
2018-10-12 20:07:27 +02:00
return sdp - > sd_args . ar_data = = GFS2_DATA_ORDERED ;
2007-10-17 08:35:19 +01:00
}
2018-10-12 20:07:27 +02:00
static inline bool gfs2_is_writeback ( const struct gfs2_sbd * sdp )
2007-10-17 08:47:38 +01:00
{
2018-10-12 20:07:27 +02:00
return sdp - > sd_args . ar_data = = GFS2_DATA_WRITEBACK ;
2007-10-17 08:47:38 +01:00
}
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 )
{
2023-10-21 21:59:03 +02:00
inode - > i_blocks = blocks < < ( inode - > i_blkbits - 9 ) ;
2008-02-12 14:17:27 +00:00
}
static inline u64 gfs2_get_inode_blocks ( const struct inode * inode )
2006-11-08 15:45:46 -05:00
{
2023-10-21 21:59:03 +02:00
return inode - > i_blocks > > ( inode - > i_blkbits - 9 ) ;
2006-11-08 15:45:46 -05:00
}
2008-02-12 14:17:27 +00:00
static inline void gfs2_add_inode_blocks ( struct inode * inode , s64 change )
{
2023-10-21 21:59:03 +02:00
change < < = inode - > i_blkbits - 9 ;
2019-03-06 07:00:43 -07:00
gfs2_assert ( GFS2_SB ( inode ) , ( change > = 0 | | inode - > i_blocks > = - change ) ) ;
2008-02-12 14:17:27 +00:00
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 ) ;
}
2010-08-11 09:53:11 +01:00
static inline int gfs2_check_internal_file_size ( struct inode * inode ,
u64 minsize , u64 maxsize )
{
u64 size = i_size_read ( inode ) ;
if ( size < minsize | | size > maxsize )
goto err ;
2016-08-02 12:05:27 -05:00
if ( size & ( BIT ( inode - > i_blkbits ) - 1 ) )
2010-08-11 09:53:11 +01:00
goto err ;
return 0 ;
err :
gfs2_consist_inode ( GFS2_I ( inode ) ) ;
return - EIO ;
}
2007-06-01 14:11:58 +01:00
2023-10-09 18:49:31 +02:00
struct inode * gfs2_inode_lookup ( struct super_block * sb , unsigned type ,
u64 no_addr , u64 no_formal_ino ,
unsigned int blktype ) ;
struct inode * gfs2_lookup_by_inum ( struct gfs2_sbd * sdp , u64 no_addr ,
u64 no_formal_ino ,
unsigned int blktype ) ;
int gfs2_inode_refresh ( struct gfs2_inode * ip ) ;
struct inode * gfs2_lookupi ( struct inode * dir , const struct qstr * name ,
int is_root ) ;
int gfs2_permission ( struct mnt_idmap * idmap ,
struct inode * inode , int mask ) ;
struct inode * gfs2_lookup_meta ( struct inode * dip , const char * name ) ;
void gfs2_dinode_out ( const struct gfs2_inode * ip , void * buf ) ;
int gfs2_open_common ( struct inode * inode , struct file * file ) ;
loff_t gfs2_seek_data ( struct file * file , loff_t offset ) ;
loff_t gfs2_seek_hole ( struct file * file , loff_t offset ) ;
2006-01-16 16:50:04 +00:00
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
2023-10-09 18:49:31 +02:00
int gfs2_fileattr_get ( struct dentry * dentry , struct fileattr * fa ) ;
int gfs2_fileattr_set ( struct mnt_idmap * idmap ,
struct dentry * dentry , struct fileattr * fa ) ;
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__ */