diff options
Diffstat (limited to 'fs/xfs/xfs_qm.c')
| -rw-r--r-- | fs/xfs/xfs_qm.c | 83 | 
1 files changed, 48 insertions, 35 deletions
| diff --git a/fs/xfs/xfs_qm.c b/fs/xfs/xfs_qm.c index 010a13a201aa..5b848f4b637f 100644 --- a/fs/xfs/xfs_qm.c +++ b/fs/xfs/xfs_qm.c @@ -48,7 +48,7 @@  STATIC int	xfs_qm_init_quotainos(xfs_mount_t *);  STATIC int	xfs_qm_init_quotainfo(xfs_mount_t *); - +STATIC void	xfs_qm_destroy_quotainos(xfs_quotainfo_t *qi);  STATIC void	xfs_qm_dqfree_one(struct xfs_dquot *dqp);  /*   * We use the batch lookup interface to iterate over the dquots as it @@ -162,7 +162,7 @@ xfs_qm_dqpurge(  		 */  		error = xfs_qm_dqflush(dqp, &bp);  		if (error) { -			xfs_warn(mp, "%s: dquot %p flush failed", +			xfs_warn(mp, "%s: dquot "PTR_FMT" flush failed",  				__func__, dqp);  		} else {  			error = xfs_bwrite(bp); @@ -291,8 +291,7 @@ xfs_qm_dqattach_one(  	 * exist on disk and we didn't ask it to allocate; ESRCH if quotas got  	 * turned off suddenly.  	 */ -	error = xfs_qm_dqget(ip->i_mount, ip, id, type, -			     doalloc | XFS_QMOPT_DOWARN, &dqp); +	error = xfs_qm_dqget(ip->i_mount, ip, id, type, doalloc, &dqp);  	if (error)  		return error; @@ -481,7 +480,7 @@ xfs_qm_dquot_isolate(  		error = xfs_qm_dqflush(dqp, &bp);  		if (error) { -			xfs_warn(dqp->q_mount, "%s: dquot %p flush failed", +			xfs_warn(dqp->q_mount, "%s: dquot "PTR_FMT" flush failed",  				 __func__, dqp);  			goto out_unlock_dirty;  		} @@ -574,7 +573,7 @@ xfs_qm_set_defquota(  	struct xfs_def_quota    *defq;  	int			error; -	error = xfs_qm_dqread(mp, 0, type, XFS_QMOPT_DOWARN, &dqp); +	error = xfs_qm_dqread(mp, 0, type, 0, &dqp);  	if (!error) {  		xfs_disk_dquot_t        *ddqp = &dqp->q_core; @@ -652,7 +651,7 @@ xfs_qm_init_quotainfo(  			XFS_IS_UQUOTA_RUNNING(mp) ? XFS_DQ_USER :  			 (XFS_IS_GQUOTA_RUNNING(mp) ? XFS_DQ_GROUP :  			  XFS_DQ_PROJ), -			XFS_QMOPT_DOWARN, &dqp); +			0, &dqp);  	if (!error) {  		xfs_disk_dquot_t	*ddqp = &dqp->q_core; @@ -695,9 +694,17 @@ xfs_qm_init_quotainfo(  	qinf->qi_shrinker.scan_objects = xfs_qm_shrink_scan;  	qinf->qi_shrinker.seeks = DEFAULT_SEEKS;  	qinf->qi_shrinker.flags = SHRINKER_NUMA_AWARE; -	register_shrinker(&qinf->qi_shrinker); + +	error = register_shrinker(&qinf->qi_shrinker); +	if (error) +		goto out_free_inos; +  	return 0; +out_free_inos: +	mutex_destroy(&qinf->qi_quotaofflock); +	mutex_destroy(&qinf->qi_tree_lock); +	xfs_qm_destroy_quotainos(qinf);  out_free_lru:  	list_lru_destroy(&qinf->qi_lru);  out_free_qinf: @@ -706,7 +713,6 @@ out_free_qinf:  	return error;  } -  /*   * Gets called when unmounting a filesystem or when all quotas get   * turned off. @@ -723,19 +729,8 @@ xfs_qm_destroy_quotainfo(  	unregister_shrinker(&qi->qi_shrinker);  	list_lru_destroy(&qi->qi_lru); - -	if (qi->qi_uquotaip) { -		IRELE(qi->qi_uquotaip); -		qi->qi_uquotaip = NULL; /* paranoia */ -	} -	if (qi->qi_gquotaip) { -		IRELE(qi->qi_gquotaip); -		qi->qi_gquotaip = NULL; -	} -	if (qi->qi_pquotaip) { -		IRELE(qi->qi_pquotaip); -		qi->qi_pquotaip = NULL; -	} +	xfs_qm_destroy_quotainos(qi); +	mutex_destroy(&qi->qi_tree_lock);  	mutex_destroy(&qi->qi_quotaofflock);  	kmem_free(qi);  	mp->m_quotainfo = NULL; @@ -793,8 +788,8 @@ xfs_qm_qino_alloc(  		return error;  	if (need_alloc) { -		error = xfs_dir_ialloc(&tp, NULL, S_IFREG, 1, 0, 0, 1, ip, -								&committed); +		error = xfs_dir_ialloc(&tp, NULL, S_IFREG, 1, 0, 0, ip, +				&committed);  		if (error) {  			xfs_trans_cancel(tp);  			return error; @@ -847,6 +842,7 @@ xfs_qm_reset_dqcounts(  {  	struct xfs_dqblk	*dqb;  	int			j; +	xfs_failaddr_t		fa;  	trace_xfs_reset_dqcounts(bp, _RET_IP_); @@ -868,10 +864,13 @@ xfs_qm_reset_dqcounts(  		/*  		 * Do a sanity check, and if needed, repair the dqblk. Don't  		 * output any warnings because it's perfectly possible to -		 * find uninitialised dquot blks. See comment in xfs_dqcheck. +		 * find uninitialised dquot blks. See comment in +		 * xfs_dquot_verify.  		 */ -		xfs_dqcheck(mp, ddq, id+j, type, XFS_QMOPT_DQREPAIR, -			    "xfs_quotacheck"); +		fa = xfs_dquot_verify(mp, ddq, id + j, type, 0); +		if (fa) +			xfs_dquot_repair(mp, ddq, id + j, type); +  		/*  		 * Reset type in case we are reusing group quota file for  		 * project quotas or vice versa @@ -1078,8 +1077,7 @@ xfs_qm_quotacheck_dqadjust(  	struct xfs_dquot	*dqp;  	int			error; -	error = xfs_qm_dqget(mp, ip, id, type, -			     XFS_QMOPT_DQALLOC | XFS_QMOPT_DOWARN, &dqp); +	error = xfs_qm_dqget(mp, ip, id, type, XFS_QMOPT_DQALLOC, &dqp);  	if (error) {  		/*  		 * Shouldn't be able to turn off quotas here. @@ -1600,6 +1598,24 @@ error_rele:  }  STATIC void +xfs_qm_destroy_quotainos( +	xfs_quotainfo_t	*qi) +{ +	if (qi->qi_uquotaip) { +		IRELE(qi->qi_uquotaip); +		qi->qi_uquotaip = NULL; /* paranoia */ +	} +	if (qi->qi_gquotaip) { +		IRELE(qi->qi_gquotaip); +		qi->qi_gquotaip = NULL; +	} +	if (qi->qi_pquotaip) { +		IRELE(qi->qi_pquotaip); +		qi->qi_pquotaip = NULL; +	} +} + +STATIC void  xfs_qm_dqfree_one(  	struct xfs_dquot	*dqp)  { @@ -1682,8 +1698,7 @@ xfs_qm_vop_dqalloc(  			xfs_iunlock(ip, lockflags);  			error = xfs_qm_dqget(mp, NULL, uid,  						 XFS_DQ_USER, -						 XFS_QMOPT_DQALLOC | -						 XFS_QMOPT_DOWARN, +						 XFS_QMOPT_DQALLOC,  						 &uq);  			if (error) {  				ASSERT(error != -ENOENT); @@ -1709,8 +1724,7 @@ xfs_qm_vop_dqalloc(  			xfs_iunlock(ip, lockflags);  			error = xfs_qm_dqget(mp, NULL, gid,  						 XFS_DQ_GROUP, -						 XFS_QMOPT_DQALLOC | -						 XFS_QMOPT_DOWARN, +						 XFS_QMOPT_DQALLOC,  						 &gq);  			if (error) {  				ASSERT(error != -ENOENT); @@ -1729,8 +1743,7 @@ xfs_qm_vop_dqalloc(  			xfs_iunlock(ip, lockflags);  			error = xfs_qm_dqget(mp, NULL, (xfs_dqid_t)prid,  						 XFS_DQ_PROJ, -						 XFS_QMOPT_DQALLOC | -						 XFS_QMOPT_DOWARN, +						 XFS_QMOPT_DQALLOC,  						 &pq);  			if (error) {  				ASSERT(error != -ENOENT); | 
