diff options
author | Dmitry Kasatkin <dmitry.kasatkin@intel.com> | 2012-05-29 14:02:21 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2012-05-30 21:04:53 -0400 |
commit | 799243a389bde0de10fa21ca1ca453d2fe538b85 (patch) | |
tree | f69ae5a69a4936ff3adbda72c64edc25756f0648 /fs/attr.c | |
parent | a0a9b0433767713342f9cc70f563483c38e26f30 (diff) |
vfs: increment iversion when a file is truncated
When a file is truncated with truncate()/ftruncate() and then closed,
iversion is not updated. This patch uses ATTR_SIZE flag as an indication
to increment iversion.
Mimi said:
On fput(), i_version is used to detect and flag files that have changed
and need to be re-measured in the IMA measurement policy. When a file
is truncated with truncate()/ftruncate() and then closed, i_version is
not updated. As a result, although the file has changed, it will not be
re-measured and added to the IMA measurement list on subsequent access.
Signed-off-by: Dmitry Kasatkin <dmitry.kasatkin@intel.com>
Acked-by: Mimi Zohar <zohar@us.ibm.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/attr.c')
-rw-r--r-- | fs/attr.c | 5 |
1 files changed, 5 insertions, 0 deletions
@@ -176,6 +176,11 @@ int notify_change(struct dentry * dentry, struct iattr * attr) | |||
176 | return -EPERM; | 176 | return -EPERM; |
177 | } | 177 | } |
178 | 178 | ||
179 | if ((ia_valid & ATTR_SIZE) && IS_I_VERSION(inode)) { | ||
180 | if (attr->ia_size != inode->i_size) | ||
181 | inode_inc_iversion(inode); | ||
182 | } | ||
183 | |||
179 | if ((ia_valid & ATTR_MODE)) { | 184 | if ((ia_valid & ATTR_MODE)) { |
180 | umode_t amode = attr->ia_mode; | 185 | umode_t amode = attr->ia_mode; |
181 | /* Flag setting protected by i_mutex */ | 186 | /* Flag setting protected by i_mutex */ |