|
@@ -1175,14 +1175,14 @@ int ocfs2_setattr(struct dentry *dentry, struct iattr *attr)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- if ((attr->ia_valid & ATTR_UID && attr->ia_uid != inode->i_uid) ||
|
|
|
- (attr->ia_valid & ATTR_GID && attr->ia_gid != inode->i_gid)) {
|
|
|
+ if ((attr->ia_valid & ATTR_UID && !uid_eq(attr->ia_uid, inode->i_uid)) ||
|
|
|
+ (attr->ia_valid & ATTR_GID && !gid_eq(attr->ia_gid, inode->i_gid))) {
|
|
|
/*
|
|
|
* Gather pointers to quota structures so that allocation /
|
|
|
* freeing of quota structures happens here and not inside
|
|
|
* dquot_transfer() where we have problems with lock ordering
|
|
|
*/
|
|
|
- if (attr->ia_valid & ATTR_UID && attr->ia_uid != inode->i_uid
|
|
|
+ if (attr->ia_valid & ATTR_UID && !uid_eq(attr->ia_uid, inode->i_uid)
|
|
|
&& OCFS2_HAS_RO_COMPAT_FEATURE(sb,
|
|
|
OCFS2_FEATURE_RO_COMPAT_USRQUOTA)) {
|
|
|
transfer_to[USRQUOTA] = dqget(sb, make_kqid_uid(attr->ia_uid));
|
|
@@ -1191,7 +1191,7 @@ int ocfs2_setattr(struct dentry *dentry, struct iattr *attr)
|
|
|
goto bail_unlock;
|
|
|
}
|
|
|
}
|
|
|
- if (attr->ia_valid & ATTR_GID && attr->ia_gid != inode->i_gid
|
|
|
+ if (attr->ia_valid & ATTR_GID && !gid_eq(attr->ia_gid, inode->i_gid)
|
|
|
&& OCFS2_HAS_RO_COMPAT_FEATURE(sb,
|
|
|
OCFS2_FEATURE_RO_COMPAT_GRPQUOTA)) {
|
|
|
transfer_to[GRPQUOTA] = dqget(sb, make_kqid_gid(attr->ia_gid));
|