aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/nfs/nfs4xdr.c38
1 files changed, 13 insertions, 25 deletions
diff --git a/fs/nfs/nfs4xdr.c b/fs/nfs/nfs4xdr.c
index 9bf5e66d11db..4c43e4874c52 100644
--- a/fs/nfs/nfs4xdr.c
+++ b/fs/nfs/nfs4xdr.c
@@ -5803,11 +5803,10 @@ __be32 *nfs4_decode_dirent(struct xdr_stream *xdr, struct nfs_entry *entry,
5803 p = xdr_decode_hyper(p, &entry->cookie); 5803 p = xdr_decode_hyper(p, &entry->cookie);
5804 entry->len = ntohl(*p++); 5804 entry->len = ntohl(*p++);
5805 5805
5806 p = xdr_inline_decode(xdr, entry->len + 4); 5806 p = xdr_inline_decode(xdr, entry->len);
5807 if (unlikely(!p)) 5807 if (unlikely(!p))
5808 goto out_overflow; 5808 goto out_overflow;
5809 entry->name = (const char *) p; 5809 entry->name = (const char *) p;
5810 p += XDR_QUADLEN(entry->len);
5811 5810
5812 /* 5811 /*
5813 * In case the server doesn't return an inode number, 5812 * In case the server doesn't return an inode number,
@@ -5817,30 +5816,19 @@ __be32 *nfs4_decode_dirent(struct xdr_stream *xdr, struct nfs_entry *entry,
5817 entry->ino = 1; 5816 entry->ino = 1;
5818 entry->fattr->valid = 0; 5817 entry->fattr->valid = 0;
5819 5818
5820 len = ntohl(*p++); /* bitmap length */ 5819 if (decode_attr_bitmap(xdr, bitmap) < 0)
5821 if (len-- > 0) { 5820 goto out_overflow;
5822 p = xdr_inline_decode(xdr, 4); 5821
5823 if (unlikely(!p)) 5822 if (decode_attr_length(xdr, &len, &p) < 0)
5824 goto out_overflow; 5823 goto out_overflow;
5825 bitmap[0] = ntohl(*p++); 5824
5826 if (len-- > 0) { 5825 if (decode_getfattr_attrs(xdr, bitmap, entry->fattr, entry->fh, server, 1) < 0)
5827 p = xdr_inline_decode(xdr, 4); 5826 goto out_overflow;
5828 if (unlikely(!p)) 5827 if (entry->fattr->valid & NFS_ATTR_FATTR_FILEID)
5829 goto out_overflow; 5828 entry->ino = entry->fattr->fileid;
5830 bitmap[1] = ntohl(*p++); 5829
5831 p += len; 5830 if (verify_attr_len(xdr, p, len) < 0)
5832 }
5833 }
5834 p = xdr_inline_decode(xdr, 4);
5835 if (unlikely(!p))
5836 goto out_overflow; 5831 goto out_overflow;
5837 len = XDR_QUADLEN(ntohl(*p++)); /* attribute buffer length */
5838 if (len > 0) {
5839 if (decode_getfattr_attrs(xdr, bitmap, entry->fattr, entry->fh, server, 1) < 0)
5840 goto out_overflow;
5841 if (entry->fattr->valid & NFS_ATTR_FATTR_FILEID)
5842 entry->ino = entry->fattr->fileid;
5843 }
5844 5832
5845 p = xdr_inline_peek(xdr, 8); 5833 p = xdr_inline_peek(xdr, 8);
5846 if (p != NULL) 5834 if (p != NULL)