Page MenuHomeFreeBSD

D31511.diff
No OneTemporary

D31511.diff

diff --git a/sys/fs/nfsserver/nfs_nfsdserv.c b/sys/fs/nfsserver/nfs_nfsdserv.c
--- a/sys/fs/nfsserver/nfs_nfsdserv.c
+++ b/sys/fs/nfsserver/nfs_nfsdserv.c
@@ -5347,12 +5347,18 @@
off = fxdr_hyper(tl); tl += 2;
lop->lo_first = off;
len = fxdr_hyper(tl);
- lop->lo_end = off + len;
+ lop->lo_end = lop->lo_first + len;
/*
- * Paranoia, just in case it wraps around, which shouldn't
- * ever happen anyhow.
+ * Sanity check the offset and length.
+ * off and len are off_t (signed int64_t) whereas
+ * lo_first and lo_end are uint64_t and, as such,
+ * if off >= 0 && len > 0, lo_end cannot overflow
+ * unless off_t is changed to something other than
+ * int64_t. Check lo_end < lo_first in case that
+ * is someday the case.
*/
- if (nd->nd_repstat == 0 && (lop->lo_end < lop->lo_first || len <= 0))
+ if (nd->nd_repstat == 0 && (len <= 0 || off < 0 || lop->lo_end >
+ OFF_MAX || lop->lo_end < lop->lo_first))
nd->nd_repstat = NFSERR_INVAL;
if (nd->nd_repstat == 0 && vnode_vtype(vp) != VREG)

File Metadata

Mime Type
text/plain
Expires
Thu, Jan 16, 9:15 AM (20 h, 26 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
15823189
Default Alt Text
D31511.diff (1 KB)

Event Timeline