diff options
Diffstat (limited to 'fs/xfs/xfs_iops.c')
| -rw-r--r-- | fs/xfs/xfs_iops.c | 27 | 
1 files changed, 14 insertions, 13 deletions
| diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c index ca9ecaa81112..96dda62d497b 100644 --- a/fs/xfs/xfs_iops.c +++ b/fs/xfs/xfs_iops.c @@ -467,9 +467,6 @@ xfs_setattr_mode(  	ASSERT(tp);  	ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL)); -	if (!in_group_p(inode->i_gid) && !capable(CAP_FSETID)) -		mode &= ~S_ISGID; -  	ip->i_d.di_mode &= S_IFMT;  	ip->i_d.di_mode |= mode & ~S_IFMT; @@ -495,15 +492,18 @@ xfs_setattr_nonsize(  	trace_xfs_setattr(ip); -	if (mp->m_flags & XFS_MOUNT_RDONLY) -		return XFS_ERROR(EROFS); +	/* If acls are being inherited, we already have this checked */ +	if (!(flags & XFS_ATTR_NOACL)) { +		if (mp->m_flags & XFS_MOUNT_RDONLY) +			return XFS_ERROR(EROFS); -	if (XFS_FORCED_SHUTDOWN(mp)) -		return XFS_ERROR(EIO); +		if (XFS_FORCED_SHUTDOWN(mp)) +			return XFS_ERROR(EIO); -	error = -inode_change_ok(inode, iattr); -	if (error) -		return XFS_ERROR(error); +		error = -inode_change_ok(inode, iattr); +		if (error) +			return XFS_ERROR(error); +	}  	ASSERT((mask & ATTR_SIZE) == 0); @@ -539,7 +539,7 @@ xfs_setattr_nonsize(  		ASSERT(udqp == NULL);  		ASSERT(gdqp == NULL);  		error = xfs_qm_vop_dqalloc(ip, uid, gid, xfs_get_projid(ip), -					 qflags, &udqp, &gdqp); +					 qflags, &udqp, &gdqp, NULL);  		if (error)  			return error;  	} @@ -575,7 +575,7 @@ xfs_setattr_nonsize(  		     (XFS_IS_GQUOTA_ON(mp) && igid != gid))) {  			ASSERT(tp);  			error = xfs_qm_vop_chown_reserve(tp, ip, udqp, gdqp, -						capable(CAP_FOWNER) ? +						NULL, capable(CAP_FOWNER) ?  						XFS_QMOPT_FORCE_RES : 0);  			if (error)	/* out of quota */  				goto out_trans_cancel; @@ -987,7 +987,8 @@ xfs_fiemap_format(  	if (bmv->bmv_oflags & BMV_OF_PREALLOC)  		fiemap_flags |= FIEMAP_EXTENT_UNWRITTEN;  	else if (bmv->bmv_oflags & BMV_OF_DELALLOC) { -		fiemap_flags |= FIEMAP_EXTENT_DELALLOC; +		fiemap_flags |= (FIEMAP_EXTENT_DELALLOC | +				 FIEMAP_EXTENT_UNKNOWN);  		physical = 0;   /* no block yet */  	}  	if (bmv->bmv_oflags & BMV_OF_LAST) | 
