diff options
Diffstat (limited to 'fs/xfs/quota/xfs_qm.c')
-rw-r--r-- | fs/xfs/quota/xfs_qm.c | 102 |
1 files changed, 42 insertions, 60 deletions
diff --git a/fs/xfs/quota/xfs_qm.c b/fs/xfs/quota/xfs_qm.c index a545d3e142f6..79aadb1c1f44 100644 --- a/fs/xfs/quota/xfs_qm.c +++ b/fs/xfs/quota/xfs_qm.c | |||
@@ -91,10 +91,10 @@ extern mutex_t qcheck_lock; | |||
91 | for (dqp = (l)->qh_next; dqp != NULL; dqp = dqp->NXT) { \ | 91 | for (dqp = (l)->qh_next; dqp != NULL; dqp = dqp->NXT) { \ |
92 | cmn_err(CE_DEBUG, " %d. \"%d (%s)\" " \ | 92 | cmn_err(CE_DEBUG, " %d. \"%d (%s)\" " \ |
93 | "bcnt = %d, icnt = %d, refs = %d", \ | 93 | "bcnt = %d, icnt = %d, refs = %d", \ |
94 | ++i, (int) INT_GET(dqp->q_core.d_id, ARCH_CONVERT), \ | 94 | ++i, (int) be32_to_cpu(dqp->q_core.d_id), \ |
95 | DQFLAGTO_TYPESTR(dqp), \ | 95 | DQFLAGTO_TYPESTR(dqp), \ |
96 | (int) INT_GET(dqp->q_core.d_bcount, ARCH_CONVERT), \ | 96 | (int) be64_to_cpu(dqp->q_core.d_bcount), \ |
97 | (int) INT_GET(dqp->q_core.d_icount, ARCH_CONVERT), \ | 97 | (int) be64_to_cpu(dqp->q_core.d_icount), \ |
98 | (int) dqp->q_nrefs); } \ | 98 | (int) dqp->q_nrefs); } \ |
99 | } | 99 | } |
100 | #else | 100 | #else |
@@ -727,7 +727,7 @@ xfs_qm_dqattach_one( | |||
727 | */ | 727 | */ |
728 | if (udqhint && | 728 | if (udqhint && |
729 | (dqp = udqhint->q_gdquot) && | 729 | (dqp = udqhint->q_gdquot) && |
730 | (INT_GET(dqp->q_core.d_id, ARCH_CONVERT) == id)) { | 730 | (be32_to_cpu(dqp->q_core.d_id) == id)) { |
731 | ASSERT(XFS_DQ_IS_LOCKED(udqhint)); | 731 | ASSERT(XFS_DQ_IS_LOCKED(udqhint)); |
732 | xfs_dqlock(dqp); | 732 | xfs_dqlock(dqp); |
733 | XFS_DQHOLD(dqp); | 733 | XFS_DQHOLD(dqp); |
@@ -1197,42 +1197,24 @@ xfs_qm_init_quotainfo( | |||
1197 | * a user or group before he or she can not perform any | 1197 | * a user or group before he or she can not perform any |
1198 | * more writing. If it is zero, a default is used. | 1198 | * more writing. If it is zero, a default is used. |
1199 | */ | 1199 | */ |
1200 | qinf->qi_btimelimit = | 1200 | qinf->qi_btimelimit = ddqp->d_btimer ? |
1201 | INT_GET(ddqp->d_btimer, ARCH_CONVERT) ? | 1201 | be32_to_cpu(ddqp->d_btimer) : XFS_QM_BTIMELIMIT; |
1202 | INT_GET(ddqp->d_btimer, ARCH_CONVERT) : | 1202 | qinf->qi_itimelimit = ddqp->d_itimer ? |
1203 | XFS_QM_BTIMELIMIT; | 1203 | be32_to_cpu(ddqp->d_itimer) : XFS_QM_ITIMELIMIT; |
1204 | qinf->qi_itimelimit = | 1204 | qinf->qi_rtbtimelimit = ddqp->d_rtbtimer ? |
1205 | INT_GET(ddqp->d_itimer, ARCH_CONVERT) ? | 1205 | be32_to_cpu(ddqp->d_rtbtimer) : XFS_QM_RTBTIMELIMIT; |
1206 | INT_GET(ddqp->d_itimer, ARCH_CONVERT) : | 1206 | qinf->qi_bwarnlimit = ddqp->d_bwarns ? |
1207 | XFS_QM_ITIMELIMIT; | 1207 | be16_to_cpu(ddqp->d_bwarns) : XFS_QM_BWARNLIMIT; |
1208 | qinf->qi_rtbtimelimit = | 1208 | qinf->qi_iwarnlimit = ddqp->d_iwarns ? |
1209 | INT_GET(ddqp->d_rtbtimer, ARCH_CONVERT) ? | 1209 | be16_to_cpu(ddqp->d_iwarns) : XFS_QM_IWARNLIMIT; |
1210 | INT_GET(ddqp->d_rtbtimer, ARCH_CONVERT) : | 1210 | qinf->qi_rtbwarnlimit = ddqp->d_rtbwarns ? |
1211 | XFS_QM_RTBTIMELIMIT; | 1211 | be16_to_cpu(ddqp->d_rtbwarns) : XFS_QM_RTBWARNLIMIT; |
1212 | qinf->qi_bwarnlimit = | 1212 | qinf->qi_bhardlimit = be64_to_cpu(ddqp->d_blk_hardlimit); |
1213 | INT_GET(ddqp->d_bwarns, ARCH_CONVERT) ? | 1213 | qinf->qi_bsoftlimit = be64_to_cpu(ddqp->d_blk_softlimit); |
1214 | INT_GET(ddqp->d_bwarns, ARCH_CONVERT) : | 1214 | qinf->qi_ihardlimit = be64_to_cpu(ddqp->d_ino_hardlimit); |
1215 | XFS_QM_BWARNLIMIT; | 1215 | qinf->qi_isoftlimit = be64_to_cpu(ddqp->d_ino_softlimit); |
1216 | qinf->qi_iwarnlimit = | 1216 | qinf->qi_rtbhardlimit = be64_to_cpu(ddqp->d_rtb_hardlimit); |
1217 | INT_GET(ddqp->d_iwarns, ARCH_CONVERT) ? | 1217 | qinf->qi_rtbsoftlimit = be64_to_cpu(ddqp->d_rtb_softlimit); |
1218 | INT_GET(ddqp->d_iwarns, ARCH_CONVERT) : | ||
1219 | XFS_QM_IWARNLIMIT; | ||
1220 | qinf->qi_rtbwarnlimit = | ||
1221 | INT_GET(ddqp->d_rtbwarns, ARCH_CONVERT) ? | ||
1222 | INT_GET(ddqp->d_rtbwarns, ARCH_CONVERT) : | ||
1223 | XFS_QM_RTBWARNLIMIT; | ||
1224 | qinf->qi_bhardlimit = | ||
1225 | INT_GET(ddqp->d_blk_hardlimit, ARCH_CONVERT); | ||
1226 | qinf->qi_bsoftlimit = | ||
1227 | INT_GET(ddqp->d_blk_softlimit, ARCH_CONVERT); | ||
1228 | qinf->qi_ihardlimit = | ||
1229 | INT_GET(ddqp->d_ino_hardlimit, ARCH_CONVERT); | ||
1230 | qinf->qi_isoftlimit = | ||
1231 | INT_GET(ddqp->d_ino_softlimit, ARCH_CONVERT); | ||
1232 | qinf->qi_rtbhardlimit = | ||
1233 | INT_GET(ddqp->d_rtb_hardlimit, ARCH_CONVERT); | ||
1234 | qinf->qi_rtbsoftlimit = | ||
1235 | INT_GET(ddqp->d_rtb_softlimit, ARCH_CONVERT); | ||
1236 | 1218 | ||
1237 | /* | 1219 | /* |
1238 | * We sent the XFS_QMOPT_DQSUSER flag to dqget because | 1220 | * We sent the XFS_QMOPT_DQSUSER flag to dqget because |
@@ -1511,15 +1493,15 @@ xfs_qm_reset_dqcounts( | |||
1511 | */ | 1493 | */ |
1512 | (void) xfs_qm_dqcheck(ddq, id+j, type, XFS_QMOPT_DQREPAIR, | 1494 | (void) xfs_qm_dqcheck(ddq, id+j, type, XFS_QMOPT_DQREPAIR, |
1513 | "xfs_quotacheck"); | 1495 | "xfs_quotacheck"); |
1514 | INT_SET(ddq->d_bcount, ARCH_CONVERT, 0ULL); | 1496 | ddq->d_bcount = 0; |
1515 | INT_SET(ddq->d_icount, ARCH_CONVERT, 0ULL); | 1497 | ddq->d_icount = 0; |
1516 | INT_SET(ddq->d_rtbcount, ARCH_CONVERT, 0ULL); | 1498 | ddq->d_rtbcount = 0; |
1517 | INT_SET(ddq->d_btimer, ARCH_CONVERT, (time_t)0); | 1499 | ddq->d_btimer = 0; |
1518 | INT_SET(ddq->d_itimer, ARCH_CONVERT, (time_t)0); | 1500 | ddq->d_itimer = 0; |
1519 | INT_SET(ddq->d_rtbtimer, ARCH_CONVERT, (time_t)0); | 1501 | ddq->d_rtbtimer = 0; |
1520 | INT_SET(ddq->d_bwarns, ARCH_CONVERT, 0UL); | 1502 | ddq->d_bwarns = 0; |
1521 | INT_SET(ddq->d_iwarns, ARCH_CONVERT, 0UL); | 1503 | ddq->d_iwarns = 0; |
1522 | INT_SET(ddq->d_rtbwarns, ARCH_CONVERT, 0UL); | 1504 | ddq->d_rtbwarns = 0; |
1523 | ddq = (xfs_disk_dquot_t *) ((xfs_dqblk_t *)ddq + 1); | 1505 | ddq = (xfs_disk_dquot_t *) ((xfs_dqblk_t *)ddq + 1); |
1524 | } | 1506 | } |
1525 | 1507 | ||
@@ -1692,14 +1674,14 @@ xfs_qm_quotacheck_dqadjust( | |||
1692 | * Adjust the inode count and the block count to reflect this inode's | 1674 | * Adjust the inode count and the block count to reflect this inode's |
1693 | * resource usage. | 1675 | * resource usage. |
1694 | */ | 1676 | */ |
1695 | INT_MOD(dqp->q_core.d_icount, ARCH_CONVERT, +1); | 1677 | be64_add(&dqp->q_core.d_icount, 1); |
1696 | dqp->q_res_icount++; | 1678 | dqp->q_res_icount++; |
1697 | if (nblks) { | 1679 | if (nblks) { |
1698 | INT_MOD(dqp->q_core.d_bcount, ARCH_CONVERT, nblks); | 1680 | be64_add(&dqp->q_core.d_bcount, nblks); |
1699 | dqp->q_res_bcount += nblks; | 1681 | dqp->q_res_bcount += nblks; |
1700 | } | 1682 | } |
1701 | if (rtblks) { | 1683 | if (rtblks) { |
1702 | INT_MOD(dqp->q_core.d_rtbcount, ARCH_CONVERT, rtblks); | 1684 | be64_add(&dqp->q_core.d_rtbcount, rtblks); |
1703 | dqp->q_res_rtbcount += rtblks; | 1685 | dqp->q_res_rtbcount += rtblks; |
1704 | } | 1686 | } |
1705 | 1687 | ||
@@ -2186,7 +2168,7 @@ xfs_qm_shake_freelist( | |||
2186 | xfs_dqtrace_entry(dqp, "DQSHAKE: UNLINKING"); | 2168 | xfs_dqtrace_entry(dqp, "DQSHAKE: UNLINKING"); |
2187 | #ifdef QUOTADEBUG | 2169 | #ifdef QUOTADEBUG |
2188 | cmn_err(CE_DEBUG, "Shake 0x%p, ID 0x%x\n", | 2170 | cmn_err(CE_DEBUG, "Shake 0x%p, ID 0x%x\n", |
2189 | dqp, INT_GET(dqp->q_core.d_id, ARCH_CONVERT)); | 2171 | dqp, be32_to_cpu(dqp->q_core.d_id)); |
2190 | #endif | 2172 | #endif |
2191 | ASSERT(dqp->q_nrefs == 0); | 2173 | ASSERT(dqp->q_nrefs == 0); |
2192 | nextdqp = dqp->dq_flnext; | 2174 | nextdqp = dqp->dq_flnext; |
@@ -2654,7 +2636,7 @@ xfs_qm_vop_chown_reserve( | |||
2654 | XFS_QMOPT_RES_RTBLKS : XFS_QMOPT_RES_REGBLKS; | 2636 | XFS_QMOPT_RES_RTBLKS : XFS_QMOPT_RES_REGBLKS; |
2655 | 2637 | ||
2656 | if (XFS_IS_UQUOTA_ON(mp) && udqp && | 2638 | if (XFS_IS_UQUOTA_ON(mp) && udqp && |
2657 | ip->i_d.di_uid != (uid_t)INT_GET(udqp->q_core.d_id, ARCH_CONVERT)) { | 2639 | ip->i_d.di_uid != (uid_t)be32_to_cpu(udqp->q_core.d_id)) { |
2658 | delblksudq = udqp; | 2640 | delblksudq = udqp; |
2659 | /* | 2641 | /* |
2660 | * If there are delayed allocation blocks, then we have to | 2642 | * If there are delayed allocation blocks, then we have to |
@@ -2667,10 +2649,10 @@ xfs_qm_vop_chown_reserve( | |||
2667 | } | 2649 | } |
2668 | } | 2650 | } |
2669 | if (XFS_IS_OQUOTA_ON(ip->i_mount) && gdqp) { | 2651 | if (XFS_IS_OQUOTA_ON(ip->i_mount) && gdqp) { |
2670 | if ((XFS_IS_GQUOTA_ON(ip->i_mount) && ip->i_d.di_gid != | 2652 | if ((XFS_IS_GQUOTA_ON(ip->i_mount) && |
2671 | INT_GET(gdqp->q_core.d_id, ARCH_CONVERT)) || | 2653 | ip->i_d.di_gid != be32_to_cpu(gdqp->q_core.d_id)) || |
2672 | (XFS_IS_PQUOTA_ON(ip->i_mount) && ip->i_d.di_projid != | 2654 | (XFS_IS_PQUOTA_ON(ip->i_mount) && |
2673 | INT_GET(gdqp->q_core.d_id, ARCH_CONVERT))) { | 2655 | ip->i_d.di_projid != be32_to_cpu(gdqp->q_core.d_id))) { |
2674 | delblksgdq = gdqp; | 2656 | delblksgdq = gdqp; |
2675 | if (delblks) { | 2657 | if (delblks) { |
2676 | ASSERT(ip->i_gdquot); | 2658 | ASSERT(ip->i_gdquot); |
@@ -2760,7 +2742,7 @@ xfs_qm_vop_dqattach_and_dqmod_newinode( | |||
2760 | xfs_dqunlock(udqp); | 2742 | xfs_dqunlock(udqp); |
2761 | ASSERT(ip->i_udquot == NULL); | 2743 | ASSERT(ip->i_udquot == NULL); |
2762 | ip->i_udquot = udqp; | 2744 | ip->i_udquot = udqp; |
2763 | ASSERT(ip->i_d.di_uid == INT_GET(udqp->q_core.d_id, ARCH_CONVERT)); | 2745 | ASSERT(ip->i_d.di_uid == be32_to_cpu(udqp->q_core.d_id)); |
2764 | xfs_trans_mod_dquot(tp, udqp, XFS_TRANS_DQ_ICOUNT, 1); | 2746 | xfs_trans_mod_dquot(tp, udqp, XFS_TRANS_DQ_ICOUNT, 1); |
2765 | } | 2747 | } |
2766 | if (gdqp) { | 2748 | if (gdqp) { |
@@ -2769,7 +2751,7 @@ xfs_qm_vop_dqattach_and_dqmod_newinode( | |||
2769 | xfs_dqunlock(gdqp); | 2751 | xfs_dqunlock(gdqp); |
2770 | ASSERT(ip->i_gdquot == NULL); | 2752 | ASSERT(ip->i_gdquot == NULL); |
2771 | ip->i_gdquot = gdqp; | 2753 | ip->i_gdquot = gdqp; |
2772 | ASSERT(ip->i_d.di_gid == INT_GET(gdqp->q_core.d_id, ARCH_CONVERT)); | 2754 | ASSERT(ip->i_d.di_gid == be32_to_cpu(gdqp->q_core.d_id)); |
2773 | xfs_trans_mod_dquot(tp, gdqp, XFS_TRANS_DQ_ICOUNT, 1); | 2755 | xfs_trans_mod_dquot(tp, gdqp, XFS_TRANS_DQ_ICOUNT, 1); |
2774 | } | 2756 | } |
2775 | } | 2757 | } |