diff options
| author | Kinglong Mee <kinglongmee@gmail.com> | 2019-08-05 11:08:02 +0800 | 
|---|---|---|
| committer | hari gowtham <hari.gowtham005@gmail.com> | 2019-08-07 05:09:15 +0000 | 
| commit | cf42677ac0cc042ea4318062219908095d4027c0 (patch) | |
| tree | 112ba82429ef6ca00fe00d0810fb6fab64708635 | |
| parent | aa45fcc1384ea6120d582cdad35b1d610e6437af (diff) | |
features/utime: always update ctime at setattr
For the nfs EXCLUSIVE mode create may sets a later time
to mtime (at verifier), it should not set to ctime for
storage.ctime does not allowed set ctime to a earlier time.
 /* Earlier, mdata was updated only if the existing time is less
  * than the time to be updated. This would fail the scenarios
  * where mtime can be set to any time using the syscall. Hence
  * just updating without comparison. But the ctime is not
  * allowed to changed to older date.
  */
According to kernel's setattr, always set ctime at setattr,
and doesnot set ctime from mtime at storage.ctime.
Backport of:
 > Patch: https://review.gluster.org/23154
 > Change-Id: I5cfde6cb7f8939da9617506e3dc80bd840e0d749
 > BUG: 1737288
 > Signed-off-by: Kinglong Mee <kinglongmee@gmail.com>
Change-Id: I5cfde6cb7f8939da9617506e3dc80bd840e0d749
fixes: bz#1737746
Signed-off-by: Kotresh HR <khiremat@redhat.com>
| -rwxr-xr-x | xlators/features/utime/src/utime-gen-fops-c.py | 13 | ||||
| -rw-r--r-- | xlators/storage/posix/src/posix-metadata.c | 2 | 
2 files changed, 2 insertions, 13 deletions
| diff --git a/xlators/features/utime/src/utime-gen-fops-c.py b/xlators/features/utime/src/utime-gen-fops-c.py index 8730a51d13e..a8637ffe6f6 100755 --- a/xlators/features/utime/src/utime-gen-fops-c.py +++ b/xlators/features/utime/src/utime-gen-fops-c.py @@ -82,18 +82,7 @@ gf_utime_@NAME@ (call_frame_t *frame, xlator_t *this,               @LONG_ARGS@)  {          gl_timespec_get(&frame->root->ctime); - -        if (!valid) { -                frame->root->flags |= MDATA_CTIME; -        } - -        if (valid & (GF_SET_ATTR_UID | GF_SET_ATTR_GID)) { -                frame->root->flags |= MDATA_CTIME; -        } - -        if (valid & GF_SET_ATTR_MODE) { -                frame->root->flags |= MDATA_CTIME; -        } +        frame->root->flags |= MDATA_CTIME;          STACK_WIND (frame, gf_utime_@NAME@_cbk, FIRST_CHILD(this),                      FIRST_CHILD(this)->fops->@NAME@, @SHORT_ARGS@); diff --git a/xlators/storage/posix/src/posix-metadata.c b/xlators/storage/posix/src/posix-metadata.c index 57791fa9536..5cbdc988fb1 100644 --- a/xlators/storage/posix/src/posix-metadata.c +++ b/xlators/storage/posix/src/posix-metadata.c @@ -631,7 +631,7 @@ posix_update_utime_in_mdata(xlator_t *this, const char *real_path, int fd,              tv.tv_sec = stbuf->ia_mtime;              SET_TIMESPEC_NSEC_OR_TIMEVAL_USEC(tv, stbuf->ia_mtime_nsec); -            flag.ctime = 1; +            flag.ctime = 0;              flag.mtime = 1;              flag.atime = 0; | 
