|
@@ -117,6 +117,9 @@ static struct inode *jfs_alloc_inode(struct super_block *sb)
|
|
|
jfs_inode = kmem_cache_alloc(jfs_inode_cachep, GFP_NOFS);
|
|
|
if (!jfs_inode)
|
|
|
return NULL;
|
|
|
+#ifdef CONFIG_QUOTA
|
|
|
+ memset(&jfs_inode->i_dquot, 0, sizeof(jfs_inode->i_dquot));
|
|
|
+#endif
|
|
|
return &jfs_inode->vfs_inode;
|
|
|
}
|
|
|
|
|
@@ -537,6 +540,7 @@ static int jfs_fill_super(struct super_block *sb, void *data, int silent)
|
|
|
#ifdef CONFIG_QUOTA
|
|
|
sb->dq_op = &dquot_operations;
|
|
|
sb->s_qcop = &dquot_quotactl_ops;
|
|
|
+ sb->s_quota_types = QTYPE_MASK_USR | QTYPE_MASK_GRP;
|
|
|
#endif
|
|
|
|
|
|
/*
|
|
@@ -836,6 +840,10 @@ out:
|
|
|
return len - towrite;
|
|
|
}
|
|
|
|
|
|
+static struct dquot **jfs_get_dquots(struct inode *inode)
|
|
|
+{
|
|
|
+ return JFS_IP(inode)->i_dquot;
|
|
|
+}
|
|
|
#endif
|
|
|
|
|
|
static const struct super_operations jfs_super_operations = {
|
|
@@ -854,6 +862,7 @@ static const struct super_operations jfs_super_operations = {
|
|
|
#ifdef CONFIG_QUOTA
|
|
|
.quota_read = jfs_quota_read,
|
|
|
.quota_write = jfs_quota_write,
|
|
|
+ .get_dquots = jfs_get_dquots,
|
|
|
#endif
|
|
|
};
|
|
|
|