diff options
| author | Christoph Hellwig <hch@lst.de> | 2009-06-08 15:33:32 +0200 | 
|---|---|---|
| committer | Christoph Hellwig <hch@brick.lst.de> | 2009-06-08 15:33:32 +0200 | 
| commit | 7d095257e321214e4cf359abd131ba1f09c60cba (patch) | |
| tree | 3f71e2650651616f8ba168b64a82ab48aedef14c /fs/xfs/xfs_vnodeops.c | |
| parent | 0c5e1ce89f1eacc366ec421c0f5f681159479c28 (diff) | |
xfs: kill xfs_qmops
Kill the quota ops function vector and replace it with direct calls or
stubs in the CONFIG_XFS_QUOTA=n case.
Make sure we check XFS_IS_QUOTA_RUNNING in the right spots.  We can remove
the number of those checks because the XFS_TRANS_DQ_DIRTY flag can't be set
otherwise.
This brings us back closer to the way this code worked in IRIX and earlier
Linux versions, but we keep a lot of the more useful factoring of common
code.
Eventually we should also kill xfs_qm_bhv.c, but that's left for a later
patch.
Reduces the size of the source code by about 250 lines and the size of
XFS module by about 1.5 kilobytes with quotas enabled:
   text	   data	    bss	    dec	    hex	filename
 615957	   2960	   3848	 622765	  980ad	fs/xfs/xfs.o
 617231	   3152	   3848	 624231	  98667	fs/xfs/xfs.o.old
Fallout:
 - xfs_qm_dqattach is split into xfs_qm_dqattach_locked which expects
   the inode locked and xfs_qm_dqattach which does the locking around it,
   thus removing XFS_QMOPT_ILOCKED.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Eric Sandeen <sandeen@sandeen.net>
