From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752283AbdCNNWW (ORCPT ); Tue, 14 Mar 2017 09:22:22 -0400 Received: from mail-pg0-f65.google.com ([74.125.83.65]:34026 "EHLO mail-pg0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752255AbdCNNWS (ORCPT ); Tue, 14 Mar 2017 09:22:18 -0400 Date: Tue, 14 Mar 2017 22:21:09 +0900 From: Sergey Senozhatsky To: Daniel Vetter Cc: Jani Nikula , David Airlie , intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Sergey Senozhatsky , Sergey Senozhatsky Subject: [linux-mmotm] i915_gem_userptr_get_pages: possible circular locking dependency detected Message-ID: <20170314132109.GA388@tigerII.localdomain> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.8.0 (2017-02-23) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello, [ 530.698622] ====================================================== [ 530.698623] WARNING: possible circular locking dependency detected [ 530.698626] 4.11.0-rc2-mm1-dbg-00167-gdb8a9941614c-dirty #222 Not tainted [ 530.698627] ------------------------------------------------------ [ 530.698628] Xorg/343 is trying to acquire lock: [ 530.698630] (&mm->mmap_sem){++++++}, at: [] i915_gem_userptr_get_pages+0x60/0x29c [i915] [ 530.698702] but task is already holding lock: [ 530.698703] (&obj->mm.lock){+.+.+.}, at: [] __i915_gem_object_get_pages+0x21/0x62 [i915] [ 530.698763] which lock already depends on the new lock. [ 530.698764] the existing dependency chain (in reverse order) is: [ 530.698766] -> #1 (&obj->mm.lock){+.+.+.}: [ 530.698779] lock_acquire+0x130/0x1c4 [ 530.698822] i915_gem_fault+0x138/0x531 [i915] [ 530.698826] __do_fault+0x1e/0xb4 [ 530.698831] __handle_mm_fault+0x897/0xe37 [ 530.698834] handle_mm_fault+0x93/0xd2 [ 530.698839] __do_page_fault+0x20c/0x3db [ 530.698843] do_page_fault+0xc/0xe [ 530.698848] page_fault+0x22/0x30 [ 530.698849] -> #0 (&mm->mmap_sem){++++++}: [ 530.698858] __lock_acquire+0xf49/0x1548 [ 530.698861] lock_acquire+0x130/0x1c4 [ 530.698866] down_read+0x3e/0x62 [ 530.698910] i915_gem_userptr_get_pages+0x60/0x29c [i915] [ 530.698951] ____i915_gem_object_get_pages+0x3f/0x57 [i915] [ 530.698993] __i915_gem_object_get_pages+0x41/0x62 [i915] [ 530.699035] i915_gem_set_domain_ioctl+0x1f6/0x2b0 [i915] [ 530.699057] drm_ioctl+0x248/0x363 [drm] [ 530.699061] vfs_ioctl+0x18/0x34 [ 530.699064] do_vfs_ioctl+0x5a2/0x64d [ 530.699067] SyS_ioctl+0x43/0x61 [ 530.699070] entry_SYSCALL_64_fastpath+0x18/0xad [ 530.699072] other info that might help us debug this: [ 530.699073] Possible unsafe locking scenario: [ 530.699075] CPU0 CPU1 [ 530.699076] ---- ---- [ 530.699077] lock(&obj->mm.lock); [ 530.699081] lock(&mm->mmap_sem); [ 530.699084] lock(&obj->mm.lock); [ 530.699087] lock(&mm->mmap_sem); [ 530.699090] *** DEADLOCK *** [ 530.699092] 1 lock held by Xorg/343: [ 530.699094] #0: (&obj->mm.lock){+.+.+.}, at: [] __i915_gem_object_get_pages+0x21/0x62 [i915] [ 530.699141] stack backtrace: [ 530.699144] CPU: 6 PID: 343 Comm: Xorg Not tainted 4.11.0-rc2-mm1-dbg-00167-gdb8a9941614c-dirty #222 [ 530.699146] Call Trace: [ 530.699152] dump_stack+0x68/0x92 [ 530.699158] print_circular_bug+0x286/0x294 [ 530.699163] __lock_acquire+0xf49/0x1548 [ 530.699168] ? lock_acquire+0x130/0x1c4 [ 530.699173] lock_acquire+0x130/0x1c4 [ 530.699177] ? lock_acquire+0x130/0x1c4 [ 530.699223] ? i915_gem_userptr_get_pages+0x60/0x29c [i915] [ 530.699228] down_read+0x3e/0x62 [ 530.699273] ? i915_gem_userptr_get_pages+0x60/0x29c [i915] [ 530.699318] i915_gem_userptr_get_pages+0x60/0x29c [i915] [ 530.699361] ____i915_gem_object_get_pages+0x3f/0x57 [i915] [ 530.699403] __i915_gem_object_get_pages+0x41/0x62 [i915] [ 530.699446] i915_gem_set_domain_ioctl+0x1f6/0x2b0 [i915] [ 530.699463] drm_ioctl+0x248/0x363 [drm] [ 530.699506] ? i915_gem_obj_prepare_shmem_write+0x1ba/0x1ba [i915] [ 530.699511] vfs_ioctl+0x18/0x34 [ 530.699514] do_vfs_ioctl+0x5a2/0x64d [ 530.699517] ? __fget+0x182/0x194 [ 530.699521] SyS_ioctl+0x43/0x61 [ 530.699524] entry_SYSCALL_64_fastpath+0x18/0xad [ 530.699527] RIP: 0033:0x7fa1bb3150d7 [ 530.699529] RSP: 002b:00007ffe1f1fbc48 EFLAGS: 00000246 ORIG_RAX: 0000000000000010 [ 530.699534] RAX: ffffffffffffffda RBX: 00000000e0000000 RCX: 00007fa1bb3150d7 [ 530.699536] RDX: 00007ffe1f1fbc70 RSI: 00000000400c645f RDI: 000000000000000b [ 530.699538] RBP: 00000000a1fcd537 R08: 00000000000000ff R09: 0000000001c564d8 [ 530.699540] R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000015 [ 530.699542] R13: 0000000001c474b0 R14: 00000000000001f2 R15: 0000000001c43488 -ss From mboxrd@z Thu Jan 1 00:00:00 1970 From: Sergey Senozhatsky Subject: [linux-mmotm] i915_gem_userptr_get_pages: possible circular locking dependency detected Date: Tue, 14 Mar 2017 22:21:09 +0900 Message-ID: <20170314132109.GA388@tigerII.localdomain> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Content-Disposition: inline List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: Daniel Vetter Cc: Sergey Senozhatsky , intel-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Sergey Senozhatsky List-Id: dri-devel@lists.freedesktop.org SGVsbG8sCgpbICA1MzAuNjk4NjIyXSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT0KWyAgNTMwLjY5ODYyM10gV0FSTklORzogcG9zc2libGUgY2ly Y3VsYXIgbG9ja2luZyBkZXBlbmRlbmN5IGRldGVjdGVkClsgIDUzMC42OTg2MjZdIDQuMTEuMC1y YzItbW0xLWRiZy0wMDE2Ny1nZGI4YTk5NDE2MTRjLWRpcnR5ICMyMjIgTm90IHRhaW50ZWQKWyAg NTMwLjY5ODYyN10gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tClsgIDUzMC42OTg2MjhdIFhvcmcvMzQzIGlzIHRyeWluZyB0byBhY3F1aXJlIGxv Y2s6ClsgIDUzMC42OTg2MzBdICAoJm1tLT5tbWFwX3NlbSl7KysrKysrfSwgYXQ6IFs8ZmZmZmZm ZmZhMDU3ZTA4NT5dIGk5MTVfZ2VtX3VzZXJwdHJfZ2V0X3BhZ2VzKzB4NjAvMHgyOWMgW2k5MTVd ClsgIDUzMC42OTg3MDJdIAogICAgICAgICAgICAgICBidXQgdGFzayBpcyBhbHJlYWR5IGhvbGRp bmcgbG9jazoKWyAgNTMwLjY5ODcwM10gICgmb2JqLT5tbS5sb2NrKXsrLisuKy59LCBhdDogWzxm ZmZmZmZmZmEwNTcyZDc4Pl0gX19pOTE1X2dlbV9vYmplY3RfZ2V0X3BhZ2VzKzB4MjEvMHg2MiBb aTkxNV0KWyAgNTMwLjY5ODc2M10gCiAgICAgICAgICAgICAgIHdoaWNoIGxvY2sgYWxyZWFkeSBk ZXBlbmRzIG9uIHRoZSBuZXcgbG9jay4KClsgIDUzMC42OTg3NjRdIAogICAgICAgICAgICAgICB0 aGUgZXhpc3RpbmcgZGVwZW5kZW5jeSBjaGFpbiAoaW4gcmV2ZXJzZSBvcmRlcikgaXM6ClsgIDUz MC42OTg3NjZdIAogICAgICAgICAgICAgICAtPiAjMSAoJm9iai0+bW0ubG9jayl7Ky4rLisufToK WyAgNTMwLjY5ODc3OV0gICAgICAgIGxvY2tfYWNxdWlyZSsweDEzMC8weDFjNApbICA1MzAuNjk4 ODIyXSAgICAgICAgaTkxNV9nZW1fZmF1bHQrMHgxMzgvMHg1MzEgW2k5MTVdClsgIDUzMC42OTg4 MjZdICAgICAgICBfX2RvX2ZhdWx0KzB4MWUvMHhiNApbICA1MzAuNjk4ODMxXSAgICAgICAgX19o YW5kbGVfbW1fZmF1bHQrMHg4OTcvMHhlMzcKWyAgNTMwLjY5ODgzNF0gICAgICAgIGhhbmRsZV9t bV9mYXVsdCsweDkzLzB4ZDIKWyAgNTMwLjY5ODgzOV0gICAgICAgIF9fZG9fcGFnZV9mYXVsdCsw eDIwYy8weDNkYgpbICA1MzAuNjk4ODQzXSAgICAgICAgZG9fcGFnZV9mYXVsdCsweGMvMHhlClsg IDUzMC42OTg4NDhdICAgICAgICBwYWdlX2ZhdWx0KzB4MjIvMHgzMApbICA1MzAuNjk4ODQ5XSAK ICAgICAgICAgICAgICAgLT4gIzAgKCZtbS0+bW1hcF9zZW0peysrKysrK306ClsgIDUzMC42OTg4 NThdICAgICAgICBfX2xvY2tfYWNxdWlyZSsweGY0OS8weDE1NDgKWyAgNTMwLjY5ODg2MV0gICAg ICAgIGxvY2tfYWNxdWlyZSsweDEzMC8weDFjNApbICA1MzAuNjk4ODY2XSAgICAgICAgZG93bl9y ZWFkKzB4M2UvMHg2MgpbICA1MzAuNjk4OTEwXSAgICAgICAgaTkxNV9nZW1fdXNlcnB0cl9nZXRf cGFnZXMrMHg2MC8weDI5YyBbaTkxNV0KWyAgNTMwLjY5ODk1MV0gICAgICAgIF9fX19pOTE1X2dl bV9vYmplY3RfZ2V0X3BhZ2VzKzB4M2YvMHg1NyBbaTkxNV0KWyAgNTMwLjY5ODk5M10gICAgICAg IF9faTkxNV9nZW1fb2JqZWN0X2dldF9wYWdlcysweDQxLzB4NjIgW2k5MTVdClsgIDUzMC42OTkw MzVdICAgICAgICBpOTE1X2dlbV9zZXRfZG9tYWluX2lvY3RsKzB4MWY2LzB4MmIwIFtpOTE1XQpb ICA1MzAuNjk5MDU3XSAgICAgICAgZHJtX2lvY3RsKzB4MjQ4LzB4MzYzIFtkcm1dClsgIDUzMC42 OTkwNjFdICAgICAgICB2ZnNfaW9jdGwrMHgxOC8weDM0ClsgIDUzMC42OTkwNjRdICAgICAgICBk b192ZnNfaW9jdGwrMHg1YTIvMHg2NGQKWyAgNTMwLjY5OTA2N10gICAgICAgIFN5U19pb2N0bCsw eDQzLzB4NjEKWyAgNTMwLjY5OTA3MF0gICAgICAgIGVudHJ5X1NZU0NBTExfNjRfZmFzdHBhdGgr MHgxOC8weGFkClsgIDUzMC42OTkwNzJdIAogICAgICAgICAgICAgICBvdGhlciBpbmZvIHRoYXQg bWlnaHQgaGVscCB1cyBkZWJ1ZyB0aGlzOgoKWyAgNTMwLjY5OTA3M10gIFBvc3NpYmxlIHVuc2Fm ZSBsb2NraW5nIHNjZW5hcmlvOgoKWyAgNTMwLjY5OTA3NV0gICAgICAgIENQVTAgICAgICAgICAg ICAgICAgICAgIENQVTEKWyAgNTMwLjY5OTA3Nl0gICAgICAgIC0tLS0gICAgICAgICAgICAgICAg ICAgIC0tLS0KWyAgNTMwLjY5OTA3N10gICBsb2NrKCZvYmotPm1tLmxvY2spOwpbICA1MzAuNjk5 MDgxXSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9jaygmbW0tPm1tYXBfc2VtKTsK WyAgNTMwLjY5OTA4NF0gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvY2soJm9iai0+ bW0ubG9jayk7ClsgIDUzMC42OTkwODddICAgbG9jaygmbW0tPm1tYXBfc2VtKTsKWyAgNTMwLjY5 OTA5MF0gCiAgICAgICAgICAgICAgICAqKiogREVBRExPQ0sgKioqCgpbICA1MzAuNjk5MDkyXSAx IGxvY2sgaGVsZCBieSBYb3JnLzM0MzoKWyAgNTMwLjY5OTA5NF0gICMwOiAgKCZvYmotPm1tLmxv Y2speysuKy4rLn0sIGF0OiBbPGZmZmZmZmZmYTA1NzJkNzg+XSBfX2k5MTVfZ2VtX29iamVjdF9n ZXRfcGFnZXMrMHgyMS8weDYyIFtpOTE1XQpbICA1MzAuNjk5MTQxXSAKICAgICAgICAgICAgICAg c3RhY2sgYmFja3RyYWNlOgpbICA1MzAuNjk5MTQ0XSBDUFU6IDYgUElEOiAzNDMgQ29tbTogWG9y ZyBOb3QgdGFpbnRlZCA0LjExLjAtcmMyLW1tMS1kYmctMDAxNjctZ2RiOGE5OTQxNjE0Yy1kaXJ0 eSAjMjIyClsgIDUzMC42OTkxNDZdIENhbGwgVHJhY2U6ClsgIDUzMC42OTkxNTJdICBkdW1wX3N0 YWNrKzB4NjgvMHg5MgpbICA1MzAuNjk5MTU4XSAgcHJpbnRfY2lyY3VsYXJfYnVnKzB4Mjg2LzB4 Mjk0ClsgIDUzMC42OTkxNjNdICBfX2xvY2tfYWNxdWlyZSsweGY0OS8weDE1NDgKWyAgNTMwLjY5 OTE2OF0gID8gbG9ja19hY3F1aXJlKzB4MTMwLzB4MWM0ClsgIDUzMC42OTkxNzNdICBsb2NrX2Fj cXVpcmUrMHgxMzAvMHgxYzQKWyAgNTMwLjY5OTE3N10gID8gbG9ja19hY3F1aXJlKzB4MTMwLzB4 MWM0ClsgIDUzMC42OTkyMjNdICA/IGk5MTVfZ2VtX3VzZXJwdHJfZ2V0X3BhZ2VzKzB4NjAvMHgy OWMgW2k5MTVdClsgIDUzMC42OTkyMjhdICBkb3duX3JlYWQrMHgzZS8weDYyClsgIDUzMC42OTky NzNdICA/IGk5MTVfZ2VtX3VzZXJwdHJfZ2V0X3BhZ2VzKzB4NjAvMHgyOWMgW2k5MTVdClsgIDUz MC42OTkzMThdICBpOTE1X2dlbV91c2VycHRyX2dldF9wYWdlcysweDYwLzB4MjljIFtpOTE1XQpb ICA1MzAuNjk5MzYxXSAgX19fX2k5MTVfZ2VtX29iamVjdF9nZXRfcGFnZXMrMHgzZi8weDU3IFtp OTE1XQpbICA1MzAuNjk5NDAzXSAgX19pOTE1X2dlbV9vYmplY3RfZ2V0X3BhZ2VzKzB4NDEvMHg2 MiBbaTkxNV0KWyAgNTMwLjY5OTQ0Nl0gIGk5MTVfZ2VtX3NldF9kb21haW5faW9jdGwrMHgxZjYv MHgyYjAgW2k5MTVdClsgIDUzMC42OTk0NjNdICBkcm1faW9jdGwrMHgyNDgvMHgzNjMgW2RybV0K WyAgNTMwLjY5OTUwNl0gID8gaTkxNV9nZW1fb2JqX3ByZXBhcmVfc2htZW1fd3JpdGUrMHgxYmEv MHgxYmEgW2k5MTVdClsgIDUzMC42OTk1MTFdICB2ZnNfaW9jdGwrMHgxOC8weDM0ClsgIDUzMC42 OTk1MTRdICBkb192ZnNfaW9jdGwrMHg1YTIvMHg2NGQKWyAgNTMwLjY5OTUxN10gID8gX19mZ2V0 KzB4MTgyLzB4MTk0ClsgIDUzMC42OTk1MjFdICBTeVNfaW9jdGwrMHg0My8weDYxClsgIDUzMC42 OTk1MjRdICBlbnRyeV9TWVNDQUxMXzY0X2Zhc3RwYXRoKzB4MTgvMHhhZApbICA1MzAuNjk5NTI3 XSBSSVA6IDAwMzM6MHg3ZmExYmIzMTUwZDcKWyAgNTMwLjY5OTUyOV0gUlNQOiAwMDJiOjAwMDA3 ZmZlMWYxZmJjNDggRUZMQUdTOiAwMDAwMDI0NiBPUklHX1JBWDogMDAwMDAwMDAwMDAwMDAxMApb ICA1MzAuNjk5NTM0XSBSQVg6IGZmZmZmZmZmZmZmZmZmZGEgUkJYOiAwMDAwMDAwMGUwMDAwMDAw IFJDWDogMDAwMDdmYTFiYjMxNTBkNwpbICA1MzAuNjk5NTM2XSBSRFg6IDAwMDA3ZmZlMWYxZmJj NzAgUlNJOiAwMDAwMDAwMDQwMGM2NDVmIFJESTogMDAwMDAwMDAwMDAwMDAwYgpbICA1MzAuNjk5 NTM4XSBSQlA6IDAwMDAwMDAwYTFmY2Q1MzcgUjA4OiAwMDAwMDAwMDAwMDAwMGZmIFIwOTogMDAw MDAwMDAwMWM1NjRkOApbICA1MzAuNjk5NTQwXSBSMTA6IDAwMDAwMDAwMDAwMDAwMDAgUjExOiAw MDAwMDAwMDAwMDAwMjQ2IFIxMjogMDAwMDAwMDAwMDAwMDAxNQpbICA1MzAuNjk5NTQyXSBSMTM6 IDAwMDAwMDAwMDFjNDc0YjAgUjE0OiAwMDAwMDAwMDAwMDAwMWYyIFIxNTogMDAwMDAwMDAwMWM0 MzQ4OAoKCgktc3MKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X18KZHJpLWRldmVsIG1haWxpbmcgbGlzdApkcmktZGV2ZWxAbGlzdHMuZnJlZWRlc2t0b3Aub3Jn Cmh0dHBzOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vZHJpLWRldmVs Cg==