Module Name: src Committed By: riastradh Date: Mon Feb 14 13:22:21 UTC 2022
Modified Files: src/sys/external/bsd/drm2/dist/drm: drm_mm.c Log Message: drm/mm: Allow hole address range queries. To generate a diff of this commit: cvs rdiff -u -r1.16 -r1.17 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.16 src/sys/external/bsd/drm2/dist/drm/drm_mm.c:1.17 --- src/sys/external/bsd/drm2/dist/drm/drm_mm.c:1.16 Mon Feb 14 13:22:11 2022 +++ src/sys/external/bsd/drm2/dist/drm/drm_mm.c Mon Feb 14 13:22:21 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: drm_mm.c,v 1.16 2022/02/14 13:22:11 riastradh Exp $ */ +/* $NetBSD: drm_mm.c,v 1.17 2022/02/14 13:22:21 riastradh Exp $ */ /************************************************************************** * @@ -45,7 +45,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: drm_mm.c,v 1.16 2022/02/14 13:22:11 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: drm_mm.c,v 1.17 2022/02/14 13:22:21 riastradh Exp $"); #include <linux/export.h> #include <linux/interval_tree_generic.h> @@ -240,6 +240,13 @@ compare_hole_addrs(void *cookie, const v const u64 aa = __drm_mm_hole_node_start(a); const u64 ba = __drm_mm_hole_node_start(b); + KASSERTMSG((aa == ba || + aa + a->hole_size <= ba || + aa >= ba + b->hole_size), + "overlapping holes: [0x%"PRIx64", 0x%"PRIx64")," + " [0x%"PRIx64", 0x%"PRIx64")", + aa, aa + a->hole_size, + ba, ba + b->hole_size); if (aa < ba) return -1; if (aa > ba) @@ -256,7 +263,7 @@ compare_hole_addr_key(void *cookie, cons if (a < *k) return -1; - if (a > *k) + if (a + n->hole_size >= *k) /* allows range lookups */ return +1; return 0; } @@ -432,7 +439,7 @@ static struct drm_mm_node *find_hole(str #ifdef __NetBSD__ struct drm_mm_node *node; - node = rb_tree_find_node_leq(&mm->holes_addr.rbr_tree, &addr); + 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);