Module Name: src Committed By: riastradh Date: Wed Aug 20 13:48:08 UTC 2014
Modified Files: src/sys/external/bsd/drm2/dist/drm/i915: i915_gem.c src/sys/external/bsd/drm2/ttm: ttm_bo_vm.c Log Message: Drop take the {ttm,gem} vmobjlock in the fault handler. - We don't need this lock. - uvm does nothing between taking it and calling the fault handler. - Now that the uvm_aobj shares vmobjlock with the {ttm,gem} uvm object, we must not hold the lock when we call uvm_obj_wirepages on the uvm_aobj. XXX pullup to netbsd-7 To generate a diff of this commit: cvs rdiff -u -r1.14 -r1.15 src/sys/external/bsd/drm2/dist/drm/i915/i915_gem.c cvs rdiff -u -r1.3 -r1.4 src/sys/external/bsd/drm2/ttm/ttm_bo_vm.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/i915_gem.c diff -u src/sys/external/bsd/drm2/dist/drm/i915/i915_gem.c:1.14 src/sys/external/bsd/drm2/dist/drm/i915/i915_gem.c:1.15 --- src/sys/external/bsd/drm2/dist/drm/i915/i915_gem.c:1.14 Wed Jul 16 21:48:53 2014 +++ src/sys/external/bsd/drm2/dist/drm/i915/i915_gem.c Wed Aug 20 13:48:08 2014 @@ -1842,6 +1842,9 @@ i915_gem_fault(struct uvm_faultinfo *ufi intel_runtime_pm_get(dev_priv); + /* Thanks, uvm, but we don't need this lock. */ + mutex_exit(uobj->vmobjlock); + ret = i915_mutex_lock_interruptible(dev); if (ret) goto out; @@ -1880,6 +1883,7 @@ unpin: unlock: mutex_unlock(&dev->struct_mutex); out: + mutex_enter(uobj->vmobjlock); uvmfault_unlockall(ufi, ufi->entry->aref.ar_amap, uobj); if (ret == -ERESTART) uvm_wait("i915flt"); Index: src/sys/external/bsd/drm2/ttm/ttm_bo_vm.c diff -u src/sys/external/bsd/drm2/ttm/ttm_bo_vm.c:1.3 src/sys/external/bsd/drm2/ttm/ttm_bo_vm.c:1.4 --- src/sys/external/bsd/drm2/ttm/ttm_bo_vm.c:1.3 Mon Aug 18 01:17:34 2014 +++ src/sys/external/bsd/drm2/ttm/ttm_bo_vm.c Wed Aug 20 13:48:08 2014 @@ -1,4 +1,4 @@ -/* $NetBSD: ttm_bo_vm.c,v 1.3 2014/08/18 01:17:34 riastradh Exp $ */ +/* $NetBSD: ttm_bo_vm.c,v 1.4 2014/08/20 13:48:08 riastradh Exp $ */ /*- * Copyright (c) 2014 The NetBSD Foundation, Inc. @@ -30,7 +30,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: ttm_bo_vm.c,v 1.3 2014/08/18 01:17:34 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: ttm_bo_vm.c,v 1.4 2014/08/20 13:48:08 riastradh Exp $"); #include <sys/types.h> @@ -92,6 +92,9 @@ ttm_bo_uvm_fault(struct uvm_faultinfo *u unsigned mmapflags; int ret; + /* Thanks, uvm, but we don't need this lock. */ + mutex_exit(uobj->vmobjlock); + /* Copy-on-write mappings make no sense for the graphics aperture. */ if (UVM_ET_ISCOPYONWRITE(ufi->entry)) { ret = -EIO; @@ -199,7 +202,8 @@ ttm_bo_uvm_fault(struct uvm_faultinfo *u out3: pmap_update(ufi->orig_map->pmap); out2: ttm_mem_io_unlock(man); out1: ttm_bo_unreserve(bo); -out0: uvmfault_unlockall(ufi, ufi->entry->aref.ar_amap, uobj); +out0: mutex_enter(uobj->vmobjlock); + uvmfault_unlockall(ufi, ufi->entry->aref.ar_amap, uobj); /* XXX errno Linux->NetBSD */ return -ret; }