Diffstat (limited to 'fs/xfs/xfs_vnodeops.c')
| -rw-r--r-- | fs/xfs/xfs_vnodeops.c | 99 | 
1 files changed, 51 insertions, 48 deletions
| diff --git a/fs/xfs/xfs_vnodeops.c b/fs/xfs/xfs_vnodeops.c index 19cf90a9c762..b56321b2b9f0 100644 --- a/fs/xfs/xfs_vnodeops.c +++ b/fs/xfs/xfs_vnodeops.c @@ -118,7 +118,7 @@ xfs_setattr(  		 */  		ASSERT(udqp == NULL);  		ASSERT(gdqp == NULL); -		code = XFS_QM_DQVOPALLOC(mp, ip, uid, gid, ip->i_d.di_projid, +		code = xfs_qm_vop_dqalloc(ip, uid, gid, ip->i_d.di_projid,  					 qflags, &udqp, &gdqp);  		if (code)  			return code; @@ -180,10 +180,11 @@ xfs_setattr(  		 * Do a quota reservation only if uid/gid is actually  		 * going to change.  		 */ -		if ((XFS_IS_UQUOTA_ON(mp) && iuid != uid) || -		    (XFS_IS_GQUOTA_ON(mp) && igid != gid)) { +		if (XFS_IS_QUOTA_RUNNING(mp) && +		    ((XFS_IS_UQUOTA_ON(mp) && iuid != uid) || +		     (XFS_IS_GQUOTA_ON(mp) && igid != gid))) {  			ASSERT(tp); -			code = XFS_QM_DQVOPCHOWNRESV(mp, tp, ip, udqp, gdqp, +			code = xfs_qm_vop_chown_reserve(tp, ip, udqp, gdqp,  						capable(CAP_FOWNER) ?  						XFS_QMOPT_FORCE_RES : 0);  			if (code)	/* out of quota */ @@ -217,7 +218,7 @@ xfs_setattr(  		/*  		 * Make sure that the dquots are attached to the inode.  		 */ -		code = XFS_QM_DQATTACH(mp, ip, XFS_QMOPT_ILOCKED); +		code = xfs_qm_dqattach_locked(ip, 0);  		if (code)  			goto error_return; @@ -351,21 +352,21 @@ xfs_setattr(  		 * in the transaction.  		 */  		if (iuid != uid) { -			if (XFS_IS_UQUOTA_ON(mp)) { +			if (XFS_IS_QUOTA_RUNNING(mp) && XFS_IS_UQUOTA_ON(mp)) {  				ASSERT(mask & ATTR_UID);  				ASSERT(udqp); -				olddquot1 = XFS_QM_DQVOPCHOWN(mp, tp, ip, +				olddquot1 = xfs_qm_vop_chown(tp, ip,  							&ip->i_udquot, udqp);  			}  			ip->i_d.di_uid = uid;  			inode->i_uid = uid;  		}  		if (igid != gid) { -			if (XFS_IS_GQUOTA_ON(mp)) { +			if (XFS_IS_QUOTA_RUNNING(mp) && XFS_IS_GQUOTA_ON(mp)) {  				ASSERT(!XFS_IS_PQUOTA_ON(mp));  				ASSERT(mask & ATTR_GID);  				ASSERT(gdqp); -				olddquot2 = XFS_QM_DQVOPCHOWN(mp, tp, ip, +				olddquot2 = xfs_qm_vop_chown(tp, ip,  							&ip->i_gdquot, gdqp);  			}  			ip->i_d.di_gid = gid; @@ -461,10 +462,10 @@ xfs_setattr(  	/*  	 * Release any dquot(s) the inode had kept before chown.  	 */ -	XFS_QM_DQRELE(mp, olddquot1); -	XFS_QM_DQRELE(mp, olddquot2); -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(olddquot1); +	xfs_qm_dqrele(olddquot2); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	if (code) {  		return code; @@ -482,8 +483,8 @@ xfs_setattr(  	commit_flags |= XFS_TRANS_ABORT;  	/* FALLTHROUGH */   error_return: -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	if (tp) {  		xfs_trans_cancel(tp, commit_flags);  	} @@ -739,7 +740,8 @@ xfs_free_eofblocks(  		/*  		 * Attach the dquots to the inode up front.  		 */ -		if ((error = XFS_QM_DQATTACH(mp, ip, 0))) +		error = xfs_qm_dqattach(ip, 0); +		if (error)  			return error;  		/* @@ -1181,7 +1183,8 @@ xfs_inactive(  	ASSERT(ip->i_d.di_nlink == 0); -	if ((error = XFS_QM_DQATTACH(mp, ip, 0))) +	error = xfs_qm_dqattach(ip, 0); +	if (error)  		return VN_INACTIVE_CACHE;  	tp = xfs_trans_alloc(mp, XFS_TRANS_INACTIVE); @@ -1307,7 +1310,7 @@ xfs_inactive(  		/*  		 * Credit the quota account(s). The inode is gone.  		 */ -		XFS_TRANS_MOD_DQUOT_BYINO(mp, tp, ip, XFS_TRANS_DQ_ICOUNT, -1); +		xfs_trans_mod_dquot_byino(tp, ip, XFS_TRANS_DQ_ICOUNT, -1);  		/*  		 * Just ignore errors at this point.  There is nothing we can @@ -1323,11 +1326,11 @@ xfs_inactive(  			xfs_fs_cmn_err(CE_NOTE, mp, "xfs_inactive: "  				"xfs_trans_commit() returned error %d", error);  	} +  	/*  	 * Release the dquots held by inode, if any.  	 */ -	XFS_QM_DQDETACH(mp, ip); - +	xfs_qm_dqdetach(ip);  	xfs_iunlock(ip, XFS_IOLOCK_EXCL | XFS_ILOCK_EXCL);   out: @@ -1427,8 +1430,7 @@ xfs_create(  	/*  	 * Make sure that we have allocated dquot(s) on disk.  	 */ -	error = XFS_QM_DQVOPALLOC(mp, dp, -			current_fsuid(), current_fsgid(), prid, +	error = xfs_qm_vop_dqalloc(dp, current_fsuid(), current_fsgid(), prid,  			XFS_QMOPT_QUOTALL | XFS_QMOPT_INHERIT, &udqp, &gdqp);  	if (error)  		goto std_return; @@ -1489,7 +1491,7 @@ xfs_create(  	/*  	 * Reserve disk quota and the inode.  	 */ -	error = XFS_TRANS_RESERVE_QUOTA(mp, tp, udqp, gdqp, resblks, 1, 0); +	error = xfs_trans_reserve_quota(tp, mp, udqp, gdqp, resblks, 1, 0);  	if (error)  		goto out_trans_cancel; @@ -1561,7 +1563,7 @@ xfs_create(  	 * These ids of the inode couldn't have changed since the new  	 * inode has been locked ever since it was created.  	 */ -	XFS_QM_DQVOPCREATE(mp, tp, ip, udqp, gdqp); +	xfs_qm_vop_create_dqattach(tp, ip, udqp, gdqp);  	/*  	 * xfs_trans_commit normally decrements the vnode ref count @@ -1580,8 +1582,8 @@ xfs_create(  		goto out_dqrele;  	} -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	*ipp = ip; @@ -1602,8 +1604,8 @@ xfs_create(   out_trans_cancel:  	xfs_trans_cancel(tp, cancel_flags);   out_dqrele: -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	if (unlock_dp_on_error)  		xfs_iunlock(dp, XFS_ILOCK_EXCL); @@ -1837,11 +1839,11 @@ xfs_remove(  			return error;  	} -	error = XFS_QM_DQATTACH(mp, dp, 0); +	error = xfs_qm_dqattach(dp, 0);  	if (error)  		goto std_return; -	error = XFS_QM_DQATTACH(mp, ip, 0); +	error = xfs_qm_dqattach(ip, 0);  	if (error)  		goto std_return; @@ -2028,11 +2030,11 @@ xfs_link(  	/* Return through std_return after this point. */ -	error = XFS_QM_DQATTACH(mp, sip, 0); +	error = xfs_qm_dqattach(sip, 0);  	if (error)  		goto std_return; -	error = XFS_QM_DQATTACH(mp, tdp, 0); +	error = xfs_qm_dqattach(tdp, 0);  	if (error)  		goto std_return; @@ -2205,8 +2207,7 @@ xfs_symlink(  	/*  	 * Make sure that we have allocated dquot(s) on disk.  	 */ -	error = XFS_QM_DQVOPALLOC(mp, dp, -			current_fsuid(), current_fsgid(), prid, +	error = xfs_qm_vop_dqalloc(dp, current_fsuid(), current_fsgid(), prid,  			XFS_QMOPT_QUOTALL | XFS_QMOPT_INHERIT, &udqp, &gdqp);  	if (error)  		goto std_return; @@ -2248,7 +2249,7 @@ xfs_symlink(  	/*  	 * Reserve disk quota : blocks and inode.  	 */ -	error = XFS_TRANS_RESERVE_QUOTA(mp, tp, udqp, gdqp, resblks, 1, 0); +	error = xfs_trans_reserve_quota(tp, mp, udqp, gdqp, resblks, 1, 0);  	if (error)  		goto error_return; @@ -2288,7 +2289,7 @@ xfs_symlink(  	/*  	 * Also attach the dquot(s) to it, if applicable.  	 */ -	XFS_QM_DQVOPCREATE(mp, tp, ip, udqp, gdqp); +	xfs_qm_vop_create_dqattach(tp, ip, udqp, gdqp);  	if (resblks)  		resblks -= XFS_IALLOC_SPACE_RES(mp); @@ -2376,8 +2377,8 @@ xfs_symlink(  		goto error2;  	}  	error = xfs_trans_commit(tp, XFS_TRANS_RELEASE_LOG_RES); -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	/* Fall through to std_return with error = 0 or errno from  	 * xfs_trans_commit	*/ @@ -2401,8 +2402,8 @@ std_return:  	cancel_flags |= XFS_TRANS_ABORT;   error_return:  	xfs_trans_cancel(tp, cancel_flags); -	XFS_QM_DQRELE(mp, udqp); -	XFS_QM_DQRELE(mp, gdqp); +	xfs_qm_dqrele(udqp); +	xfs_qm_dqrele(gdqp);  	if (unlock_dp_on_error)  		xfs_iunlock(dp, XFS_ILOCK_EXCL); @@ -2541,7 +2542,8 @@ xfs_alloc_file_space(  	if (XFS_FORCED_SHUTDOWN(mp))  		return XFS_ERROR(EIO); -	if ((error = XFS_QM_DQATTACH(mp, ip, 0))) +	error = xfs_qm_dqattach(ip, 0); +	if (error)  		return error;  	if (len <= 0) @@ -2628,8 +2630,8 @@ retry:  			break;  		}  		xfs_ilock(ip, XFS_ILOCK_EXCL); -		error = XFS_TRANS_RESERVE_QUOTA_NBLKS(mp, tp, ip, -						      qblocks, 0, quota_flag); +		error = xfs_trans_reserve_quota_nblks(tp, ip, qblocks, +						      0, quota_flag);  		if (error)  			goto error1; @@ -2688,7 +2690,7 @@ dmapi_enospc_check:  error0:	/* Cancel bmap, unlock inode, unreserve quota blocks, cancel trans */  	xfs_bmap_cancel(&free_list); -	XFS_TRANS_UNRESERVE_QUOTA_NBLKS(mp, tp, ip, qblocks, 0, quota_flag); +	xfs_trans_unreserve_quota_nblks(tp, ip, qblocks, 0, quota_flag);  error1:	/* Just cancel transaction */  	xfs_trans_cancel(tp, XFS_TRANS_RELEASE_LOG_RES | XFS_TRANS_ABORT); @@ -2827,7 +2829,8 @@ xfs_free_file_space(  	xfs_itrace_entry(ip); -	if ((error = XFS_QM_DQATTACH(mp, ip, 0))) +	error = xfs_qm_dqattach(ip, 0); +	if (error)  		return error;  	error = 0; @@ -2953,9 +2956,9 @@ xfs_free_file_space(  			break;  		}  		xfs_ilock(ip, XFS_ILOCK_EXCL); -		error = XFS_TRANS_RESERVE_QUOTA(mp, tp, -				ip->i_udquot, ip->i_gdquot, resblks, 0, -				XFS_QMOPT_RES_REGBLKS); +		error = xfs_trans_reserve_quota(tp, mp, +				ip->i_udquot, ip->i_gdquot, +				resblks, 0, XFS_QMOPT_RES_REGBLKS);  		if (error)  			goto error1; | 
