X-Git-Url: https://git.karo-electronics.de/?a=blobdiff_plain;f=fs%2Fattr.c;h=26c71ba1eed49d2f500c9e8044e68693492a47ee;hb=cb28a1bbdb4790378e7366d6c9ee1d2340b84f92;hp=966b73e25f82e06f69ad0eca22a3f6fe268c4cd0;hpb=81f8320f624a785d77443ace83391d0fdee695f6;p=karo-tx-linux.git diff --git a/fs/attr.c b/fs/attr.c index 966b73e25f82..26c71ba1eed4 100644 --- a/fs/attr.c +++ b/fs/attr.c @@ -51,7 +51,7 @@ int inode_change_ok(struct inode *inode, struct iattr *attr) } /* Check for setting the inode time. */ - if (ia_valid & (ATTR_MTIME_SET | ATTR_ATIME_SET)) { + if (ia_valid & (ATTR_MTIME_SET | ATTR_ATIME_SET | ATTR_TIMES_SET)) { if (!is_owner_or_cap(inode)) goto error; } @@ -108,6 +108,11 @@ int notify_change(struct dentry * dentry, struct iattr * attr) struct timespec now; unsigned int ia_valid = attr->ia_valid; + if (ia_valid & (ATTR_MODE | ATTR_UID | ATTR_GID | ATTR_TIMES_SET)) { + if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) + return -EPERM; + } + now = current_fs_time(inode->i_sb); attr->ia_ctime = now;