diff options
-rw-r--r-- | fs/quota/dquot.c | 10 | ||||
-rw-r--r-- | include/linux/quotaops.h | 11 |
2 files changed, 15 insertions, 6 deletions
diff --git a/fs/quota/dquot.c b/fs/quota/dquot.c index 3fc62b097bed..7b980954993b 100644 --- a/fs/quota/dquot.c +++ b/fs/quota/dquot.c | |||
@@ -1351,28 +1351,30 @@ static qsize_t *inode_reserved_space(struct inode * inode) | |||
1351 | return inode->i_sb->dq_op->get_reserved_space(inode); | 1351 | return inode->i_sb->dq_op->get_reserved_space(inode); |
1352 | } | 1352 | } |
1353 | 1353 | ||
1354 | static void inode_add_rsv_space(struct inode *inode, qsize_t number) | 1354 | void inode_add_rsv_space(struct inode *inode, qsize_t number) |
1355 | { | 1355 | { |
1356 | spin_lock(&inode->i_lock); | 1356 | spin_lock(&inode->i_lock); |
1357 | *inode_reserved_space(inode) += number; | 1357 | *inode_reserved_space(inode) += number; |
1358 | spin_unlock(&inode->i_lock); | 1358 | spin_unlock(&inode->i_lock); |
1359 | } | 1359 | } |
1360 | EXPORT_SYMBOL(inode_add_rsv_space); | ||
1360 | 1361 | ||
1361 | 1362 | void inode_claim_rsv_space(struct inode *inode, qsize_t number) | |
1362 | static void inode_claim_rsv_space(struct inode *inode, qsize_t number) | ||
1363 | { | 1363 | { |
1364 | spin_lock(&inode->i_lock); | 1364 | spin_lock(&inode->i_lock); |
1365 | *inode_reserved_space(inode) -= number; | 1365 | *inode_reserved_space(inode) -= number; |
1366 | __inode_add_bytes(inode, number); | 1366 | __inode_add_bytes(inode, number); |
1367 | spin_unlock(&inode->i_lock); | 1367 | spin_unlock(&inode->i_lock); |
1368 | } | 1368 | } |
1369 | EXPORT_SYMBOL(inode_claim_rsv_space); | ||
1369 | 1370 | ||
1370 | static void inode_sub_rsv_space(struct inode *inode, qsize_t number) | 1371 | void inode_sub_rsv_space(struct inode *inode, qsize_t number) |
1371 | { | 1372 | { |
1372 | spin_lock(&inode->i_lock); | 1373 | spin_lock(&inode->i_lock); |
1373 | *inode_reserved_space(inode) -= number; | 1374 | *inode_reserved_space(inode) -= number; |
1374 | spin_unlock(&inode->i_lock); | 1375 | spin_unlock(&inode->i_lock); |
1375 | } | 1376 | } |
1377 | EXPORT_SYMBOL(inode_sub_rsv_space); | ||
1376 | 1378 | ||
1377 | static qsize_t inode_get_rsv_space(struct inode *inode) | 1379 | static qsize_t inode_get_rsv_space(struct inode *inode) |
1378 | { | 1380 | { |
diff --git a/include/linux/quotaops.h b/include/linux/quotaops.h index 3ebb23153640..a529d86e7e73 100644 --- a/include/linux/quotaops.h +++ b/include/linux/quotaops.h | |||
@@ -26,6 +26,10 @@ static inline void writeout_quota_sb(struct super_block *sb, int type) | |||
26 | sb->s_qcop->quota_sync(sb, type); | 26 | sb->s_qcop->quota_sync(sb, type); |
27 | } | 27 | } |
28 | 28 | ||
29 | void inode_add_rsv_space(struct inode *inode, qsize_t number); | ||
30 | void inode_claim_rsv_space(struct inode *inode, qsize_t number); | ||
31 | void inode_sub_rsv_space(struct inode *inode, qsize_t number); | ||
32 | |||
29 | int dquot_initialize(struct inode *inode, int type); | 33 | int dquot_initialize(struct inode *inode, int type); |
30 | int dquot_drop(struct inode *inode); | 34 | int dquot_drop(struct inode *inode); |
31 | struct dquot *dqget(struct super_block *sb, unsigned int id, int type); | 35 | struct dquot *dqget(struct super_block *sb, unsigned int id, int type); |
@@ -42,7 +46,6 @@ int dquot_alloc_inode(const struct inode *inode, qsize_t number); | |||
42 | int dquot_reserve_space(struct inode *inode, qsize_t number, int prealloc); | 46 | int dquot_reserve_space(struct inode *inode, qsize_t number, int prealloc); |
43 | int dquot_claim_space(struct inode *inode, qsize_t number); | 47 | int dquot_claim_space(struct inode *inode, qsize_t number); |
44 | void dquot_release_reserved_space(struct inode *inode, qsize_t number); | 48 | void dquot_release_reserved_space(struct inode *inode, qsize_t number); |
45 | qsize_t dquot_get_reserved_space(struct inode *inode); | ||
46 | 49 | ||
47 | int dquot_free_space(struct inode *inode, qsize_t number); | 50 | int dquot_free_space(struct inode *inode, qsize_t number); |
48 | int dquot_free_inode(const struct inode *inode, qsize_t number); | 51 | int dquot_free_inode(const struct inode *inode, qsize_t number); |
@@ -199,6 +202,8 @@ static inline int vfs_dq_reserve_space(struct inode *inode, qsize_t nr) | |||
199 | if (inode->i_sb->dq_op->reserve_space(inode, nr, 0) == NO_QUOTA) | 202 | if (inode->i_sb->dq_op->reserve_space(inode, nr, 0) == NO_QUOTA) |
200 | return 1; | 203 | return 1; |
201 | } | 204 | } |
205 | else | ||
206 | inode_add_rsv_space(inode, nr); | ||
202 | return 0; | 207 | return 0; |
203 | } | 208 | } |
204 | 209 | ||
@@ -221,7 +226,7 @@ static inline int vfs_dq_claim_space(struct inode *inode, qsize_t nr) | |||
221 | if (inode->i_sb->dq_op->claim_space(inode, nr) == NO_QUOTA) | 226 | if (inode->i_sb->dq_op->claim_space(inode, nr) == NO_QUOTA) |
222 | return 1; | 227 | return 1; |
223 | } else | 228 | } else |
224 | inode_add_bytes(inode, nr); | 229 | inode_claim_rsv_space(inode, nr); |
225 | 230 | ||
226 | mark_inode_dirty(inode); | 231 | mark_inode_dirty(inode); |
227 | return 0; | 232 | return 0; |
@@ -235,6 +240,8 @@ void vfs_dq_release_reservation_space(struct inode *inode, qsize_t nr) | |||
235 | { | 240 | { |
236 | if (sb_any_quota_active(inode->i_sb)) | 241 | if (sb_any_quota_active(inode->i_sb)) |
237 | inode->i_sb->dq_op->release_rsv(inode, nr); | 242 | inode->i_sb->dq_op->release_rsv(inode, nr); |
243 | else | ||
244 | inode_sub_rsv_space(inode, nr); | ||
238 | } | 245 | } |
239 | 246 | ||
240 | static inline void vfs_dq_free_space_nodirty(struct inode *inode, qsize_t nr) | 247 | static inline void vfs_dq_free_space_nodirty(struct inode *inode, qsize_t nr) |