Module Name:    src
Committed By:   riastradh
Date:           Sun Dec 19 12:08:46 UTC 2021

Modified Files:
        src/sys/external/bsd/drm2/dist/drm/i915/gem: i915_gem_mman.c

Log Message:
i915: Release vmobjlock on fault.

We need to take this later, but it's not helpful for uvm_fault to
have taken it immediately prior to calling pgo_fault -- still not
clear on why uvm_fault does that.


To generate a diff of this commit:
cvs rdiff -u -r1.16 -r1.17 \
    src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_mman.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_mman.c
diff -u src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_mman.c:1.16 src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_mman.c:1.17
--- src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_mman.c:1.16	Sun Dec 19 12:08:36 2021
+++ src/sys/external/bsd/drm2/dist/drm/i915/gem/i915_gem_mman.c	Sun Dec 19 12:08:46 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: i915_gem_mman.c,v 1.16 2021/12/19 12:08:36 riastradh Exp $	*/
+/*	$NetBSD: i915_gem_mman.c,v 1.17 2021/12/19 12:08:46 riastradh Exp $	*/
 
 /*
  * SPDX-License-Identifier: MIT
@@ -7,7 +7,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: i915_gem_mman.c,v 1.16 2021/12/19 12:08:36 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: i915_gem_mman.c,v 1.17 2021/12/19 12:08:46 riastradh Exp $");
 
 #include <linux/anon_inodes.h>
 #include <linux/mman.h>
@@ -567,6 +567,13 @@ i915_gem_fault(struct uvm_faultinfo *ufi
 	KASSERT(i915_gem_object_type_has(obj,
 		I915_GEM_OBJECT_HAS_STRUCT_PAGE));
 
+	/*
+	 * The lock isn't actually helpful for us and the caller in
+	 * uvm_fault only just acquired it anyway so no important
+	 * invariants are implied by it.
+	 */
+	rw_exit(obj->base.filp->vmobjlock);
+
 	KASSERT(ufi->entry->start <= vaddr);
 	KASSERT((ufi->entry->offset & (PAGE_SIZE - 1)) == 0);
 	uoffset = ufi->entry->offset + (vaddr - ufi->entry->start);
@@ -630,7 +637,7 @@ i915_gem_fault(struct uvm_faultinfo *ufi
 
 out:	if (pinned)
 		i915_gem_object_unpin_pages(obj);
-	uvmfault_unlockall(ufi, ufi->entry->aref.ar_amap, uobj);
+	uvmfault_unlockall(ufi, ufi->entry->aref.ar_amap, NULL);
 
 	/*
 	 * Remap EINTR to success, so that we return to userland.

Reply via email to