aboutsummaryrefslogtreecommitdiffstats
path: root/fs/quota
diff options
context:
space:
mode:
authorDmitry Monakhov <dmonakhov@openvz.org>2010-03-27 08:15:38 -0400
committerJan Kara <jack@suse.cz>2010-05-21 13:30:37 -0400
commiteabf290d1470921f0ce5a9b22464ae30646a0677 (patch)
treeba3a4ae74101a2ca31fabdbfa3576776cbddf2ed /fs/quota
parent46891532370e862d6bddedef9e6ca22a59a51fa4 (diff)
quota: optimize mark_dirty logic
- Skip locking if quota is dirty already. - Return old quota state to help fs-specciffic implementation to optimize case where quota was dirty already. Signed-off-by: Dmitry Monakhov <dmonakhov@openvz.org> Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'fs/quota')
-rw-r--r--fs/quota/dquot.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/fs/quota/dquot.c b/fs/quota/dquot.c
index 788b5802a7ce..05c590e10ac2 100644
--- a/fs/quota/dquot.c
+++ b/fs/quota/dquot.c
@@ -317,14 +317,23 @@ static inline int mark_dquot_dirty(struct dquot *dquot)
317 return dquot->dq_sb->dq_op->mark_dirty(dquot); 317 return dquot->dq_sb->dq_op->mark_dirty(dquot);
318} 318}
319 319
320/* Mark dquot dirty in atomic manner, and return it's old dirty flag state */
320int dquot_mark_dquot_dirty(struct dquot *dquot) 321int dquot_mark_dquot_dirty(struct dquot *dquot)
321{ 322{
323 int ret = 1;
324
325 /* If quota is dirty already, we don't have to acquire dq_list_lock */
326 if (test_bit(DQ_MOD_B, &dquot->dq_flags))
327 return 1;
328
322 spin_lock(&dq_list_lock); 329 spin_lock(&dq_list_lock);
323 if (!test_and_set_bit(DQ_MOD_B, &dquot->dq_flags)) 330 if (!test_and_set_bit(DQ_MOD_B, &dquot->dq_flags)) {
324 list_add(&dquot->dq_dirty, &sb_dqopt(dquot->dq_sb)-> 331 list_add(&dquot->dq_dirty, &sb_dqopt(dquot->dq_sb)->
325 info[dquot->dq_type].dqi_dirty_list); 332 info[dquot->dq_type].dqi_dirty_list);
333 ret = 0;
334 }
326 spin_unlock(&dq_list_lock); 335 spin_unlock(&dq_list_lock);
327 return 0; 336 return ret;
328} 337}
329EXPORT_SYMBOL(dquot_mark_dquot_dirty); 338EXPORT_SYMBOL(dquot_mark_dquot_dirty);
330 339