summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorSagi Grimberg <sagi@grimberg.me>2025-04-25 15:49:19 +0300
committerAnna Schumaker <anna.schumaker@oracle.com>2025-05-28 17:17:13 -0400
commitaba41e90aadeca8d4656f90639aa5f91ce564f1c (patch)
tree78d8d9e917f0f226e4a38217ef6aea04a9241fde /lib
parentd2e1d783f2c619cf9d8242b67a0ab0d2915f2920 (diff)
NFSv4.2: fix setattr caching of TIME_[MODIFY|ACCESS]_SET when timestamps are delegated
nfs_setattr will flush all pending writes before updating a file time attributes. However when the client holds delegated timestamps, it can update its timestamps locally as it is the authority for the file times attributes. The client will later set the file attributes by adding a setattr to the delegreturn compound updating the server time attributes. Fix nfs_setattr to avoid flushing pending writes when the file time attributes are delegated and the mtime/atime are set to a fixed timestamp (ATTR_[MODIFY|ACCESS]_SET. Also, when sending the setattr procedure over the wire, we need to clear the correct attribute bits from the bitmask. I was able to measure a noticable speedup when measuring untar performance. Test: $ time tar xzf ~/dir.tgz Baseline: 1m13.072s Patched: 0m49.038s Which is more than 30% latency improvement. Signed-off-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Anna Schumaker <anna.schumaker@oracle.com>
Diffstat (limited to 'lib')
0 files changed, 0 insertions, 0 deletions