nfsd: use 64-bit seconds fields in nfsd v4 code
After commit 95582b0083
"vfs: change inode times to use struct
timespec64" there are spots in the NFSv4 decoding where we decode the
protocol into a struct timeval and then convert that into a timeval64.
That's unnecesary in the NFSv4 case since the on-the-wire protocol also
uses 64-bit values. So just fix up our code to use timeval64 everywhere.
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
This commit is contained in:
@@ -274,14 +274,12 @@ static char *savemem(struct nfsd4_compoundargs *argp, __be32 *p, int nbytes)
|
||||
* we ignore all 32 bits of 'nseconds'.
|
||||
*/
|
||||
static __be32
|
||||
nfsd4_decode_time(struct nfsd4_compoundargs *argp, struct timespec *tv)
|
||||
nfsd4_decode_time(struct nfsd4_compoundargs *argp, struct timespec64 *tv)
|
||||
{
|
||||
DECODE_HEAD;
|
||||
u64 sec;
|
||||
|
||||
READ_BUF(12);
|
||||
p = xdr_decode_hyper(p, &sec);
|
||||
tv->tv_sec = sec;
|
||||
p = xdr_decode_hyper(p, &tv->tv_sec);
|
||||
tv->tv_nsec = be32_to_cpup(p++);
|
||||
if (tv->tv_nsec >= (u32)1000000000)
|
||||
return nfserr_inval;
|
||||
@@ -320,7 +318,6 @@ nfsd4_decode_fattr(struct nfsd4_compoundargs *argp, u32 *bmval,
|
||||
struct iattr *iattr, struct nfs4_acl **acl,
|
||||
struct xdr_netobj *label, int *umask)
|
||||
{
|
||||
struct timespec ts;
|
||||
int expected_len, len = 0;
|
||||
u32 dummy32;
|
||||
char *buf;
|
||||
@@ -422,8 +419,7 @@ nfsd4_decode_fattr(struct nfsd4_compoundargs *argp, u32 *bmval,
|
||||
switch (dummy32) {
|
||||
case NFS4_SET_TO_CLIENT_TIME:
|
||||
len += 12;
|
||||
status = nfsd4_decode_time(argp, &ts);
|
||||
iattr->ia_atime = timespec_to_timespec64(ts);
|
||||
status = nfsd4_decode_time(argp, &iattr->ia_atime);
|
||||
if (status)
|
||||
return status;
|
||||
iattr->ia_valid |= (ATTR_ATIME | ATTR_ATIME_SET);
|
||||
@@ -442,8 +438,7 @@ nfsd4_decode_fattr(struct nfsd4_compoundargs *argp, u32 *bmval,
|
||||
switch (dummy32) {
|
||||
case NFS4_SET_TO_CLIENT_TIME:
|
||||
len += 12;
|
||||
status = nfsd4_decode_time(argp, &ts);
|
||||
iattr->ia_mtime = timespec_to_timespec64(ts);
|
||||
status = nfsd4_decode_time(argp, &iattr->ia_mtime);
|
||||
if (status)
|
||||
return status;
|
||||
iattr->ia_valid |= (ATTR_MTIME | ATTR_MTIME_SET);
|
||||
|
Reference in New Issue
Block a user