diff options
Diffstat (limited to 'fs/quota')
-rw-r--r-- | fs/quota/dquot.c | 70 |
1 files changed, 36 insertions, 34 deletions
diff --git a/fs/quota/dquot.c b/fs/quota/dquot.c index e840fa2b112e..4881db32e56d 100644 --- a/fs/quota/dquot.c +++ b/fs/quota/dquot.c | |||
@@ -253,7 +253,7 @@ static inline struct dquot *find_dquot(unsigned int hashent, struct super_block | |||
253 | if (dquot->dq_sb == sb && dquot->dq_id == id && dquot->dq_type == type) | 253 | if (dquot->dq_sb == sb && dquot->dq_id == id && dquot->dq_type == type) |
254 | return dquot; | 254 | return dquot; |
255 | } | 255 | } |
256 | return NODQUOT; | 256 | return NULL; |
257 | } | 257 | } |
258 | 258 | ||
259 | /* Add a dquot to the tail of the free list */ | 259 | /* Add a dquot to the tail of the free list */ |
@@ -696,7 +696,7 @@ static struct dquot *get_empty_dquot(struct super_block *sb, int type) | |||
696 | 696 | ||
697 | dquot = sb->dq_op->alloc_dquot(sb, type); | 697 | dquot = sb->dq_op->alloc_dquot(sb, type); |
698 | if(!dquot) | 698 | if(!dquot) |
699 | return NODQUOT; | 699 | return NULL; |
700 | 700 | ||
701 | mutex_init(&dquot->dq_lock); | 701 | mutex_init(&dquot->dq_lock); |
702 | INIT_LIST_HEAD(&dquot->dq_free); | 702 | INIT_LIST_HEAD(&dquot->dq_free); |
@@ -722,10 +722,10 @@ static struct dquot *get_empty_dquot(struct super_block *sb, int type) | |||
722 | struct dquot *dqget(struct super_block *sb, unsigned int id, int type) | 722 | struct dquot *dqget(struct super_block *sb, unsigned int id, int type) |
723 | { | 723 | { |
724 | unsigned int hashent = hashfn(sb, id, type); | 724 | unsigned int hashent = hashfn(sb, id, type); |
725 | struct dquot *dquot = NODQUOT, *empty = NODQUOT; | 725 | struct dquot *dquot = NULL, *empty = NULL; |
726 | 726 | ||
727 | if (!sb_has_quota_active(sb, type)) | 727 | if (!sb_has_quota_active(sb, type)) |
728 | return NODQUOT; | 728 | return NULL; |
729 | we_slept: | 729 | we_slept: |
730 | spin_lock(&dq_list_lock); | 730 | spin_lock(&dq_list_lock); |
731 | spin_lock(&dq_state_lock); | 731 | spin_lock(&dq_state_lock); |
@@ -736,15 +736,17 @@ we_slept: | |||
736 | } | 736 | } |
737 | spin_unlock(&dq_state_lock); | 737 | spin_unlock(&dq_state_lock); |
738 | 738 | ||
739 | if ((dquot = find_dquot(hashent, sb, id, type)) == NODQUOT) { | 739 | dquot = find_dquot(hashent, sb, id, type); |
740 | if (empty == NODQUOT) { | 740 | if (!dquot) { |
741 | if (!empty) { | ||
741 | spin_unlock(&dq_list_lock); | 742 | spin_unlock(&dq_list_lock); |
742 | if ((empty = get_empty_dquot(sb, type)) == NODQUOT) | 743 | empty = get_empty_dquot(sb, type); |
744 | if (!empty) | ||
743 | schedule(); /* Try to wait for a moment... */ | 745 | schedule(); /* Try to wait for a moment... */ |
744 | goto we_slept; | 746 | goto we_slept; |
745 | } | 747 | } |
746 | dquot = empty; | 748 | dquot = empty; |
747 | empty = NODQUOT; | 749 | empty = NULL; |
748 | dquot->dq_id = id; | 750 | dquot->dq_id = id; |
749 | /* all dquots go on the inuse_list */ | 751 | /* all dquots go on the inuse_list */ |
750 | put_inuse(dquot); | 752 | put_inuse(dquot); |
@@ -766,7 +768,7 @@ we_slept: | |||
766 | /* Read the dquot and instantiate it (everything done only if needed) */ | 768 | /* Read the dquot and instantiate it (everything done only if needed) */ |
767 | if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags) && sb->dq_op->acquire_dquot(dquot) < 0) { | 769 | if (!test_bit(DQ_ACTIVE_B, &dquot->dq_flags) && sb->dq_op->acquire_dquot(dquot) < 0) { |
768 | dqput(dquot); | 770 | dqput(dquot); |
769 | dquot = NODQUOT; | 771 | dquot = NULL; |
770 | goto out; | 772 | goto out; |
771 | } | 773 | } |
772 | #ifdef __DQUOT_PARANOIA | 774 | #ifdef __DQUOT_PARANOIA |
@@ -787,9 +789,9 @@ static int dqinit_needed(struct inode *inode, int type) | |||
787 | if (IS_NOQUOTA(inode)) | 789 | if (IS_NOQUOTA(inode)) |
788 | return 0; | 790 | return 0; |
789 | if (type != -1) | 791 | if (type != -1) |
790 | return inode->i_dquot[type] == NODQUOT; | 792 | return !inode->i_dquot[type]; |
791 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) | 793 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) |
792 | if (inode->i_dquot[cnt] == NODQUOT) | 794 | if (!inode->i_dquot[cnt]) |
793 | return 1; | 795 | return 1; |
794 | return 0; | 796 | return 0; |
795 | } | 797 | } |
@@ -840,8 +842,8 @@ static int remove_inode_dquot_ref(struct inode *inode, int type, | |||
840 | { | 842 | { |
841 | struct dquot *dquot = inode->i_dquot[type]; | 843 | struct dquot *dquot = inode->i_dquot[type]; |
842 | 844 | ||
843 | inode->i_dquot[type] = NODQUOT; | 845 | inode->i_dquot[type] = NULL; |
844 | if (dquot != NODQUOT) { | 846 | if (dquot) { |
845 | if (dqput_blocks(dquot)) { | 847 | if (dqput_blocks(dquot)) { |
846 | #ifdef __DQUOT_PARANOIA | 848 | #ifdef __DQUOT_PARANOIA |
847 | if (atomic_read(&dquot->dq_count) != 1) | 849 | if (atomic_read(&dquot->dq_count) != 1) |
@@ -1112,7 +1114,7 @@ static inline void flush_warnings(struct dquot * const *dquots, char *warntype) | |||
1112 | int i; | 1114 | int i; |
1113 | 1115 | ||
1114 | for (i = 0; i < MAXQUOTAS; i++) | 1116 | for (i = 0; i < MAXQUOTAS; i++) |
1115 | if (dquots[i] != NODQUOT && warntype[i] != QUOTA_NL_NOWARN && | 1117 | if (dquots[i] && warntype[i] != QUOTA_NL_NOWARN && |
1116 | !warning_issued(dquots[i], warntype[i])) { | 1118 | !warning_issued(dquots[i], warntype[i])) { |
1117 | #ifdef CONFIG_PRINT_QUOTA_WARNING | 1119 | #ifdef CONFIG_PRINT_QUOTA_WARNING |
1118 | print_warning(dquots[i], warntype[i]); | 1120 | print_warning(dquots[i], warntype[i]); |
@@ -1249,7 +1251,7 @@ int dquot_initialize(struct inode *inode, int type) | |||
1249 | { | 1251 | { |
1250 | unsigned int id = 0; | 1252 | unsigned int id = 0; |
1251 | int cnt, ret = 0; | 1253 | int cnt, ret = 0; |
1252 | struct dquot *got[MAXQUOTAS] = { NODQUOT, NODQUOT }; | 1254 | struct dquot *got[MAXQUOTAS] = { NULL, NULL }; |
1253 | struct super_block *sb = inode->i_sb; | 1255 | struct super_block *sb = inode->i_sb; |
1254 | 1256 | ||
1255 | /* First test before acquiring mutex - solves deadlocks when we | 1257 | /* First test before acquiring mutex - solves deadlocks when we |
@@ -1282,9 +1284,9 @@ int dquot_initialize(struct inode *inode, int type) | |||
1282 | /* Avoid races with quotaoff() */ | 1284 | /* Avoid races with quotaoff() */ |
1283 | if (!sb_has_quota_active(sb, cnt)) | 1285 | if (!sb_has_quota_active(sb, cnt)) |
1284 | continue; | 1286 | continue; |
1285 | if (inode->i_dquot[cnt] == NODQUOT) { | 1287 | if (!inode->i_dquot[cnt]) { |
1286 | inode->i_dquot[cnt] = got[cnt]; | 1288 | inode->i_dquot[cnt] = got[cnt]; |
1287 | got[cnt] = NODQUOT; | 1289 | got[cnt] = NULL; |
1288 | } | 1290 | } |
1289 | } | 1291 | } |
1290 | out_err: | 1292 | out_err: |
@@ -1307,7 +1309,7 @@ int dquot_drop(struct inode *inode) | |||
1307 | down_write(&sb_dqopt(inode->i_sb)->dqptr_sem); | 1309 | down_write(&sb_dqopt(inode->i_sb)->dqptr_sem); |
1308 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1310 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1309 | put[cnt] = inode->i_dquot[cnt]; | 1311 | put[cnt] = inode->i_dquot[cnt]; |
1310 | inode->i_dquot[cnt] = NODQUOT; | 1312 | inode->i_dquot[cnt] = NULL; |
1311 | } | 1313 | } |
1312 | up_write(&sb_dqopt(inode->i_sb)->dqptr_sem); | 1314 | up_write(&sb_dqopt(inode->i_sb)->dqptr_sem); |
1313 | 1315 | ||
@@ -1332,7 +1334,7 @@ void vfs_dq_drop(struct inode *inode) | |||
1332 | * must assure that nobody can come after the DQUOT_DROP and | 1334 | * must assure that nobody can come after the DQUOT_DROP and |
1333 | * add quota pointers back anyway */ | 1335 | * add quota pointers back anyway */ |
1334 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) | 1336 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) |
1335 | if (inode->i_dquot[cnt] != NODQUOT) | 1337 | if (inode->i_dquot[cnt]) |
1336 | break; | 1338 | break; |
1337 | if (cnt < MAXQUOTAS) | 1339 | if (cnt < MAXQUOTAS) |
1338 | inode->i_sb->dq_op->drop(inode); | 1340 | inode->i_sb->dq_op->drop(inode); |
@@ -1363,7 +1365,7 @@ int __dquot_alloc_space(struct inode *inode, qsize_t number, | |||
1363 | 1365 | ||
1364 | spin_lock(&dq_data_lock); | 1366 | spin_lock(&dq_data_lock); |
1365 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1367 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1366 | if (inode->i_dquot[cnt] == NODQUOT) | 1368 | if (!inode->i_dquot[cnt]) |
1367 | continue; | 1369 | continue; |
1368 | if (check_bdq(inode->i_dquot[cnt], number, warn, warntype+cnt) | 1370 | if (check_bdq(inode->i_dquot[cnt], number, warn, warntype+cnt) |
1369 | == NO_QUOTA) { | 1371 | == NO_QUOTA) { |
@@ -1372,7 +1374,7 @@ int __dquot_alloc_space(struct inode *inode, qsize_t number, | |||
1372 | } | 1374 | } |
1373 | } | 1375 | } |
1374 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1376 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1375 | if (inode->i_dquot[cnt] == NODQUOT) | 1377 | if (!inode->i_dquot[cnt]) |
1376 | continue; | 1378 | continue; |
1377 | if (reserve) | 1379 | if (reserve) |
1378 | dquot_resv_space(inode->i_dquot[cnt], number); | 1380 | dquot_resv_space(inode->i_dquot[cnt], number); |
@@ -1461,14 +1463,14 @@ int dquot_alloc_inode(const struct inode *inode, qsize_t number) | |||
1461 | } | 1463 | } |
1462 | spin_lock(&dq_data_lock); | 1464 | spin_lock(&dq_data_lock); |
1463 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1465 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1464 | if (inode->i_dquot[cnt] == NODQUOT) | 1466 | if (!inode->i_dquot[cnt]) |
1465 | continue; | 1467 | continue; |
1466 | if (check_idq(inode->i_dquot[cnt], number, warntype+cnt) == NO_QUOTA) | 1468 | if (check_idq(inode->i_dquot[cnt], number, warntype+cnt) == NO_QUOTA) |
1467 | goto warn_put_all; | 1469 | goto warn_put_all; |
1468 | } | 1470 | } |
1469 | 1471 | ||
1470 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1472 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1471 | if (inode->i_dquot[cnt] == NODQUOT) | 1473 | if (!inode->i_dquot[cnt]) |
1472 | continue; | 1474 | continue; |
1473 | dquot_incr_inodes(inode->i_dquot[cnt], number); | 1475 | dquot_incr_inodes(inode->i_dquot[cnt], number); |
1474 | } | 1476 | } |
@@ -1506,7 +1508,7 @@ int dquot_claim_space(struct inode *inode, qsize_t number) | |||
1506 | spin_lock(&dq_data_lock); | 1508 | spin_lock(&dq_data_lock); |
1507 | /* Claim reserved quotas to allocated quotas */ | 1509 | /* Claim reserved quotas to allocated quotas */ |
1508 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1510 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1509 | if (inode->i_dquot[cnt] != NODQUOT) | 1511 | if (inode->i_dquot[cnt]) |
1510 | dquot_claim_reserved_space(inode->i_dquot[cnt], | 1512 | dquot_claim_reserved_space(inode->i_dquot[cnt], |
1511 | number); | 1513 | number); |
1512 | } | 1514 | } |
@@ -1540,7 +1542,7 @@ void dquot_release_reserved_space(struct inode *inode, qsize_t number) | |||
1540 | spin_lock(&dq_data_lock); | 1542 | spin_lock(&dq_data_lock); |
1541 | /* Release reserved dquots */ | 1543 | /* Release reserved dquots */ |
1542 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1544 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1543 | if (inode->i_dquot[cnt] != NODQUOT) | 1545 | if (inode->i_dquot[cnt]) |
1544 | dquot_free_reserved_space(inode->i_dquot[cnt], number); | 1546 | dquot_free_reserved_space(inode->i_dquot[cnt], number); |
1545 | } | 1547 | } |
1546 | spin_unlock(&dq_data_lock); | 1548 | spin_unlock(&dq_data_lock); |
@@ -1576,7 +1578,7 @@ out_sub: | |||
1576 | } | 1578 | } |
1577 | spin_lock(&dq_data_lock); | 1579 | spin_lock(&dq_data_lock); |
1578 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1580 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1579 | if (inode->i_dquot[cnt] == NODQUOT) | 1581 | if (!inode->i_dquot[cnt]) |
1580 | continue; | 1582 | continue; |
1581 | warntype[cnt] = info_bdq_free(inode->i_dquot[cnt], number); | 1583 | warntype[cnt] = info_bdq_free(inode->i_dquot[cnt], number); |
1582 | dquot_decr_space(inode->i_dquot[cnt], number); | 1584 | dquot_decr_space(inode->i_dquot[cnt], number); |
@@ -1614,7 +1616,7 @@ int dquot_free_inode(const struct inode *inode, qsize_t number) | |||
1614 | } | 1616 | } |
1615 | spin_lock(&dq_data_lock); | 1617 | spin_lock(&dq_data_lock); |
1616 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1618 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1617 | if (inode->i_dquot[cnt] == NODQUOT) | 1619 | if (!inode->i_dquot[cnt]) |
1618 | continue; | 1620 | continue; |
1619 | warntype[cnt] = info_idq_free(inode->i_dquot[cnt], number); | 1621 | warntype[cnt] = info_idq_free(inode->i_dquot[cnt], number); |
1620 | dquot_decr_inodes(inode->i_dquot[cnt], number); | 1622 | dquot_decr_inodes(inode->i_dquot[cnt], number); |
@@ -1667,8 +1669,8 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr) | |||
1667 | return QUOTA_OK; | 1669 | return QUOTA_OK; |
1668 | /* Initialize the arrays */ | 1670 | /* Initialize the arrays */ |
1669 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1671 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1670 | transfer_from[cnt] = NODQUOT; | 1672 | transfer_from[cnt] = NULL; |
1671 | transfer_to[cnt] = NODQUOT; | 1673 | transfer_to[cnt] = NULL; |
1672 | warntype_to[cnt] = QUOTA_NL_NOWARN; | 1674 | warntype_to[cnt] = QUOTA_NL_NOWARN; |
1673 | switch (cnt) { | 1675 | switch (cnt) { |
1674 | case USRQUOTA: | 1676 | case USRQUOTA: |
@@ -1696,7 +1698,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr) | |||
1696 | space = cur_space + rsv_space; | 1698 | space = cur_space + rsv_space; |
1697 | /* Build the transfer_from list and check the limits */ | 1699 | /* Build the transfer_from list and check the limits */ |
1698 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { | 1700 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) { |
1699 | if (transfer_to[cnt] == NODQUOT) | 1701 | if (!transfer_to[cnt]) |
1700 | continue; | 1702 | continue; |
1701 | transfer_from[cnt] = inode->i_dquot[cnt]; | 1703 | transfer_from[cnt] = inode->i_dquot[cnt]; |
1702 | if (check_idq(transfer_to[cnt], 1, warntype_to + cnt) == | 1704 | if (check_idq(transfer_to[cnt], 1, warntype_to + cnt) == |
@@ -1712,7 +1714,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr) | |||
1712 | /* | 1714 | /* |
1713 | * Skip changes for same uid or gid or for turned off quota-type. | 1715 | * Skip changes for same uid or gid or for turned off quota-type. |
1714 | */ | 1716 | */ |
1715 | if (transfer_to[cnt] == NODQUOT) | 1717 | if (!transfer_to[cnt]) |
1716 | continue; | 1718 | continue; |
1717 | 1719 | ||
1718 | /* Due to IO error we might not have transfer_from[] structure */ | 1720 | /* Due to IO error we might not have transfer_from[] structure */ |
@@ -1743,7 +1745,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr) | |||
1743 | if (transfer_to[cnt]) { | 1745 | if (transfer_to[cnt]) { |
1744 | mark_dquot_dirty(transfer_to[cnt]); | 1746 | mark_dquot_dirty(transfer_to[cnt]); |
1745 | /* The reference we got is transferred to the inode */ | 1747 | /* The reference we got is transferred to the inode */ |
1746 | transfer_to[cnt] = NODQUOT; | 1748 | transfer_to[cnt] = NULL; |
1747 | } | 1749 | } |
1748 | } | 1750 | } |
1749 | warn_put_all: | 1751 | warn_put_all: |
@@ -1761,7 +1763,7 @@ over_quota: | |||
1761 | up_write(&sb_dqopt(inode->i_sb)->dqptr_sem); | 1763 | up_write(&sb_dqopt(inode->i_sb)->dqptr_sem); |
1762 | /* Clear dquot pointers we don't want to dqput() */ | 1764 | /* Clear dquot pointers we don't want to dqput() */ |
1763 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) | 1765 | for (cnt = 0; cnt < MAXQUOTAS; cnt++) |
1764 | transfer_from[cnt] = NODQUOT; | 1766 | transfer_from[cnt] = NULL; |
1765 | ret = NO_QUOTA; | 1767 | ret = NO_QUOTA; |
1766 | goto warn_put_all; | 1768 | goto warn_put_all; |
1767 | } | 1769 | } |
@@ -2256,7 +2258,7 @@ int vfs_get_dqblk(struct super_block *sb, int type, qid_t id, struct if_dqblk *d | |||
2256 | struct dquot *dquot; | 2258 | struct dquot *dquot; |
2257 | 2259 | ||
2258 | dquot = dqget(sb, id, type); | 2260 | dquot = dqget(sb, id, type); |
2259 | if (dquot == NODQUOT) | 2261 | if (!dquot) |
2260 | return -ESRCH; | 2262 | return -ESRCH; |
2261 | do_get_dqblk(dquot, di); | 2263 | do_get_dqblk(dquot, di); |
2262 | dqput(dquot); | 2264 | dqput(dquot); |