Module Name: src Committed By: riastradh Date: Fri Jan 19 22:23:19 UTC 2024
Modified Files: src/sys/external/bsd/drm2/dist/drm/i915/gem: i915_gem_region.c Log Message: i915_gem_region: Fill sg_pgs, with size/PAGE_SIZE entries. Use sg_alloc_table_from_bus_dmamem to do this. i915_gem_mman.c vm_fault_cpu and i915_gem_object_release_mmap_offset both rely on sg_pgs to be a page array, so using something else like size >> ilog2(mem->mm.chunk_size) entries doesn't work. And they rely on the sg_pgs entries to be initialized, which we weren't doing before, and which sg_alloc_table_from_bus_dmamem does for us. Related to PR kern/57833. XXX pullup-10 To generate a diff of this commit: cvs rdiff -u -r1.5 -r1.6 \ src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_region.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/i915/gem/i915_gem_region.c diff -u src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_region.c:1.5 src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_region.c:1.6 --- src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_region.c:1.5 Fri Jan 19 22:22:27 2024 +++ src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_region.c Fri Jan 19 22:23:19 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: i915_gem_region.c,v 1.5 2024/01/19 22:22:27 riastradh Exp $ */ +/* $NetBSD: i915_gem_region.c,v 1.6 2024/01/19 22:23:19 riastradh Exp $ */ // SPDX-License-Identifier: MIT /* @@ -6,7 +6,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: i915_gem_region.c,v 1.5 2024/01/19 22:22:27 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: i915_gem_region.c,v 1.6 2024/01/19 22:23:19 riastradh Exp $"); #include "intel_memory_region.h" #include "i915_gem_region.h" @@ -45,10 +45,12 @@ i915_gem_object_get_pages_buddy(struct d if (!st) return -ENOMEM; +#ifndef __NetBSD__ if (sg_alloc_table(st, size >> ilog2(mem->mm.chunk_size), GFP_KERNEL)) { kfree(st); return -ENOMEM; } +#endif flags = I915_ALLOC_MIN_PAGE_SIZE; if (obj->flags & I915_BO_ALLOC_CONTIGUOUS) @@ -60,7 +62,6 @@ i915_gem_object_get_pages_buddy(struct d GEM_BUG_ON(list_empty(blocks)); - sg = st->sgl; #ifdef __NetBSD__ __USE(prev_end); bus_dma_tag_t dmat = obj->base.dev->dmat; @@ -68,6 +69,8 @@ i915_gem_object_get_pages_buddy(struct d int i = 0, nsegs = 0; bool loaded = false; + sg = NULL; + list_for_each_entry(block, blocks, link) { if (nsegs >= INT_MAX || nsegs >= SIZE_MAX/sizeof(segs[0])) @@ -84,7 +87,15 @@ i915_gem_object_get_pages_buddy(struct d segs[i].ds_addr = mem->region.start + offset; segs[i].ds_len = block_size; + i++; } + KASSERT(i == nsegs); + + ret = sg_alloc_table_from_bus_dmamem(st, dmat, segs, nsegs, + GFP_KERNEL); + if (ret) + goto err; + sg = st->sgl; /* XXX errno NetBSD->Linux */ ret = -bus_dmamap_create(dmat, size, nsegs, size, 0, BUS_DMA_WAITOK, @@ -107,6 +118,7 @@ i915_gem_object_get_pages_buddy(struct d sg_page_sizes = i915_sg_page_sizes(sg); #else + sg = st->sgl; st->nents = 0; sg_page_sizes = 0; prev_end = (resource_size_t)-1; @@ -154,6 +166,8 @@ i915_gem_object_get_pages_buddy(struct d err: if (loaded) bus_dmamap_unload(dmat, st->sgl->sg_dmamap); + if (sg && sg->sg_dmamap) + bus_dmamap_destroy(dmat, sg->sg_dmamap); if (segs) kmem_free(segs, nsegs * sizeof(segs[0])); __intel_memory_region_put_pages_buddy(mem, blocks);