struct nfs_server *server = NFS_SERVER(inode);
        struct nfs4_accessargs args = {
                .fh = NFS_FH(inode),
-               .bitmask = server->cache_consistency_bitmask,
                .access = entry->mask,
        };
        struct nfs4_accessres res = {
        };
        int status = 0;
 
-       res.fattr = nfs_alloc_fattr();
-       if (res.fattr == NULL)
-               return -ENOMEM;
+       if (!nfs_have_delegated_attributes(inode)) {
+               res.fattr = nfs_alloc_fattr();
+               if (res.fattr == NULL)
+                       return -ENOMEM;
+               args.bitmask = server->cache_consistency_bitmask;
+       }
 
        status = nfs4_call_sync(server->client, server, &msg, &args.seq_args, &res.seq_res, 0);
        if (!status) {
                nfs_access_set_mask(entry, res.access);
-               nfs_refresh_inode(inode, res.fattr);
+               if (res.fattr)
+                       nfs_refresh_inode(inode, res.fattr);
        }
        nfs_free_fattr(res.fattr);
        return status;
 
        encode_sequence(xdr, &args->seq_args, &hdr);
        encode_putfh(xdr, args->fh, &hdr);
        encode_access(xdr, args->access, &hdr);
-       encode_getfattr(xdr, args->bitmask, &hdr);
+       if (args->bitmask)
+               encode_getfattr(xdr, args->bitmask, &hdr);
        encode_nops(&hdr);
 }
 
        status = decode_access(xdr, &res->supported, &res->access);
        if (status != 0)
                goto out;
-       decode_getfattr(xdr, res->fattr, res->server);
+       if (res->fattr)
+               decode_getfattr(xdr, res->fattr, res->server);
 out:
        return status;
 }