Module Name:    src
Committed By:   riastradh
Date:           Thu Sep  1 11:48:59 UTC 2022

Modified Files:
        src/sys/external/bsd/drm2/dist/drm: drm_mm.c

Log Message:
drm_mm: Give up on trying to phrase find_hole with public rbtree API.

Firefox works with WebGL on Mesa iris_dri.so now.


To generate a diff of this commit:
cvs rdiff -u -r1.19 -r1.20 src/sys/external/bsd/drm2/dist/drm/drm_mm.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/external/bsd/drm2/dist/drm/drm_mm.c
diff -u src/sys/external/bsd/drm2/dist/drm/drm_mm.c:1.19 src/sys/external/bsd/drm2/dist/drm/drm_mm.c:1.20
--- src/sys/external/bsd/drm2/dist/drm/drm_mm.c:1.19	Thu Sep  1 01:54:28 2022
+++ src/sys/external/bsd/drm2/dist/drm/drm_mm.c	Thu Sep  1 11:48:59 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: drm_mm.c,v 1.19 2022/09/01 01:54:28 riastradh Exp $	*/
+/*	$NetBSD: drm_mm.c,v 1.20 2022/09/01 11:48:59 riastradh Exp $	*/
 
 /**************************************************************************
  *
@@ -45,7 +45,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: drm_mm.c,v 1.19 2022/09/01 01:54:28 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: drm_mm.c,v 1.20 2022/09/01 11:48:59 riastradh Exp $");
 
 #include <linux/export.h>
 #include <linux/interval_tree_generic.h>
@@ -437,16 +437,10 @@ static struct drm_mm_node *best_hole(str
 static struct drm_mm_node *find_hole(struct drm_mm *mm, u64 addr)
 {
 #ifdef __NetBSD__
-	struct drm_mm_node *node;
-
-	node = rb_tree_find_node(&mm->holes_addr.rbr_tree, &addr);
-	KASSERT(node == NULL || __drm_mm_hole_node_start(node) <= addr);
-	KASSERT(node == NULL || addr <
-	    __drm_mm_hole_node_start(node) + node->hole_size);
-
-	return node;
+	struct rb_node *rb = mm->holes_addr.rbr_tree.rbt_root;
 #else
 	struct rb_node *rb = mm->holes_addr.rb_node;
+#endif
 	struct drm_mm_node *node = NULL;
 
 	while (rb) {
@@ -464,7 +458,6 @@ static struct drm_mm_node *find_hole(str
 	}
 
 	return node;
-#endif
 }
 
 static struct drm_mm_node *
@@ -478,18 +471,10 @@ first_hole(struct drm_mm *mm,
 		return best_hole(mm, size);
 
 	case DRM_MM_INSERT_LOW:
-#ifdef __NetBSD__
-		return rb_tree_find_node_geq(&mm->holes_addr.rbr_tree, &start);
-#else
 		return find_hole(mm, start);
-#endif
 
 	case DRM_MM_INSERT_HIGH:
-#ifdef __NetBSD__
-		return rb_tree_find_node_leq(&mm->holes_addr.rbr_tree, &end);
-#else
 		return find_hole(mm, end);
-#endif
 
 	case DRM_MM_INSERT_EVICT:
 		return list_first_entry_or_null(&mm->hole_stack,

Reply via email to