Lines Matching refs:dquot

266 static inline void insert_dquot_hash(struct dquot *dquot)  in insert_dquot_hash()  argument
269 head = dquot_hash + hashfn(dquot->dq_sb, dquot->dq_id); in insert_dquot_hash()
270 hlist_add_head(&dquot->dq_hash, head); in insert_dquot_hash()
273 static inline void remove_dquot_hash(struct dquot *dquot) in remove_dquot_hash() argument
275 hlist_del_init(&dquot->dq_hash); in remove_dquot_hash()
278 static struct dquot *find_dquot(unsigned int hashent, struct super_block *sb, in find_dquot()
282 struct dquot *dquot; in find_dquot() local
285 dquot = hlist_entry(node, struct dquot, dq_hash); in find_dquot()
286 if (dquot->dq_sb == sb && qid_eq(dquot->dq_id, qid)) in find_dquot()
287 return dquot; in find_dquot()
293 static inline void put_dquot_last(struct dquot *dquot) in put_dquot_last() argument
295 list_add_tail(&dquot->dq_free, &free_dquots); in put_dquot_last()
299 static inline void remove_free_dquot(struct dquot *dquot) in remove_free_dquot() argument
301 if (list_empty(&dquot->dq_free)) in remove_free_dquot()
303 list_del_init(&dquot->dq_free); in remove_free_dquot()
307 static inline void put_inuse(struct dquot *dquot) in put_inuse() argument
311 list_add_tail(&dquot->dq_inuse, &inuse_list); in put_inuse()
315 static inline void remove_inuse(struct dquot *dquot) in remove_inuse() argument
318 list_del(&dquot->dq_inuse); in remove_inuse()
324 static void wait_on_dquot(struct dquot *dquot) in wait_on_dquot() argument
326 mutex_lock(&dquot->dq_lock); in wait_on_dquot()
327 mutex_unlock(&dquot->dq_lock); in wait_on_dquot()
330 static inline int dquot_dirty(struct dquot *dquot) in dquot_dirty() argument
332 return test_bit(DQ_MOD_B, &dquot->dq_flags); in dquot_dirty()
335 static inline int mark_dquot_dirty(struct dquot *dquot) in mark_dquot_dirty() argument
337 return dquot->dq_sb->dq_op->mark_dirty(dquot); in mark_dquot_dirty()
341 int dquot_mark_dquot_dirty(struct dquot *dquot) in dquot_mark_dquot_dirty() argument
346 if (test_bit(DQ_MOD_B, &dquot->dq_flags)) in dquot_mark_dquot_dirty()
350 if (!test_and_set_bit(DQ_MOD_B, &dquot->dq_flags)) { in dquot_mark_dquot_dirty()
351 list_add(&dquot->dq_dirty, &sb_dqopt(dquot->dq_sb)-> in dquot_mark_dquot_dirty()
352 info[dquot->dq_id.type].dqi_dirty_list); in dquot_mark_dquot_dirty()
361 static inline int mark_all_dquot_dirty(struct dquot * const *dquot) in mark_all_dquot_dirty() argument
367 if (dquot[cnt]) in mark_all_dquot_dirty()
369 ret = mark_dquot_dirty(dquot[cnt]); in mark_all_dquot_dirty()
376 static inline void dqput_all(struct dquot **dquot) in dqput_all() argument
381 dqput(dquot[cnt]); in dqput_all()
385 static inline int clear_dquot_dirty(struct dquot *dquot) in clear_dquot_dirty() argument
387 if (!test_and_clear_bit(DQ_MOD_B, &dquot->dq_flags)) in clear_dquot_dirty()
389 list_del_init(&dquot->dq_dirty); in clear_dquot_dirty()
403 int dquot_acquire(struct dquot *dquot) in dquot_acquire() argument
406 struct quota_info *dqopt = sb_dqopt(dquot->dq_sb); in dquot_acquire()
408 mutex_lock(&dquot->dq_lock); in dquot_acquire()
410 if (!test_bit(DQ_READ_B, &dquot->dq_flags)) in dquot_acquire()
411 ret = dqopt->ops[dquot->dq_id.type]->read_dqblk(dquot); in dquot_acquire()
414 set_bit(DQ_READ_B, &dquot->dq_flags); in dquot_acquire()
416 if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags) && !dquot->dq_off) { in dquot_acquire()
417 ret = dqopt->ops[dquot->dq_id.type]->commit_dqblk(dquot); in dquot_acquire()
419 if (info_dirty(&dqopt->info[dquot->dq_id.type])) { in dquot_acquire()
420 ret2 = dqopt->ops[dquot->dq_id.type]->write_file_info( in dquot_acquire()
421 dquot->dq_sb, dquot->dq_id.type); in dquot_acquire()
430 set_bit(DQ_ACTIVE_B, &dquot->dq_flags); in dquot_acquire()
433 mutex_unlock(&dquot->dq_lock); in dquot_acquire()
441 int dquot_commit(struct dquot *dquot) in dquot_commit() argument
444 struct quota_info *dqopt = sb_dqopt(dquot->dq_sb); in dquot_commit()
448 if (!clear_dquot_dirty(dquot)) { in dquot_commit()
455 if (test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) in dquot_commit()
456 ret = dqopt->ops[dquot->dq_id.type]->commit_dqblk(dquot); in dquot_commit()
468 int dquot_release(struct dquot *dquot) in dquot_release() argument
471 struct quota_info *dqopt = sb_dqopt(dquot->dq_sb); in dquot_release()
473 mutex_lock(&dquot->dq_lock); in dquot_release()
475 if (atomic_read(&dquot->dq_count) > 1) in dquot_release()
478 if (dqopt->ops[dquot->dq_id.type]->release_dqblk) { in dquot_release()
479 ret = dqopt->ops[dquot->dq_id.type]->release_dqblk(dquot); in dquot_release()
481 if (info_dirty(&dqopt->info[dquot->dq_id.type])) { in dquot_release()
482 ret2 = dqopt->ops[dquot->dq_id.type]->write_file_info( in dquot_release()
483 dquot->dq_sb, dquot->dq_id.type); in dquot_release()
488 clear_bit(DQ_ACTIVE_B, &dquot->dq_flags); in dquot_release()
491 mutex_unlock(&dquot->dq_lock); in dquot_release()
496 void dquot_destroy(struct dquot *dquot) in dquot_destroy() argument
498 kmem_cache_free(dquot_cachep, dquot); in dquot_destroy()
502 static inline void do_destroy_dquot(struct dquot *dquot) in do_destroy_dquot() argument
504 dquot->dq_sb->dq_op->destroy_dquot(dquot); in do_destroy_dquot()
515 struct dquot *dquot, *tmp; in invalidate_dquots() local
519 list_for_each_entry_safe(dquot, tmp, &inuse_list, dq_inuse) { in invalidate_dquots()
520 if (dquot->dq_sb != sb) in invalidate_dquots()
522 if (dquot->dq_id.type != type) in invalidate_dquots()
525 if (atomic_read(&dquot->dq_count)) { in invalidate_dquots()
528 dqgrab(dquot); in invalidate_dquots()
529 prepare_to_wait(&dquot->dq_wait_unused, &wait, in invalidate_dquots()
539 if (atomic_read(&dquot->dq_count) > 1) in invalidate_dquots()
541 finish_wait(&dquot->dq_wait_unused, &wait); in invalidate_dquots()
542 dqput(dquot); in invalidate_dquots()
552 remove_dquot_hash(dquot); in invalidate_dquots()
553 remove_free_dquot(dquot); in invalidate_dquots()
554 remove_inuse(dquot); in invalidate_dquots()
555 do_destroy_dquot(dquot); in invalidate_dquots()
562 int (*fn)(struct dquot *dquot, unsigned long priv), in dquot_scan_active() argument
565 struct dquot *dquot, *old_dquot = NULL; in dquot_scan_active() local
570 list_for_each_entry(dquot, &inuse_list, dq_inuse) { in dquot_scan_active()
571 if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) in dquot_scan_active()
573 if (dquot->dq_sb != sb) in dquot_scan_active()
576 atomic_inc(&dquot->dq_count); in dquot_scan_active()
580 old_dquot = dquot; in dquot_scan_active()
586 wait_on_dquot(dquot); in dquot_scan_active()
587 if (test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) { in dquot_scan_active()
588 ret = fn(dquot, priv); in dquot_scan_active()
608 struct dquot *dquot; in dquot_writeback_dquots() local
622 dquot = list_first_entry(dirty, struct dquot, in dquot_writeback_dquots()
625 if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) { in dquot_writeback_dquots()
626 clear_dquot_dirty(dquot); in dquot_writeback_dquots()
632 dqgrab(dquot); in dquot_writeback_dquots()
635 err = sb->dq_op->write_dquot(dquot); in dquot_writeback_dquots()
638 dqput(dquot); in dquot_writeback_dquots()
699 struct dquot *dquot; in dqcache_shrink_scan() local
705 dquot = list_entry(head, struct dquot, dq_free); in dqcache_shrink_scan()
706 remove_dquot_hash(dquot); in dqcache_shrink_scan()
707 remove_free_dquot(dquot); in dqcache_shrink_scan()
708 remove_inuse(dquot); in dqcache_shrink_scan()
709 do_destroy_dquot(dquot); in dqcache_shrink_scan()
734 void dqput(struct dquot *dquot) in dqput() argument
738 if (!dquot) in dqput()
741 if (!atomic_read(&dquot->dq_count)) { in dqput()
742 quota_error(dquot->dq_sb, "trying to free free dquot of %s %d", in dqput()
743 quotatypes[dquot->dq_id.type], in dqput()
744 from_kqid(&init_user_ns, dquot->dq_id)); in dqput()
751 if (atomic_read(&dquot->dq_count) > 1) { in dqput()
753 atomic_dec(&dquot->dq_count); in dqput()
755 if (!sb_has_quota_active(dquot->dq_sb, dquot->dq_id.type) && in dqput()
756 atomic_read(&dquot->dq_count) == 1) in dqput()
757 wake_up(&dquot->dq_wait_unused); in dqput()
762 if (test_bit(DQ_ACTIVE_B, &dquot->dq_flags) && dquot_dirty(dquot)) { in dqput()
765 ret = dquot->dq_sb->dq_op->write_dquot(dquot); in dqput()
767 quota_error(dquot->dq_sb, "Can't write quota structure" in dqput()
775 clear_dquot_dirty(dquot); in dqput()
781 clear_dquot_dirty(dquot); in dqput()
782 if (test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) { in dqput()
784 dquot->dq_sb->dq_op->release_dquot(dquot); in dqput()
787 atomic_dec(&dquot->dq_count); in dqput()
790 BUG_ON(!list_empty(&dquot->dq_free)); in dqput()
792 put_dquot_last(dquot); in dqput()
797 struct dquot *dquot_alloc(struct super_block *sb, int type) in dquot_alloc()
803 static struct dquot *get_empty_dquot(struct super_block *sb, int type) in get_empty_dquot()
805 struct dquot *dquot; in get_empty_dquot() local
807 dquot = sb->dq_op->alloc_dquot(sb, type); in get_empty_dquot()
808 if(!dquot) in get_empty_dquot()
811 mutex_init(&dquot->dq_lock); in get_empty_dquot()
812 INIT_LIST_HEAD(&dquot->dq_free); in get_empty_dquot()
813 INIT_LIST_HEAD(&dquot->dq_inuse); in get_empty_dquot()
814 INIT_HLIST_NODE(&dquot->dq_hash); in get_empty_dquot()
815 INIT_LIST_HEAD(&dquot->dq_dirty); in get_empty_dquot()
816 init_waitqueue_head(&dquot->dq_wait_unused); in get_empty_dquot()
817 dquot->dq_sb = sb; in get_empty_dquot()
818 dquot->dq_id = make_kqid_invalid(type); in get_empty_dquot()
819 atomic_set(&dquot->dq_count, 1); in get_empty_dquot()
821 return dquot; in get_empty_dquot()
832 struct dquot *dqget(struct super_block *sb, struct kqid qid) in dqget()
835 struct dquot *dquot, *empty = NULL; in dqget() local
845 dquot = ERR_PTR(-ESRCH); in dqget()
850 dquot = find_dquot(hashent, sb, qid); in dqget()
851 if (!dquot) { in dqget()
859 dquot = empty; in dqget()
861 dquot->dq_id = qid; in dqget()
863 put_inuse(dquot); in dqget()
865 insert_dquot_hash(dquot); in dqget()
869 if (!atomic_read(&dquot->dq_count)) in dqget()
870 remove_free_dquot(dquot); in dqget()
871 atomic_inc(&dquot->dq_count); in dqget()
878 wait_on_dquot(dquot); in dqget()
880 if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags)) { in dqget()
883 err = sb->dq_op->acquire_dquot(dquot); in dqget()
885 dqput(dquot); in dqget()
886 dquot = ERR_PTR(err); in dqget()
891 BUG_ON(!dquot->dq_sb); /* Has somebody invalidated entry under us? */ in dqget()
897 return dquot; in dqget()
901 static inline struct dquot **i_dquot(struct inode *inode) in i_dquot()
908 struct dquot * const *dquots; in dqinit_needed()
981 struct dquot **dquots = i_dquot(inode); in remove_inode_dquot_ref()
982 struct dquot *dquot = dquots[type]; in remove_inode_dquot_ref() local
984 if (!dquot) in remove_inode_dquot_ref()
988 if (list_empty(&dquot->dq_free)) { in remove_inode_dquot_ref()
994 list_add(&dquot->dq_free, tofree_head); in remove_inode_dquot_ref()
1001 dqput(dquot); in remove_inode_dquot_ref()
1013 struct dquot *dquot; in put_dquot_list() local
1017 dquot = list_entry(act_head, struct dquot, dq_free); in put_dquot_list()
1020 list_del_init(&dquot->dq_free); in put_dquot_list()
1021 dqput(dquot); in put_dquot_list()
1069 static inline void dquot_incr_inodes(struct dquot *dquot, qsize_t number) in dquot_incr_inodes() argument
1071 dquot->dq_dqb.dqb_curinodes += number; in dquot_incr_inodes()
1074 static inline void dquot_incr_space(struct dquot *dquot, qsize_t number) in dquot_incr_space() argument
1076 dquot->dq_dqb.dqb_curspace += number; in dquot_incr_space()
1079 static inline void dquot_resv_space(struct dquot *dquot, qsize_t number) in dquot_resv_space() argument
1081 dquot->dq_dqb.dqb_rsvspace += number; in dquot_resv_space()
1087 static void dquot_claim_reserved_space(struct dquot *dquot, qsize_t number) in dquot_claim_reserved_space() argument
1089 if (dquot->dq_dqb.dqb_rsvspace < number) { in dquot_claim_reserved_space()
1091 number = dquot->dq_dqb.dqb_rsvspace; in dquot_claim_reserved_space()
1093 dquot->dq_dqb.dqb_curspace += number; in dquot_claim_reserved_space()
1094 dquot->dq_dqb.dqb_rsvspace -= number; in dquot_claim_reserved_space()
1097 static void dquot_reclaim_reserved_space(struct dquot *dquot, qsize_t number) in dquot_reclaim_reserved_space() argument
1099 if (WARN_ON_ONCE(dquot->dq_dqb.dqb_curspace < number)) in dquot_reclaim_reserved_space()
1100 number = dquot->dq_dqb.dqb_curspace; in dquot_reclaim_reserved_space()
1101 dquot->dq_dqb.dqb_rsvspace += number; in dquot_reclaim_reserved_space()
1102 dquot->dq_dqb.dqb_curspace -= number; in dquot_reclaim_reserved_space()
1106 void dquot_free_reserved_space(struct dquot *dquot, qsize_t number) in dquot_free_reserved_space() argument
1108 if (dquot->dq_dqb.dqb_rsvspace >= number) in dquot_free_reserved_space()
1109 dquot->dq_dqb.dqb_rsvspace -= number; in dquot_free_reserved_space()
1112 dquot->dq_dqb.dqb_rsvspace = 0; in dquot_free_reserved_space()
1116 static void dquot_decr_inodes(struct dquot *dquot, qsize_t number) in dquot_decr_inodes() argument
1118 if (sb_dqopt(dquot->dq_sb)->flags & DQUOT_NEGATIVE_USAGE || in dquot_decr_inodes()
1119 dquot->dq_dqb.dqb_curinodes >= number) in dquot_decr_inodes()
1120 dquot->dq_dqb.dqb_curinodes -= number; in dquot_decr_inodes()
1122 dquot->dq_dqb.dqb_curinodes = 0; in dquot_decr_inodes()
1123 if (dquot->dq_dqb.dqb_curinodes <= dquot->dq_dqb.dqb_isoftlimit) in dquot_decr_inodes()
1124 dquot->dq_dqb.dqb_itime = (time_t) 0; in dquot_decr_inodes()
1125 clear_bit(DQ_INODES_B, &dquot->dq_flags); in dquot_decr_inodes()
1128 static void dquot_decr_space(struct dquot *dquot, qsize_t number) in dquot_decr_space() argument
1130 if (sb_dqopt(dquot->dq_sb)->flags & DQUOT_NEGATIVE_USAGE || in dquot_decr_space()
1131 dquot->dq_dqb.dqb_curspace >= number) in dquot_decr_space()
1132 dquot->dq_dqb.dqb_curspace -= number; in dquot_decr_space()
1134 dquot->dq_dqb.dqb_curspace = 0; in dquot_decr_space()
1135 if (dquot->dq_dqb.dqb_curspace <= dquot->dq_dqb.dqb_bsoftlimit) in dquot_decr_space()
1136 dquot->dq_dqb.dqb_btime = (time_t) 0; in dquot_decr_space()
1137 clear_bit(DQ_BLKS_B, &dquot->dq_flags); in dquot_decr_space()
1146 static int warning_issued(struct dquot *dquot, const int warntype) in warning_issued() argument
1155 return test_and_set_bit(flag, &dquot->dq_flags); in warning_issued()
1224 static void prepare_warning(struct dquot_warn *warn, struct dquot *dquot, in prepare_warning() argument
1227 if (warning_issued(dquot, warntype)) in prepare_warning()
1230 warn->w_sb = dquot->dq_sb; in prepare_warning()
1231 warn->w_dq_id = dquot->dq_id; in prepare_warning()
1254 static int ignore_hardlimit(struct dquot *dquot) in ignore_hardlimit() argument
1256 struct mem_dqinfo *info = &sb_dqopt(dquot->dq_sb)->info[dquot->dq_id.type]; in ignore_hardlimit()
1264 static int check_idq(struct dquot *dquot, qsize_t inodes, in check_idq() argument
1267 qsize_t newinodes = dquot->dq_dqb.dqb_curinodes + inodes; in check_idq()
1269 if (!sb_has_quota_limits_enabled(dquot->dq_sb, dquot->dq_id.type) || in check_idq()
1270 test_bit(DQ_FAKE_B, &dquot->dq_flags)) in check_idq()
1273 if (dquot->dq_dqb.dqb_ihardlimit && in check_idq()
1274 newinodes > dquot->dq_dqb.dqb_ihardlimit && in check_idq()
1275 !ignore_hardlimit(dquot)) { in check_idq()
1276 prepare_warning(warn, dquot, QUOTA_NL_IHARDWARN); in check_idq()
1280 if (dquot->dq_dqb.dqb_isoftlimit && in check_idq()
1281 newinodes > dquot->dq_dqb.dqb_isoftlimit && in check_idq()
1282 dquot->dq_dqb.dqb_itime && in check_idq()
1283 get_seconds() >= dquot->dq_dqb.dqb_itime && in check_idq()
1284 !ignore_hardlimit(dquot)) { in check_idq()
1285 prepare_warning(warn, dquot, QUOTA_NL_ISOFTLONGWARN); in check_idq()
1289 if (dquot->dq_dqb.dqb_isoftlimit && in check_idq()
1290 newinodes > dquot->dq_dqb.dqb_isoftlimit && in check_idq()
1291 dquot->dq_dqb.dqb_itime == 0) { in check_idq()
1292 prepare_warning(warn, dquot, QUOTA_NL_ISOFTWARN); in check_idq()
1293 dquot->dq_dqb.dqb_itime = get_seconds() + in check_idq()
1294 sb_dqopt(dquot->dq_sb)->info[dquot->dq_id.type].dqi_igrace; in check_idq()
1301 static int check_bdq(struct dquot *dquot, qsize_t space, int prealloc, in check_bdq() argument
1305 struct super_block *sb = dquot->dq_sb; in check_bdq()
1307 if (!sb_has_quota_limits_enabled(sb, dquot->dq_id.type) || in check_bdq()
1308 test_bit(DQ_FAKE_B, &dquot->dq_flags)) in check_bdq()
1311 tspace = dquot->dq_dqb.dqb_curspace + dquot->dq_dqb.dqb_rsvspace in check_bdq()
1314 if (dquot->dq_dqb.dqb_bhardlimit && in check_bdq()
1315 tspace > dquot->dq_dqb.dqb_bhardlimit && in check_bdq()
1316 !ignore_hardlimit(dquot)) { in check_bdq()
1318 prepare_warning(warn, dquot, QUOTA_NL_BHARDWARN); in check_bdq()
1322 if (dquot->dq_dqb.dqb_bsoftlimit && in check_bdq()
1323 tspace > dquot->dq_dqb.dqb_bsoftlimit && in check_bdq()
1324 dquot->dq_dqb.dqb_btime && in check_bdq()
1325 get_seconds() >= dquot->dq_dqb.dqb_btime && in check_bdq()
1326 !ignore_hardlimit(dquot)) { in check_bdq()
1328 prepare_warning(warn, dquot, QUOTA_NL_BSOFTLONGWARN); in check_bdq()
1332 if (dquot->dq_dqb.dqb_bsoftlimit && in check_bdq()
1333 tspace > dquot->dq_dqb.dqb_bsoftlimit && in check_bdq()
1334 dquot->dq_dqb.dqb_btime == 0) { in check_bdq()
1336 prepare_warning(warn, dquot, QUOTA_NL_BSOFTWARN); in check_bdq()
1337 dquot->dq_dqb.dqb_btime = get_seconds() + in check_bdq()
1338 sb_dqopt(sb)->info[dquot->dq_id.type].dqi_bgrace; in check_bdq()
1351 static int info_idq_free(struct dquot *dquot, qsize_t inodes) in info_idq_free() argument
1355 if (test_bit(DQ_FAKE_B, &dquot->dq_flags) || in info_idq_free()
1356 dquot->dq_dqb.dqb_curinodes <= dquot->dq_dqb.dqb_isoftlimit || in info_idq_free()
1357 !sb_has_quota_limits_enabled(dquot->dq_sb, dquot->dq_id.type)) in info_idq_free()
1360 newinodes = dquot->dq_dqb.dqb_curinodes - inodes; in info_idq_free()
1361 if (newinodes <= dquot->dq_dqb.dqb_isoftlimit) in info_idq_free()
1363 if (dquot->dq_dqb.dqb_curinodes >= dquot->dq_dqb.dqb_ihardlimit && in info_idq_free()
1364 newinodes < dquot->dq_dqb.dqb_ihardlimit) in info_idq_free()
1369 static int info_bdq_free(struct dquot *dquot, qsize_t space) in info_bdq_free() argument
1371 if (test_bit(DQ_FAKE_B, &dquot->dq_flags) || in info_bdq_free()
1372 dquot->dq_dqb.dqb_curspace <= dquot->dq_dqb.dqb_bsoftlimit) in info_bdq_free()
1375 if (dquot->dq_dqb.dqb_curspace - space <= dquot->dq_dqb.dqb_bsoftlimit) in info_bdq_free()
1377 if (dquot->dq_dqb.dqb_curspace >= dquot->dq_dqb.dqb_bhardlimit && in info_bdq_free()
1378 dquot->dq_dqb.dqb_curspace - space < dquot->dq_dqb.dqb_bhardlimit) in info_bdq_free()
1401 struct dquot **dquots, *got[MAXQUOTAS] = {}; in __dquot_initialize()
1416 struct dquot *dquot; in __dquot_initialize() local
1447 dquot = dqget(sb, qid); in __dquot_initialize()
1448 if (IS_ERR(dquot)) { in __dquot_initialize()
1450 if (PTR_ERR(dquot) != -ESRCH) { in __dquot_initialize()
1451 ret = PTR_ERR(dquot); in __dquot_initialize()
1454 dquot = NULL; in __dquot_initialize()
1456 got[cnt] = dquot; in __dquot_initialize()
1513 struct dquot **dquots = i_dquot(inode); in __dquot_drop()
1514 struct dquot *put[MAXQUOTAS]; in __dquot_drop()
1527 struct dquot * const *dquots; in dquot_drop()
1644 struct dquot **dquots; in __dquot_alloc_space()
1696 struct dquot * const *dquots; in dquot_alloc_inode()
1735 struct dquot **dquots; in dquot_claim_space_nodirty()
1765 struct dquot **dquots; in dquot_reclaim_space_nodirty()
1797 struct dquot **dquots; in __dquot_free_space()
1841 struct dquot * const *dquots; in dquot_free_inode()
1880 int __dquot_transfer(struct inode *inode, struct dquot **transfer_to) in __dquot_transfer()
1884 struct dquot *transfer_from[MAXQUOTAS] = {}; in __dquot_transfer()
1981 struct dquot *transfer_to[MAXQUOTAS] = {}; in dquot_transfer()
1982 struct dquot *dquot; in dquot_transfer() local
1990 dquot = dqget(sb, make_kqid_uid(iattr->ia_uid)); in dquot_transfer()
1991 if (IS_ERR(dquot)) { in dquot_transfer()
1992 if (PTR_ERR(dquot) != -ESRCH) { in dquot_transfer()
1993 ret = PTR_ERR(dquot); in dquot_transfer()
1996 dquot = NULL; in dquot_transfer()
1998 transfer_to[USRQUOTA] = dquot; in dquot_transfer()
2001 dquot = dqget(sb, make_kqid_gid(iattr->ia_gid)); in dquot_transfer()
2002 if (IS_ERR(dquot)) { in dquot_transfer()
2003 if (PTR_ERR(dquot) != -ESRCH) { in dquot_transfer()
2004 ret = PTR_ERR(dquot); in dquot_transfer()
2007 dquot = NULL; in dquot_transfer()
2009 transfer_to[GRPQUOTA] = dquot; in dquot_transfer()
2535 static void do_get_dqblk(struct dquot *dquot, struct qc_dqblk *di) in do_get_dqblk() argument
2537 struct mem_dqblk *dm = &dquot->dq_dqb; in do_get_dqblk()
2555 struct dquot *dquot; in dquot_get_dqblk() local
2557 dquot = dqget(sb, qid); in dquot_get_dqblk()
2558 if (IS_ERR(dquot)) in dquot_get_dqblk()
2559 return PTR_ERR(dquot); in dquot_get_dqblk()
2560 do_get_dqblk(dquot, di); in dquot_get_dqblk()
2561 dqput(dquot); in dquot_get_dqblk()
2573 static int do_set_dqblk(struct dquot *dquot, struct qc_dqblk *di) in do_set_dqblk() argument
2575 struct mem_dqblk *dm = &dquot->dq_dqb; in do_set_dqblk()
2577 struct mem_dqinfo *dqi = &sb_dqopt(dquot->dq_sb)->info[dquot->dq_id.type]; in do_set_dqblk()
2596 set_bit(DQ_LASTSET_B + QIF_SPACE_B, &dquot->dq_flags); in do_set_dqblk()
2605 set_bit(DQ_LASTSET_B + QIF_BLIMITS_B, &dquot->dq_flags); in do_set_dqblk()
2611 set_bit(DQ_LASTSET_B + QIF_INODES_B, &dquot->dq_flags); in do_set_dqblk()
2620 set_bit(DQ_LASTSET_B + QIF_ILIMITS_B, &dquot->dq_flags); in do_set_dqblk()
2626 set_bit(DQ_LASTSET_B + QIF_BTIME_B, &dquot->dq_flags); in do_set_dqblk()
2632 set_bit(DQ_LASTSET_B + QIF_ITIME_B, &dquot->dq_flags); in do_set_dqblk()
2639 clear_bit(DQ_BLKS_B, &dquot->dq_flags); in do_set_dqblk()
2648 clear_bit(DQ_INODES_B, &dquot->dq_flags); in do_set_dqblk()
2655 clear_bit(DQ_FAKE_B, &dquot->dq_flags); in do_set_dqblk()
2657 set_bit(DQ_FAKE_B, &dquot->dq_flags); in do_set_dqblk()
2659 mark_dquot_dirty(dquot); in do_set_dqblk()
2667 struct dquot *dquot; in dquot_set_dqblk() local
2670 dquot = dqget(sb, qid); in dquot_set_dqblk()
2671 if (IS_ERR(dquot)) { in dquot_set_dqblk()
2672 rc = PTR_ERR(dquot); in dquot_set_dqblk()
2675 rc = do_set_dqblk(dquot, di); in dquot_set_dqblk()
2676 dqput(dquot); in dquot_set_dqblk()
2890 sizeof(struct dquot), sizeof(unsigned long) * 4, in dquot_init()