Commit b80d2549 authored by Jan Kara's avatar Jan Kara Committed by Linus Torvalds

[PATCH] [2/13] quota-2-formats

This patch removes most format dependent code from dquot.c and quota.h
and puts calls of callback functions instead.
parent 61d681d6
This diff is collapsed.
...@@ -586,15 +586,13 @@ struct nameidata { ...@@ -586,15 +586,13 @@ struct nameidata {
#define DQUOT_USR_ENABLED 0x01 /* User diskquotas enabled */ #define DQUOT_USR_ENABLED 0x01 /* User diskquotas enabled */
#define DQUOT_GRP_ENABLED 0x02 /* Group diskquotas enabled */ #define DQUOT_GRP_ENABLED 0x02 /* Group diskquotas enabled */
struct quota_mount_options struct quota_info {
{
unsigned int flags; /* Flags for diskquotas on this device */ unsigned int flags; /* Flags for diskquotas on this device */
struct semaphore dqio_sem; /* lock device while I/O in progress */ struct semaphore dqio_sem; /* lock device while I/O in progress */
struct semaphore dqoff_sem; /* serialize quota_off() and quota_on() on device */ struct semaphore dqoff_sem; /* serialize quota_off() and quota_on() on device */
struct file *files[MAXQUOTAS]; /* fp's to quotafiles */ struct file *files[MAXQUOTAS]; /* fp's to quotafiles */
time_t inode_expire[MAXQUOTAS]; /* expiretime for inode-quota */ struct mem_dqinfo info[MAXQUOTAS]; /* Information for each quota type */
time_t block_expire[MAXQUOTAS]; /* expiretime for block-quota */ struct quota_format_ops *ops[MAXQUOTAS]; /* Operations for each format */
char rsquash[MAXQUOTAS]; /* for quotas threat root as any other user */
}; };
/* /*
...@@ -643,7 +641,7 @@ struct super_block { ...@@ -643,7 +641,7 @@ struct super_block {
struct block_device *s_bdev; struct block_device *s_bdev;
struct list_head s_instances; struct list_head s_instances;
struct quota_mount_options s_dquot; /* Diskquota specific options */ struct quota_info s_dquot; /* Diskquota specific options */
char s_id[32]; /* Informational name */ char s_id[32]; /* Informational name */
......
...@@ -40,10 +40,13 @@ ...@@ -40,10 +40,13 @@
#define _LINUX_QUOTA_ #define _LINUX_QUOTA_
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/types.h>
#define __DQUOT_VERSION__ "dquot_6.5.1" #define __DQUOT_VERSION__ "dquot_6.5.1"
#define __DQUOT_NUM_VERSION__ 6*10000+5*100+1 #define __DQUOT_NUM_VERSION__ 6*10000+5*100+1
typedef __kernel_uid32_t qid_t; /* Type in which we store ids in memory */
/* /*
* Convert diskblocks to blocks and the other way around. * Convert diskblocks to blocks and the other way around.
*/ */
...@@ -94,22 +97,12 @@ ...@@ -94,22 +97,12 @@
#define SUBCMDSHIFT 8 #define SUBCMDSHIFT 8
#define QCMD(cmd, type) (((cmd) << SUBCMDSHIFT) | ((type) & SUBCMDMASK)) #define QCMD(cmd, type) (((cmd) << SUBCMDSHIFT) | ((type) & SUBCMDMASK))
#define Q_QUOTAON 0x0100 /* enable quotas */
#define Q_QUOTAOFF 0x0200 /* disable quotas */
#define Q_GETQUOTA 0x0300 /* get limits and usage */
#define Q_SETQUOTA 0x0400 /* set limits and usage */
#define Q_SETUSE 0x0500 /* set usage */
#define Q_SYNC 0x0600 /* sync disk copy of a filesystems quotas */ #define Q_SYNC 0x0600 /* sync disk copy of a filesystems quotas */
#define Q_SETQLIM 0x0700 /* set limits */
#define Q_GETSTATS 0x0800 /* get collected stats */
#define Q_RSQUASH 0x1000 /* set root_squash option */
/* /*
* The following structure defines the format of the disk quota file * Data for one user/group kept in memory
* (as it appears on disk) - the file is an array of these structures
* indexed by user or group number.
*/ */
struct dqblk { struct mem_dqblk {
__u32 dqb_bhardlimit; /* absolute limit on disk blks alloc */ __u32 dqb_bhardlimit; /* absolute limit on disk blks alloc */
__u32 dqb_bsoftlimit; /* preferred limit on disk blks */ __u32 dqb_bsoftlimit; /* preferred limit on disk blks */
__u32 dqb_curblocks; /* current block count */ __u32 dqb_curblocks; /* current block count */
...@@ -120,6 +113,33 @@ struct dqblk { ...@@ -120,6 +113,33 @@ struct dqblk {
time_t dqb_itime; /* time limit for excessive inode use */ time_t dqb_itime; /* time limit for excessive inode use */
}; };
/*
* Data for one quotafile kept in memory
*/
struct mem_dqinfo {
int dqi_flags;
unsigned int dqi_bgrace;
unsigned int dqi_igrace;
union {
} u;
};
#ifdef __KERNEL__
#define DQF_MASK 0xffff /* Mask for format specific flags */
#define DQF_INFO_DIRTY 0x10000 /* Is info dirty? */
extern inline void mark_info_dirty(struct mem_dqinfo *info)
{
info->dqi_flags |= DQF_INFO_DIRTY;
}
#define info_dirty(info) ((info)->dqi_flags & DQF_INFO_DIRTY)
#define sb_dqopt(sb) (&(sb)->s_dquot)
#endif /* __KERNEL__ */
/* /*
* Shorthand notation. * Shorthand notation.
*/ */
...@@ -134,6 +154,11 @@ struct dqblk { ...@@ -134,6 +154,11 @@ struct dqblk {
#define dqoff(UID) ((loff_t)((UID) * sizeof (struct dqblk))) #define dqoff(UID) ((loff_t)((UID) * sizeof (struct dqblk)))
#ifdef __KERNEL__
extern int nr_dquots, nr_free_dquots;
extern int dquot_root_squash;
struct dqstats { struct dqstats {
__u32 lookups; __u32 lookups;
__u32 drops; __u32 drops;
...@@ -145,10 +170,6 @@ struct dqstats { ...@@ -145,10 +170,6 @@ struct dqstats {
__u32 syncs; __u32 syncs;
}; };
#ifdef __KERNEL__
extern int dquot_root_squash;
#define NR_DQHASH 43 /* Just an arbitrary number */ #define NR_DQHASH 43 /* Just an arbitrary number */
#define DQ_LOCKED 0x01 /* dquot under IO */ #define DQ_LOCKED 0x01 /* dquot under IO */
...@@ -174,21 +195,31 @@ struct dquot { ...@@ -174,21 +195,31 @@ struct dquot {
short dq_flags; /* See DQ_* */ short dq_flags; /* See DQ_* */
unsigned long dq_referenced; /* Number of times this dquot was unsigned long dq_referenced; /* Number of times this dquot was
referenced during its lifetime */ referenced during its lifetime */
struct dqblk dq_dqb; /* Diskquota usage */ struct mem_dqblk dq_dqb; /* Diskquota usage */
}; };
#define NODQUOT (struct dquot *)NULL extern inline void mark_dquot_dirty(struct dquot *dquot)
{
dquot->dq_flags |= DQ_MOD;
}
/* #define dquot_dirty(dquot) ((dquot)->dq_flags & DQ_MOD)
* Flags used for set_dqblk.
*/ #define NODQUOT (struct dquot *)NULL
#define SET_QUOTA 0x02
#define SET_USE 0x04
#define SET_QLIMIT 0x08
#define QUOTA_OK 0 #define QUOTA_OK 0
#define NO_QUOTA 1 #define NO_QUOTA 1
/* Operations which must be implemented by each quota format */
struct quota_format_ops {
int (*check_quota_file)(struct super_block *sb, int type); /* Detect whether file is in our format */
int (*read_file_info)(struct super_block *sb, int type); /* Read main info about file */
int (*write_file_info)(struct super_block *sb, int type); /* Write main info about file */
int (*free_file_info)(struct super_block *sb, int type); /* Called on quotaoff() */
int (*read_dqblk)(struct dquot *dquot); /* Read structure for one user */
int (*commit_dqblk)(struct dquot *dquot); /* Write (or delete) structure for one user */
};
#else #else
# /* nodep */ include <sys/cdefs.h> # /* nodep */ include <sys/cdefs.h>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment