2019-05-31 11:09:56 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2006-01-16 19:50:04 +03:00
/*
* Copyright ( C ) Sistina Software , Inc . 1997 - 2003 All rights reserved .
2006-05-18 23:09:15 +04:00
* Copyright ( C ) 2004 - 2006 Red Hat , Inc . All rights reserved .
2006-01-16 19:50:04 +03:00
*/
# ifndef __QUOTA_DOT_H__
# define __QUOTA_DOT_H__
2013-11-04 14:15:08 +04:00
# include <linux/list_lru.h>
2006-09-05 18:39:21 +04:00
struct gfs2_inode ;
struct gfs2_sbd ;
2013-02-01 05:49:26 +04:00
# define NO_UID_QUOTA_CHANGE INVALID_UID
# define NO_GID_QUOTA_CHANGE INVALID_GID
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
int gfs2_qa_get ( struct gfs2_inode * ip ) ;
void gfs2_qa_put ( struct gfs2_inode * ip ) ;
int gfs2_quota_hold ( struct gfs2_inode * ip , kuid_t uid , kgid_t gid ) ;
void gfs2_quota_unhold ( struct gfs2_inode * ip ) ;
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
int gfs2_quota_lock ( struct gfs2_inode * ip , kuid_t uid , kgid_t gid ) ;
void gfs2_quota_unlock ( struct gfs2_inode * ip ) ;
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
int gfs2_quota_check ( struct gfs2_inode * ip , kuid_t uid , kgid_t gid ,
struct gfs2_alloc_parms * ap ) ;
void gfs2_quota_change ( struct gfs2_inode * ip , s64 change ,
kuid_t uid , kgid_t gid ) ;
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
int gfs2_quota_sync ( struct super_block * sb , int type ) ;
int gfs2_quota_refresh ( struct gfs2_sbd * sdp , struct kqid qid ) ;
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
int gfs2_quota_init ( struct gfs2_sbd * sdp ) ;
void gfs2_quota_cleanup ( struct gfs2_sbd * sdp ) ;
int gfs2_quotad ( void * data ) ;
2006-01-16 19:50:04 +03:00
2023-10-09 19:49:31 +03:00
void gfs2_wake_up_statfs ( struct gfs2_sbd * sdp ) ;
2009-10-20 11:39:44 +04:00
2015-03-18 20:03:41 +03:00
static inline int gfs2_quota_lock_check ( struct gfs2_inode * ip ,
struct gfs2_alloc_parms * ap )
2008-03-10 18:34:50 +03:00
{
struct gfs2_sbd * sdp = GFS2_SB ( & ip - > i_inode ) ;
int ret ;
2018-02-20 18:03:24 +03:00
ap - > allowed = UINT_MAX ; /* Assume we are permitted a whole lot */
2020-05-05 19:53:21 +03:00
if ( capable ( CAP_SYS_RESOURCE ) | |
sdp - > sd_args . ar_quota = = GFS2_QUOTA_OFF )
2008-03-10 18:34:50 +03:00
return 0 ;
2013-02-01 05:49:26 +04:00
ret = gfs2_quota_lock ( ip , NO_UID_QUOTA_CHANGE , NO_GID_QUOTA_CHANGE ) ;
2008-03-10 18:34:50 +03:00
if ( ret )
return ret ;
2023-10-22 01:06:41 +03:00
if ( sdp - > sd_args . ar_quota = = GFS2_QUOTA_ACCOUNT )
2008-03-10 18:34:50 +03:00
return 0 ;
2015-03-18 20:03:41 +03:00
ret = gfs2_quota_check ( ip , ip - > i_inode . i_uid , ip - > i_inode . i_gid , ap ) ;
2008-03-10 18:34:50 +03:00
if ( ret )
gfs2_quota_unlock ( ip ) ;
return ret ;
}
2009-09-15 12:59:02 +04:00
extern const struct quotactl_ops gfs2_quotactl_ops ;
2023-09-11 12:44:08 +03:00
int __init gfs2_qd_shrinker_init ( void ) ;
void gfs2_qd_shrinker_exit ( void ) ;
2013-11-04 14:15:08 +04:00
extern struct list_lru gfs2_qd_lru ;
2023-10-09 19:49:31 +03:00
void __init gfs2_quota_hash_init ( void ) ;
2009-01-08 01:03:37 +03:00
2006-01-16 19:50:04 +03:00
# endif /* __QUOTA_DOT_H__ */