Module Name:    src
Committed By:   yamt
Date:           Tue May 26 22:38:18 UTC 2009

Modified Files:
        src/common/lib/libc/gen: rpst.c

Log Message:
rpst_iterate_first: fix a bug which causes unnecessary scan.


To generate a diff of this commit:
cvs rdiff -u -r1.6 -r1.7 src/common/lib/libc/gen/rpst.c

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

Modified files:

Index: src/common/lib/libc/gen/rpst.c
diff -u src/common/lib/libc/gen/rpst.c:1.6 src/common/lib/libc/gen/rpst.c:1.7
--- src/common/lib/libc/gen/rpst.c:1.6	Tue May 26 22:37:50 2009
+++ src/common/lib/libc/gen/rpst.c	Tue May 26 22:38:18 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: rpst.c,v 1.6 2009/05/26 22:37:50 yamt Exp $	*/
+/*	$NetBSD: rpst.c,v 1.7 2009/05/26 22:38:18 yamt Exp $	*/
 
 /*-
  * Copyright (c)2009 YAMAMOTO Takashi,
@@ -43,10 +43,10 @@
 #include <sys/cdefs.h>
 
 #if defined(_KERNEL)
-__KERNEL_RCSID(0, "$NetBSD: rpst.c,v 1.6 2009/05/26 22:37:50 yamt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rpst.c,v 1.7 2009/05/26 22:38:18 yamt Exp $");
 #include <sys/param.h>
 #else /* defined(_KERNEL) */
-__RCSID("$NetBSD: rpst.c,v 1.6 2009/05/26 22:37:50 yamt Exp $");
+__RCSID("$NetBSD: rpst.c,v 1.7 2009/05/26 22:38:18 yamt Exp $");
 #include <assert.h>
 #include <stdbool.h>
 #include <string.h>
@@ -379,6 +379,9 @@
 	if (n == NULL || n->n_y > max_y) {
 		return NULL;
 	}
+	if (rpst_height2max(t->t_height) < min_x) {
+		return NULL;
+	}
 	it->it_tree = t;
 	it->it_cur = n;
 	it->it_idx = (min_x & rpst_startmask(t)) != 0;

Reply via email to