VFS: check nanoseconds in utimensat
utimensat() (and possibly other callers of do_utimes()) didn't check if the nanosecond value was within the allowed range. Signed-off-by: Miklos Szeredi <mszeredi@suse.cz> Cc: Ulrich Drepper <drepper@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
995e4286a0
commit
043f46f615
1 changed files with 13 additions and 0 deletions
13
fs/utimes.c
13
fs/utimes.c
|
@ -38,6 +38,14 @@ asmlinkage long sys_utime(char __user *filename, struct utimbuf __user *times)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static bool nsec_valid(long nsec)
|
||||||
|
{
|
||||||
|
if (nsec == UTIME_OMIT || nsec == UTIME_NOW)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return nsec >= 0 && nsec <= 999999999;
|
||||||
|
}
|
||||||
|
|
||||||
/* If times==NULL, set access and modification to current time,
|
/* If times==NULL, set access and modification to current time,
|
||||||
* must be owner or have write permission.
|
* must be owner or have write permission.
|
||||||
* Else, update from *times, must be owner or super user.
|
* Else, update from *times, must be owner or super user.
|
||||||
|
@ -52,6 +60,11 @@ long do_utimes(int dfd, char __user *filename, struct timespec *times, int flags
|
||||||
struct file *f = NULL;
|
struct file *f = NULL;
|
||||||
|
|
||||||
error = -EINVAL;
|
error = -EINVAL;
|
||||||
|
if (times && (!nsec_valid(times[0].tv_nsec) ||
|
||||||
|
!nsec_valid(times[1].tv_nsec))) {
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (flags & ~AT_SYMLINK_NOFOLLOW)
|
if (flags & ~AT_SYMLINK_NOFOLLOW)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue