ext4: quota macros cleanup
Currently all quota block reservation macros contains hard-coded "2" aka MAXQUOTAS value. This is no good because in some places it is not obvious to understand what does this digit represent. Let's introduce new macro with self descriptive name. Signed-off-by: Dmitry Monakhov <dmonakhov@openvz.org> Acked-by: Mingming Cao <cmm@us.ibm.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
This commit is contained in:
parent
8aa6790f87
commit
5aca07eb7d
@ -49,7 +49,7 @@
|
|||||||
|
|
||||||
#define EXT4_DATA_TRANS_BLOCKS(sb) (EXT4_SINGLEDATA_TRANS_BLOCKS(sb) + \
|
#define EXT4_DATA_TRANS_BLOCKS(sb) (EXT4_SINGLEDATA_TRANS_BLOCKS(sb) + \
|
||||||
EXT4_XATTR_TRANS_BLOCKS - 2 + \
|
EXT4_XATTR_TRANS_BLOCKS - 2 + \
|
||||||
2*EXT4_QUOTA_TRANS_BLOCKS(sb))
|
EXT4_MAXQUOTAS_TRANS_BLOCKS(sb))
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Define the number of metadata blocks we need to account to modify data.
|
* Define the number of metadata blocks we need to account to modify data.
|
||||||
@ -57,7 +57,7 @@
|
|||||||
* This include super block, inode block, quota blocks and xattr blocks
|
* This include super block, inode block, quota blocks and xattr blocks
|
||||||
*/
|
*/
|
||||||
#define EXT4_META_TRANS_BLOCKS(sb) (EXT4_XATTR_TRANS_BLOCKS + \
|
#define EXT4_META_TRANS_BLOCKS(sb) (EXT4_XATTR_TRANS_BLOCKS + \
|
||||||
2*EXT4_QUOTA_TRANS_BLOCKS(sb))
|
EXT4_MAXQUOTAS_TRANS_BLOCKS(sb))
|
||||||
|
|
||||||
/* Delete operations potentially hit one directory's namespace plus an
|
/* Delete operations potentially hit one directory's namespace plus an
|
||||||
* entire inode, plus arbitrary amounts of bitmap/indirection data. Be
|
* entire inode, plus arbitrary amounts of bitmap/indirection data. Be
|
||||||
@ -92,6 +92,7 @@
|
|||||||
* but inode, sb and group updates are done only once */
|
* but inode, sb and group updates are done only once */
|
||||||
#define EXT4_QUOTA_INIT_BLOCKS(sb) (test_opt(sb, QUOTA) ? (DQUOT_INIT_ALLOC*\
|
#define EXT4_QUOTA_INIT_BLOCKS(sb) (test_opt(sb, QUOTA) ? (DQUOT_INIT_ALLOC*\
|
||||||
(EXT4_SINGLEDATA_TRANS_BLOCKS(sb)-3)+3+DQUOT_INIT_REWRITE) : 0)
|
(EXT4_SINGLEDATA_TRANS_BLOCKS(sb)-3)+3+DQUOT_INIT_REWRITE) : 0)
|
||||||
|
|
||||||
#define EXT4_QUOTA_DEL_BLOCKS(sb) (test_opt(sb, QUOTA) ? (DQUOT_DEL_ALLOC*\
|
#define EXT4_QUOTA_DEL_BLOCKS(sb) (test_opt(sb, QUOTA) ? (DQUOT_DEL_ALLOC*\
|
||||||
(EXT4_SINGLEDATA_TRANS_BLOCKS(sb)-3)+3+DQUOT_DEL_REWRITE) : 0)
|
(EXT4_SINGLEDATA_TRANS_BLOCKS(sb)-3)+3+DQUOT_DEL_REWRITE) : 0)
|
||||||
#else
|
#else
|
||||||
@ -99,6 +100,9 @@
|
|||||||
#define EXT4_QUOTA_INIT_BLOCKS(sb) 0
|
#define EXT4_QUOTA_INIT_BLOCKS(sb) 0
|
||||||
#define EXT4_QUOTA_DEL_BLOCKS(sb) 0
|
#define EXT4_QUOTA_DEL_BLOCKS(sb) 0
|
||||||
#endif
|
#endif
|
||||||
|
#define EXT4_MAXQUOTAS_TRANS_BLOCKS(sb) (MAXQUOTAS*EXT4_QUOTA_TRANS_BLOCKS(sb))
|
||||||
|
#define EXT4_MAXQUOTAS_INIT_BLOCKS(sb) (MAXQUOTAS*EXT4_QUOTA_INIT_BLOCKS(sb))
|
||||||
|
#define EXT4_MAXQUOTAS_DEL_BLOCKS(sb) (MAXQUOTAS*EXT4_QUOTA_DEL_BLOCKS(sb))
|
||||||
|
|
||||||
int
|
int
|
||||||
ext4_mark_iloc_dirty(handle_t *handle,
|
ext4_mark_iloc_dirty(handle_t *handle,
|
||||||
|
@ -2161,7 +2161,7 @@ ext4_ext_rm_leaf(handle_t *handle, struct inode *inode,
|
|||||||
correct_index = 1;
|
correct_index = 1;
|
||||||
credits += (ext_depth(inode)) + 1;
|
credits += (ext_depth(inode)) + 1;
|
||||||
}
|
}
|
||||||
credits += 2 * EXT4_QUOTA_TRANS_BLOCKS(inode->i_sb);
|
credits += EXT4_MAXQUOTAS_TRANS_BLOCKS(inode->i_sb);
|
||||||
|
|
||||||
err = ext4_ext_truncate_extend_restart(handle, inode, credits);
|
err = ext4_ext_truncate_extend_restart(handle, inode, credits);
|
||||||
if (err)
|
if (err)
|
||||||
|
@ -5175,7 +5175,7 @@ int ext4_setattr(struct dentry *dentry, struct iattr *attr)
|
|||||||
|
|
||||||
/* (user+group)*(old+new) structure, inode write (sb,
|
/* (user+group)*(old+new) structure, inode write (sb,
|
||||||
* inode block, ? - but truncate inode update has it) */
|
* inode block, ? - but truncate inode update has it) */
|
||||||
handle = ext4_journal_start(inode, 2*(EXT4_QUOTA_INIT_BLOCKS(inode->i_sb)+
|
handle = ext4_journal_start(inode, (EXT4_MAXQUOTAS_INIT_BLOCKS(inode->i_sb)+
|
||||||
EXT4_QUOTA_DEL_BLOCKS(inode->i_sb))+3);
|
EXT4_QUOTA_DEL_BLOCKS(inode->i_sb))+3);
|
||||||
if (IS_ERR(handle)) {
|
if (IS_ERR(handle)) {
|
||||||
error = PTR_ERR(handle);
|
error = PTR_ERR(handle);
|
||||||
|
@ -238,7 +238,7 @@ static int extend_credit_for_blkdel(handle_t *handle, struct inode *inode)
|
|||||||
* So allocate a credit of 3. We may update
|
* So allocate a credit of 3. We may update
|
||||||
* quota (user and group).
|
* quota (user and group).
|
||||||
*/
|
*/
|
||||||
needed = 3 + 2*EXT4_QUOTA_TRANS_BLOCKS(inode->i_sb);
|
needed = 3 + EXT4_MAXQUOTAS_TRANS_BLOCKS(inode->i_sb);
|
||||||
|
|
||||||
if (ext4_journal_extend(handle, needed) != 0)
|
if (ext4_journal_extend(handle, needed) != 0)
|
||||||
retval = ext4_journal_restart(handle, needed);
|
retval = ext4_journal_restart(handle, needed);
|
||||||
@ -486,7 +486,7 @@ int ext4_ext_migrate(struct inode *inode)
|
|||||||
handle = ext4_journal_start(inode,
|
handle = ext4_journal_start(inode,
|
||||||
EXT4_DATA_TRANS_BLOCKS(inode->i_sb) +
|
EXT4_DATA_TRANS_BLOCKS(inode->i_sb) +
|
||||||
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
||||||
2 * EXT4_QUOTA_INIT_BLOCKS(inode->i_sb)
|
EXT4_MAXQUOTAS_INIT_BLOCKS(inode->i_sb)
|
||||||
+ 1);
|
+ 1);
|
||||||
if (IS_ERR(handle)) {
|
if (IS_ERR(handle)) {
|
||||||
retval = PTR_ERR(handle);
|
retval = PTR_ERR(handle);
|
||||||
|
@ -1769,7 +1769,7 @@ static int ext4_create(struct inode *dir, struct dentry *dentry, int mode,
|
|||||||
retry:
|
retry:
|
||||||
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
||||||
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
||||||
2*EXT4_QUOTA_INIT_BLOCKS(dir->i_sb));
|
EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb));
|
||||||
if (IS_ERR(handle))
|
if (IS_ERR(handle))
|
||||||
return PTR_ERR(handle);
|
return PTR_ERR(handle);
|
||||||
|
|
||||||
@ -1803,7 +1803,7 @@ static int ext4_mknod(struct inode *dir, struct dentry *dentry,
|
|||||||
retry:
|
retry:
|
||||||
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
||||||
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
||||||
2*EXT4_QUOTA_INIT_BLOCKS(dir->i_sb));
|
EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb));
|
||||||
if (IS_ERR(handle))
|
if (IS_ERR(handle))
|
||||||
return PTR_ERR(handle);
|
return PTR_ERR(handle);
|
||||||
|
|
||||||
@ -1840,7 +1840,7 @@ static int ext4_mkdir(struct inode *dir, struct dentry *dentry, int mode)
|
|||||||
retry:
|
retry:
|
||||||
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
||||||
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 +
|
||||||
2*EXT4_QUOTA_INIT_BLOCKS(dir->i_sb));
|
EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb));
|
||||||
if (IS_ERR(handle))
|
if (IS_ERR(handle))
|
||||||
return PTR_ERR(handle);
|
return PTR_ERR(handle);
|
||||||
|
|
||||||
@ -2253,7 +2253,7 @@ static int ext4_symlink(struct inode *dir,
|
|||||||
retry:
|
retry:
|
||||||
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) +
|
||||||
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 5 +
|
EXT4_INDEX_EXTRA_TRANS_BLOCKS + 5 +
|
||||||
2*EXT4_QUOTA_INIT_BLOCKS(dir->i_sb));
|
EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb));
|
||||||
if (IS_ERR(handle))
|
if (IS_ERR(handle))
|
||||||
return PTR_ERR(handle);
|
return PTR_ERR(handle);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user