875b080
From patchwork Mon Nov 23 09:32:42 2015
875b080
Content-Type: text/plain; charset="utf-8"
875b080
MIME-Version: 1.0
875b080
Content-Transfer-Encoding: 7bit
875b080
Subject: [09/29] drm/udl: Use unlocked gem unreferencing
875b080
From: Daniel Vetter <daniel.vetter@ffwll.ch>
875b080
X-Patchwork-Id: 65722
875b080
Message-Id: <1448271183-20523-10-git-send-email-daniel.vetter@ffwll.ch>
875b080
To: DRI Development <dri-devel@lists.freedesktop.org>
875b080
Cc: Daniel Vetter <daniel.vetter@intel.com>,
875b080
 Daniel Vetter <daniel.vetter@ffwll.ch>,
875b080
 Intel Graphics Development <intel-gfx@lists.freedesktop.org>,
875b080
 Dave Airlie <airlied@redhat.com>
875b080
Date: Mon, 23 Nov 2015 10:32:42 +0100
875b080
875b080
For drm_gem_object_unreference callers are required to hold
875b080
dev->struct_mutex, which these paths don't. Enforcing this requirement
875b080
has become a bit more strict with
875b080
875b080
commit ef4c6270bf2867e2f8032e9614d1a8cfc6c71663
875b080
Author: Daniel Vetter <daniel.vetter@ffwll.ch>
875b080
Date:   Thu Oct 15 09:36:25 2015 +0200
875b080
875b080
    drm/gem: Check locking in drm_gem_object_unreference
875b080
875b080
Cc: Dave Airlie <airlied@redhat.com>
875b080
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
875b080
---
875b080
 drivers/gpu/drm/udl/udl_fb.c  | 2 +-
875b080
 drivers/gpu/drm/udl/udl_gem.c | 2 +-
875b080
 2 files changed, 2 insertions(+), 2 deletions(-)
875b080
875b080
diff --git a/drivers/gpu/drm/udl/udl_fb.c b/drivers/gpu/drm/udl/udl_fb.c
875b080
index 200419d4d43c..18a2acbccb7d 100644
875b080
--- a/drivers/gpu/drm/udl/udl_fb.c
875b080
+++ b/drivers/gpu/drm/udl/udl_fb.c
875b080
@@ -538,7 +538,7 @@ static int udlfb_create(struct drm_fb_helper *helper,
875b080
 out_destroy_fbi:
875b080
 	drm_fb_helper_release_fbi(helper);
875b080
 out_gfree:
875b080
-	drm_gem_object_unreference(&ufbdev->ufb.obj->base);
875b080
+	drm_gem_object_unreference_unlocked(&ufbdev->ufb.obj->base);
875b080
 out:
875b080
 	return ret;
875b080
 }
875b080
diff --git a/drivers/gpu/drm/udl/udl_gem.c b/drivers/gpu/drm/udl/udl_gem.c
875b080
index 2a0a784ab6ee..d7528e0d8442 100644
875b080
--- a/drivers/gpu/drm/udl/udl_gem.c
875b080
+++ b/drivers/gpu/drm/udl/udl_gem.c
875b080
@@ -52,7 +52,7 @@ udl_gem_create(struct drm_file *file,
875b080
 		return ret;
875b080
 	}
875b080
 
875b080
-	drm_gem_object_unreference(&obj->base);
875b080
+	drm_gem_object_unreference_unlocked(&obj->base);
875b080
 	*handle_p = handle;
875b080
 	return 0;
875b080
 }