summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>2001-08-23 08:54:22 +0000
committerache <ache@FreeBSD.org>2001-08-23 08:54:22 +0000
commit9b50a3bc0430b2517b607d70920eb81dd0f861ce (patch)
tree17f1ca80e4701e377bd2f568f97ad91938f00779
parente955b0b7351ef5c6131fda8bc95135858de68d0d (diff)
downloadFreeBSD-src-9b50a3bc0430b2517b607d70920eb81dd0f861ce.zip
FreeBSD-src-9b50a3bc0430b2517b607d70920eb81dd0f861ce.tar.gz
adv. lock:
copy EOVERFLOW handling code from main variant fix type of 'size' arg
-rw-r--r--sys/fs/smbfs/smbfs_vnops.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/sys/fs/smbfs/smbfs_vnops.c b/sys/fs/smbfs/smbfs_vnops.c
index fabc651..672e665 100644
--- a/sys/fs/smbfs/smbfs_vnops.c
+++ b/sys/fs/smbfs/smbfs_vnops.c
@@ -31,6 +31,7 @@
*
* $FreeBSD$
*/
+#include <machine/limits.h>
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/namei.h>
@@ -974,9 +975,12 @@ smbfs_advlock(ap)
/* int flags = ap->a_flags;*/
struct proc *p = curproc;
struct smb_cred scred;
- off_t start, end, size;
+ u_quad_t size;
+ off_t start, end;
int error, lkop;
+ if (fl->l_len < 0)
+ return EINVAL;
if (vp->v_type == VDIR) {
/*
* SMB protocol have no support for directory locking.
@@ -994,6 +998,9 @@ smbfs_advlock(ap)
start = fl->l_start;
break;
case SEEK_END:
+ /* size always >= 0 */
+ if (fl->l_start > 0 && size > OFF_MAX - fl->l_start)
+ return EOVERFLOW;
start = fl->l_start + size;
default:
return EINVAL;
@@ -1003,7 +1010,12 @@ smbfs_advlock(ap)
if (fl->l_len == 0)
end = -1;
else {
- end = start + fl->l_len - 1;
+ off_t oadd = fl->l_len - 1;
+
+ /* fl->l_len & start are non-negative */
+ if (oadd > OFF_MAX - start)
+ return EOVERFLOW;
+ end = start + oadd;
if (end < start)
return EINVAL;
}
OpenPOWER on IntegriCloud