diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /fs/xfs/xfs_dquot.c | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'fs/xfs/xfs_dquot.c')
| -rw-r--r-- | fs/xfs/xfs_dquot.c | 31 | 
1 files changed, 20 insertions, 11 deletions
| diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c index 044e97a33c8d..0adf27ecf3f1 100644 --- a/fs/xfs/xfs_dquot.c +++ b/fs/xfs/xfs_dquot.c @@ -570,13 +570,13 @@ xfs_qm_dqtobp(  	xfs_buf_t		**O_bpp,  	uint			flags)  { -	xfs_bmbt_irec_t map; -	int		nmaps = 1, error; -	xfs_buf_t	*bp; -	xfs_inode_t	*quotip = XFS_DQ_TO_QIP(dqp); -	xfs_mount_t	*mp = dqp->q_mount; -	xfs_dqid_t	id = be32_to_cpu(dqp->q_core.d_id); -	xfs_trans_t	*tp = (tpp ? *tpp : NULL); +	struct xfs_bmbt_irec	map; +	int			nmaps = 1, error; +	struct xfs_buf		*bp; +	struct xfs_inode	*quotip = xfs_dq_to_quota_inode(dqp); +	struct xfs_mount	*mp = dqp->q_mount; +	xfs_dqid_t		id = be32_to_cpu(dqp->q_core.d_id); +	struct xfs_trans	*tp = (tpp ? *tpp : NULL);  	dqp->q_fileoffset = (xfs_fileoff_t)id / mp->m_quotainfo->qi_dqperchunk; @@ -804,7 +804,7 @@ xfs_qm_dqget(  	xfs_dquot_t	**O_dqpp) /* OUT : locked incore dquot */  {  	struct xfs_quotainfo	*qi = mp->m_quotainfo; -	struct radix_tree_root *tree = XFS_DQUOT_TREE(qi, type); +	struct radix_tree_root *tree = xfs_dquot_tree(qi, type);  	struct xfs_dquot	*dqp;  	int			error; @@ -936,6 +936,7 @@ xfs_qm_dqput_final(  {  	struct xfs_quotainfo	*qi = dqp->q_mount->m_quotainfo;  	struct xfs_dquot	*gdqp; +	struct xfs_dquot	*pdqp;  	trace_xfs_dqput_free(dqp); @@ -949,21 +950,29 @@ xfs_qm_dqput_final(  	/*  	 * If we just added a udquot to the freelist, then we want to release -	 * the gdquot reference that it (probably) has. Otherwise it'll keep -	 * the gdquot from getting reclaimed. +	 * the gdquot/pdquot reference that it (probably) has. Otherwise it'll +	 * keep the gdquot/pdquot from getting reclaimed.  	 */  	gdqp = dqp->q_gdquot;  	if (gdqp) {  		xfs_dqlock(gdqp);  		dqp->q_gdquot = NULL;  	} + +	pdqp = dqp->q_pdquot; +	if (pdqp) { +		xfs_dqlock(pdqp); +		dqp->q_pdquot = NULL; +	}  	xfs_dqunlock(dqp);  	/* -	 * If we had a group quota hint, release it now. +	 * If we had a group/project quota hint, release it now.  	 */  	if (gdqp)  		xfs_qm_dqput(gdqp); +	if (pdqp) +		xfs_qm_dqput(pdqp);  }  /* | 
