Module Name:    src
Committed By:   alnsn
Date:           Mon Jul  7 19:56:03 UTC 2014

Modified Files:
        src/sys/net: bpf_filter.c

Log Message:
Arithmetic overflow when calculating variable offsets (BPF_LD+BPF_IND
instructions) should be handled uniformly for contiguous buffers and mbufs.


To generate a diff of this commit:
cvs rdiff -u -r1.66 -r1.67 src/sys/net/bpf_filter.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/net/bpf_filter.c
diff -u src/sys/net/bpf_filter.c:1.66 src/sys/net/bpf_filter.c:1.67
--- src/sys/net/bpf_filter.c:1.66	Sat Jul  5 22:06:11 2014
+++ src/sys/net/bpf_filter.c	Mon Jul  7 19:56:03 2014
@@ -1,4 +1,4 @@
-/*	$NetBSD: bpf_filter.c,v 1.66 2014/07/05 22:06:11 alnsn Exp $	*/
+/*	$NetBSD: bpf_filter.c,v 1.67 2014/07/07 19:56:03 alnsn Exp $	*/
 
 /*-
  * Copyright (c) 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997
@@ -37,7 +37,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bpf_filter.c,v 1.66 2014/07/05 22:06:11 alnsn Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bpf_filter.c,v 1.67 2014/07/07 19:56:03 alnsn Exp $");
 
 #if 0
 #if !(defined(lint) || defined(KERNEL))
@@ -327,13 +327,12 @@ bpf_filter(const struct bpf_insn *pc, co
 
 		case BPF_LD|BPF_W|BPF_IND:
 			k = X + pc->k;
-			if (pc->k > args->buflen ||
-			    X > args->buflen - pc->k ||
+			if (k < X || k >= args->buflen ||
 			    sizeof(int32_t) > args->buflen - k) {
 #ifdef _KERNEL
 				int merr;
 
-				if (args->buflen != 0)
+				if (k < X || args->buflen != 0)
 					return 0;
 				A = xword(args->pkt, k, &merr);
 				if (merr != 0)
@@ -348,13 +347,12 @@ bpf_filter(const struct bpf_insn *pc, co
 
 		case BPF_LD|BPF_H|BPF_IND:
 			k = X + pc->k;
-			if (pc->k > args->buflen ||
-			    X > args->buflen - pc->k ||
+			if (k < X || k >= args->buflen ||
 			    sizeof(int16_t) > args->buflen - k) {
 #ifdef _KERNEL
 				int merr;
 
-				if (args->buflen != 0)
+				if (k < X || args->buflen != 0)
 					return 0;
 				A = xhalf(args->pkt, k, &merr);
 				if (merr != 0)
@@ -369,12 +367,11 @@ bpf_filter(const struct bpf_insn *pc, co
 
 		case BPF_LD|BPF_B|BPF_IND:
 			k = X + pc->k;
-			if (pc->k >= args->buflen ||
-			    X >= args->buflen - pc->k) {
+			if (k < X || k >= args->buflen) {
 #ifdef _KERNEL
 				int merr;
 
-				if (args->buflen != 0)
+				if (k < X || args->buflen != 0)
 					return 0;
 				A = xbyte(args->pkt, k, &merr);
 				if (merr != 0)

Reply via email to