[Intel-gfx] [PATCH] drm/i915: Lock dpt_obj around set_cache_level, v2.
Thomas Hellström
thomas.hellstrom at linux.intel.com
Thu Jan 27 12:05:40 UTC 2022
On Thu, 2022-01-27 at 13:02 +0100, Maarten Lankhorst wrote:
> Op 26-01-2022 om 13:55 schreef Gwan-gyeong Mun:
> >
> >
> > On 1/26/22 9:37 AM, Maarten Lankhorst wrote:
> > > set_cache_level may unbind the object, which will result in the
> > > below
> > > lockdep splat:
> > > <6> [184.578145] [IGT] kms_addfb_basic: starting subtest addfb25-
> > > framebuffer-vs-set-tiling
> > > <4> [184.578220] ------------[ cut here ]------------
> > > <4> [184.578221] WARN_ON(debug_locks && !(lock_is_held(&(&((obj)-
> > > >base.resv)->lock.base)->dep_map) != 0))
> > > <4> [184.578237] WARNING: CPU: 6 PID: 5544 at
> > > drivers/gpu/drm/i915/i915_gem.c:123
> > > i915_gem_object_unbind+0x4a9/0x510 [i915]
> > > <4> [184.578323] Modules linked in: vgem drm_shmem_helper
> > > snd_hda_codec_hdmi i915 mei_hdcp x86_pkg_temp_thermal
> > > snd_hda_intel coretemp crct10dif_pclmul snd_intel_dspcfg
> > > crc32_pclmul ttm snd_hda_codec ghash_clmulni_intel snd_hwdep
> > > drm_kms_helper snd_hda_core e1000e mei_me syscopyarea ptp snd_pcm
> > > sysfillrect mei pps_core sysimgblt fb_sys_fops prime_numbers
> > > intel_lpss_pci smsc75xx usbnet mii
> > > <4> [184.578349] CPU: 6 PID: 5544 Comm: kms_addfb_basic Not
> > > tainted 5.16.0-CI-Patchwork_22006+ #1
> > > <4> [184.578351] Hardware name: Intel Corporation Alder Lake
> > > Client Platform/AlderLake-P DDR4 RVP, BIOS
> > > ADLPFWI1.R00.2422.A00.2110131104 10/13/2021
> > > <4> [184.578352] RIP: 0010:i915_gem_object_unbind+0x4a9/0x510
> > > [i915]
> > > <4> [184.578424] Code: 00 be ff ff ff ff 48 8d 78 68 e8 a2 6e 2b
> > > e1 85 c0 0f 85 b1 fb ff ff 48 c7 c6 48 37 9e a0 48 c7 c7 d9 fc a1
> > > a0 e8 a3 54 26 e1 <0f> 0b e9 97 fb ff ff 31 ed 48 8b 5c 24 58 65
> > > 48 33 1c 25 28 00 00
> > > <4> [184.578426] RSP: 0018:ffffc900013b3b68 EFLAGS: 00010286
> > > <4> [184.578428] RAX: 0000000000000000 RBX: ffffc900013b3bb0 RCX:
> > > 0000000000000001
> > > <4> [184.578429] RDX: 0000000080000001 RSI: ffffffff8230b42d RDI:
> > > 00000000ffffffff
> > > <4> [184.578430] RBP: ffff888120e10000 R08: 0000000000000000 R09:
> > > c0000000ffff7fff
> > > <4> [184.578431] R10: 0000000000000001 R11: ffffc900013b3980 R12:
> > > ffff8881176ea740
> > > <4> [184.578432] R13: ffff888120e10000 R14: 0000000000000000 R15:
> > > 0000000000000001
> > > <4> [184.578433] FS: 00007f65074f5e40(0000)
> > > GS:ffff88888f300000(0000) knlGS:0000000000000000
> > > <4> [184.578435] CS: 0010 DS: 0000 ES: 0000 CR0:
> > > 0000000080050033
> > > <4> [184.578436] CR2: 00007fff4420ede8 CR3: 000000010c2f2005 CR4:
> > > 0000000000770ee0
> > > <4> [184.578437] PKRU: 55555554
> > > <4> [184.578438] Call Trace:
> > > <4> [184.578439] <TASK>
> > > <4> [184.578440] ? dma_resv_iter_first_unlocked+0x78/0xf0
> > > <4> [184.578447] intel_dpt_create+0x88/0x220 [i915]
> > > <4> [184.578530] intel_framebuffer_init+0x5b8/0x620 [i915]
> > > <4> [184.578612] intel_framebuffer_create+0x3d/0x60 [i915]
> > > <4> [184.578691] intel_user_framebuffer_create+0x18f/0x2c0
> > > [i915]
> > > <4> [184.578775] drm_internal_framebuffer_create+0x36d/0x4c0
> > > <4> [184.578779] drm_mode_addfb2+0x2f/0xd0
> > > <4> [184.578781] ? drm_mode_addfb_ioctl+0x10/0x10
> > > <4> [184.578784] drm_ioctl_kernel+0xac/0x140
> > > <4> [184.578787] drm_ioctl+0x201/0x3d0
> > > <4> [184.578789] ? drm_mode_addfb_ioctl+0x10/0x10
> > > <4> [184.578796] __x64_sys_ioctl+0x6a/0xa0
> > > <4> [184.578800] do_syscall_64+0x37/0xb0
> > > <4> [184.578803] entry_SYSCALL_64_after_hwframe+0x44/0xae
> > > <4> [184.578805] RIP: 0033:0x7f6506736317
> > > <4> [184.578807] Code: b3 66 90 48 8b 05 71 4b 2d 00 64 c7 00 26
> > > 00 00 00 48 c7 c0 ff ff ff ff c3 66 2e 0f 1f 84 00 00 00 00 00 b8
> > > 10 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 41 4b 2d
> > > 00 f7 d8 64 89 01 48
> > > <4> [184.578808] RSP: 002b:00007fff44211a98 EFLAGS: 00000246
> > > ORIG_RAX: 0000000000000010
> > > <4> [184.578810] RAX: ffffffffffffffda RBX: 0000000000000006 RCX:
> > > 00007f6506736317
> > > <4> [184.578811] RDX: 00007fff44211b30 RSI: 00000000c06864b8 RDI:
> > > 0000000000000006
> > > <4> [184.578812] RBP: 00007fff44211b30 R08: 00007fff44311170 R09:
> > > 0000000000000000
> > > <4> [184.578813] R10: 0000000000000008 R11: 0000000000000246 R12:
> > > 00000000c06864b8
> > > <4> [184.578813] R13: 0000000000000006 R14: 0000000000000000 R15:
> > > 0000000000000000
> > > <4> [184.578819] </TASK>
> > > <4> [184.578820] irq event stamp: 47931
> > > <4> [184.578821] hardirqs last enabled at (47937):
> > > [<ffffffff81130dd2>] __up_console_sem+0x62/0x70
> > > <4> [184.578824] hardirqs last disabled at (47942):
> > > [<ffffffff81130db7>] __up_console_sem+0x47/0x70
> > > <4> [184.578826] softirqs last enabled at (47340):
> > > [<ffffffff81e0032d>] __do_softirq+0x32d/0x493
> > > <4> [184.578828] softirqs last disabled at (47335):
> > > [<ffffffff810b9196>] irq_exit_rcu+0xa6/0xe0
> > > <4> [184.578830] ---[ end trace f17ec219f892c7d4 ]---
> > >
> > > Changes since v1:
> > > - Fix intel_pin_fb_obj_dpt too.
> > >
> > > Fixes: 0f341974cbc2 ("drm/i915: Add i915_vma_unbind_unlocked, and
> > > take obj lock for i915_vma_unbind, v2.")
> > > Signed-off-by: Maarten Lankhorst
> > > <maarten.lankhorst at linux.intel.com>
> > > Testcase: kms_addfb_basic
> > > ---
> > > drivers/gpu/drm/i915/display/intel_dpt.c | 6 +++++-
> > > drivers/gpu/drm/i915/display/intel_fb_pin.c | 6 +++++-
> > > 2 files changed, 10 insertions(+), 2 deletions(-)
> > >
> > > diff --git a/drivers/gpu/drm/i915/display/intel_dpt.c
> > > b/drivers/gpu/drm/i915/display/intel_dpt.c
> > > index 63a83d5f85a1..c2f8f853db90 100644
> > > --- a/drivers/gpu/drm/i915/display/intel_dpt.c
> > > +++ b/drivers/gpu/drm/i915/display/intel_dpt.c
> > > @@ -253,7 +253,11 @@ intel_dpt_create(struct intel_framebuffer
> > > *fb)
> > > if (IS_ERR(dpt_obj))
> > > return ERR_CAST(dpt_obj);
> > > - ret = i915_gem_object_set_cache_level(dpt_obj,
> > > I915_CACHE_NONE);
> > > + ret = i915_gem_object_lock_interruptible(dpt_obj, NULL);
> > > + if (!ret) {
> > > + ret = i915_gem_object_set_cache_level(dpt_obj,
> > > I915_CACHE_NONE);
> > > + i915_gem_object_unlock(dpt_obj);
> > > + }
> > > if (ret) {
> > > i915_gem_object_put(dpt_obj);
> > > return ERR_PTR(ret);
> > > diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.c
> > > b/drivers/gpu/drm/i915/display/intel_fb_pin.c
> > > index 9c555f6d1958..c4b3d76341f3 100644
> > > --- a/drivers/gpu/drm/i915/display/intel_fb_pin.c
> > > +++ b/drivers/gpu/drm/i915/display/intel_fb_pin.c
> > > @@ -36,7 +36,11 @@ intel_pin_fb_obj_dpt(struct drm_framebuffer
> > > *fb,
> > > atomic_inc(&dev_priv->gpu_error.pending_fb_pin);
> > > - ret = i915_gem_object_set_cache_level(obj,
> > > I915_CACHE_NONE);
> > > + ret = i915_gem_object_lock_interruptible(obj, NULL);
> > > + if (!ret) {
> > > + ret = i915_gem_object_set_cache_level(obj,
> > > I915_CACHE_NONE);
> > > + i915_gem_object_unlock(obj);
> > > + }
> > > if (ret) {
> > > vma = ERR_PTR(ret);
> > > goto err;
> > >
> >
> > Hi Maarten,
> >
> > Even if v2 is applied, when the igt_runner runs with fast-
> > feedback.testlist as input,lock problem log occurs in dmesg below
> > in kms_busy test.
> >
> > Testing was done in adlp.
> >
> > I think the lock check routine would have to be added even when
> > doing intel_dpt_destroy(), what do you think?
> >
> >
> > -------------------------------------------------------------------
> > ----------------------------------------
> > [ 374.868359] ------------[ cut here ]------------
> > [ 374.868409] WARNING: CPU: 2 PID: 6696 at
> > drivers/gpu/drm/i915/gem/i915_gem_object.h:171
> > __i915_vma_unbind+0xdf/0xf0 [i915]
> > [ 374.868506] Modules linked in: vgem drm_shmem_helper fuse
> > snd_hda_codec_hdmi smsc75xx usbnet mii mei_hdcp
> > x86_pkg_temp_thermal snd_hda_intel snd_intel_dspcfg snd_hda_codec
> > snd_hwdep coretemp snd_hda_core snd_pcm mei_me mei i915 drm_buddy
> > crct10dif_pclmul crc32_pclmul ttm ghash_clmulni_intel drm_dp_helper
> > i2c_i801 drm_kms_helper i2c_smbus intel_lpss_pci syscopyarea
> > sysfillrect sysimgblt fb_sys_fops prime_numbers
> > [ 374.868539] CPU: 2 PID: 6696 Comm: kms_busy Not tainted 5.17.0-
> > rc1-drm-tip-test+ #26
> > [ 374.868541] Hardware name: Intel Corporation Alder Lake Client
> > Platform/AlderLake-P DDR5 RVP, BIOS
> > ADLPFWI1.R00.2162.A00.2104190450 04/19/2021
> > [ 374.868543] RIP: 0010:__i915_vma_unbind+0xdf/0xf0 [i915]
> > [ 374.868631] Code: 15 32 1c 5c e2 85 d2 0f 84 5c ff ff ff 48 8b
> > b8 38 01 00 00 be ff ff ff ff 48 83 c7 68 e8 a9 e0 8a e1 85 c0 0f
> > 85 3f ff ff ff <0f> 0b e9 38 ff ff ff 41 bc f5 ff ff ff eb 86 66 90
> > 0f 1f 44 00 00
> > [ 374.868633] RSP: 0018:ffffc900022f3cd0 EFLAGS: 00010246
> > [ 374.868636] RAX: 0000000000000000 RBX: ffff88810c204b40 RCX:
> > 0000000000000000
> > [ 374.868637] RDX: 0000000080000000 RSI: ffffffff822dc04f RDI:
> > ffffffff82339ebf
> > [ 374.868638] RBP: ffff88810c204b40 R08: 00000000ffffffff R09:
> > 0000000000000000
> > [ 374.868639] R10: 0000000000000001 R11: ffffffffa023ba80 R12:
> > ffff8881095ebb18
> > [ 374.868641] R13: ffff8881095eb800 R14: 00000000ffffffff R15:
> > ffff8881095eb848
> > [ 374.868642] FS: 00007f0326c43c00(0000)
> > GS:ffff88849f300000(0000) knlGS:0000000000000000
> > [ 374.868643] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> > [ 374.868645] CR2: 00007f0329403938 CR3: 00000001429c4006 CR4:
> > 0000000000770ee0
> > [ 374.868646] DR0: 0000000000000000 DR1: 0000000000000000 DR2:
> > 0000000000000000
> > [ 374.868647] DR3: 0000000000000000 DR6: 00000000ffff07f0 DR7:
> > 0000000000000400
> > [ 374.868649] PKRU: 55555554
> > [ 374.868650] Call Trace:
> > [ 374.868651] <TASK>
> > [ 374.868654] __i915_vm_close+0xab/0x190 [i915]
> > [ 374.868729] intel_dpt_destroy+0x29/0x60 [i915]
> > [ 374.868823] intel_user_framebuffer_destroy+0x48/0x50 [i915]
> > [ 374.868945] drm_mode_rmfb+0x1eb/0x220
> > [ 374.868958] ? drm_mode_rmfb+0x220/0x220
> > [ 374.868963] ? drm_mode_rmfb+0x220/0x220
> > [ 374.868966] drm_ioctl_kernel+0xb1/0x140
> > [ 374.868973] drm_ioctl+0x201/0x3b0
> > [ 374.868977] ? drm_mode_rmfb+0x220/0x220
> > [ 374.868981] ? tty_ioctl+0x447/0x980
> > [ 374.868986] ? find_held_lock+0x2b/0x80
> > [ 374.868995] __x64_sys_ioctl+0x83/0xa0
> > [ 374.869000] do_syscall_64+0x38/0xc0
> > [ 374.869006] entry_SYSCALL_64_after_hwframe+0x44/0xae
> > [ 374.869009] RIP: 0033:0x7f0328fde50b
> > [ 374.869012] Code: 0f 1e fa 48 8b 05 85 39 0d 00 64 c7 00 26 00
> > 00 00 48 c7 c0 ff ff ff ff c3 66 0f 1f 44 00 00 f3 0f 1e fa b8 10
> > 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 55 39 0d 00 f7
> > d8 64 89 01 48
> > [ 374.869014] RSP: 002b:00007ffec4a3f278 EFLAGS: 00000246
> > ORIG_RAX: 0000000000000010
> > [ 374.869017] RAX: ffffffffffffffda RBX: 00007ffec4a3f2bc RCX:
> > 00007f0328fde50b
> > [ 374.869019] RDX: 00007ffec4a3f2bc RSI: 00000000c00464af RDI:
> > 0000000000000005
> > [ 374.869020] RBP: 00000000c00464af R08: 0000000000000000 R09:
> > 0000000000000000
> > [ 374.869021] R10: fffffffffffffdea R11: 0000000000000246 R12:
> > 00007ffec4a3f360
> > [ 374.869022] R13: 0000000000000005 R14: 00007ffec4a3f400 R15:
> > 0000000000000000
> > [ 374.869032] </TASK>
> > [ 374.869034] irq event stamp: 258641
> > [ 374.869035] hardirqs last enabled at (258647):
> > [<ffffffff8113a437>] __up_console_sem+0x67/0x70
> > [ 374.869039] hardirqs last disabled at (258652):
> > [<ffffffff8113a41c>] __up_console_sem+0x4c/0x70
> > [ 374.869041] softirqs last enabled at (257220):
> > [<ffffffff810c104d>] irq_exit_rcu+0xdd/0x130
> > [ 374.869045] softirqs last disabled at (257215):
> > [<ffffffff810c104d>] irq_exit_rcu+0xdd/0x130
> > [ 374.869047] ---[ end trace 0000000000000000 ]---
> > [ 374.869178] ------------[ cut here ]------------
> > [ 374.869180] WARNING: CPU: 2 PID: 6696 at
> > drivers/gpu/drm/i915/gem/i915_gem_object.h:171
> > __i915_vma_evict+0x2b0/0x330 [i915]
> > [ 374.869272] Modules linked in: vgem drm_shmem_helper fuse
> > snd_hda_codec_hdmi smsc75xx usbnet mii mei_hdcp
> > x86_pkg_temp_thermal snd_hda_intel snd_intel_dspcfg snd_hda_codec
> > snd_hwdep coretemp snd_hda_core snd_pcm mei_me mei i915 drm_buddy
> > crct10dif_pclmul crc32_pclmul ttm ghash_clmulni_intel drm_dp_helper
> > i2c_i801 drm_kms_helper i2c_smbus intel_lpss_pci syscopyarea
> > sysfillrect sysimgblt fb_sys_fops prime_numbers
> > [ 374.869303] CPU: 2 PID: 6696 Comm: kms_busy Tainted: G W
> > 5.17.0-rc1-drm-tip-test+ #26
> > [ 374.869305] Hardware name: Intel Corporation Alder Lake Client
> > Platform/AlderLake-P DDR5 RVP, BIOS
> > ADLPFWI1.R00.2162.A00.2104190450 04/19/2021
> > [ 374.869306] RIP: 0010:__i915_vma_evict+0x2b0/0x330 [i915]
> > [ 374.869389] Code: 00 00 00 e8 d2 3c 2e e1 e9 84 fe ff ff 48 8b
> > b8 38 01 00 00 be ff ff ff ff 48 83 c7 68 e8 08 e2 8a e1 85 c0 0f
> > 85 91 fd ff ff <0f> 0b e9 8a fd ff ff 0f 0b e9 ca fd ff ff e8 2d e3
> > 8a e1 85 c0 0f
> > [ 374.869391] RSP: 0018:ffffc900022f3cb0 EFLAGS: 00010246
> > [ 374.869393] RAX: 0000000000000000 RBX: 0000000000000000 RCX:
> > 0000000000000000
> > [ 374.869394] RDX: 0000000080000000 RSI: ffffffff822dc04f RDI:
> > ffffffff82339ebf
> > [ 374.869395] RBP: ffff88810c204b40 R08: 00000000ffffffff R09:
> > 0000000000000001
> > [ 374.869396] R10: 0000000000000001 R11: ffff88810156ddc8 R12:
> > ffff88813fcc34c0
> > [ 374.869397] R13: ffff8881095eb800 R14: 00000000ffffffff R15:
> > ffff8881095eb848
> > [ 374.869398] FS: 00007f0326c43c00(0000)
> > GS:ffff88849f300000(0000) knlGS:0000000000000000
> > [ 374.869400] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> > [ 374.869401] CR2: 00007f0329403938 CR3: 00000001429c4006 CR4:
> > 0000000000770ee0
> > [ 374.869402] DR0: 0000000000000000 DR1: 0000000000000000 DR2:
> > 0000000000000000
> > [ 374.869403] DR3: 0000000000000000 DR6: 00000000ffff07f0 DR7:
> > 0000000000000400
> > [ 374.869404] PKRU: 55555554
> > [ 374.869405] Call Trace:
> > [ 374.869406] <TASK>
> > [ 374.869408] __i915_vma_unbind+0x6c/0xf0 [i915]
> > [ 374.869491] __i915_vm_close+0xab/0x190 [i915]
> > [ 374.869565] intel_dpt_destroy+0x29/0x60 [i915]
> > [ 374.869658] intel_user_framebuffer_destroy+0x48/0x50 [i915]
> > [ 374.869750] drm_mode_rmfb+0x1eb/0x220
> > [ 374.869757] ? drm_mode_rmfb+0x220/0x220
> > [ 374.869761] ? drm_mode_rmfb+0x220/0x220
> > [ 374.869765] drm_ioctl_kernel+0xb1/0x140
> > [ 374.869771] drm_ioctl+0x201/0x3b0
> > [ 374.869774] ? drm_mode_rmfb+0x220/0x220
> > [ 374.869779] ? tty_ioctl+0x447/0x980
> > [ 374.869782] ? find_held_lock+0x2b/0x80
> > [ 374.869789] __x64_sys_ioctl+0x83/0xa0
> > [ 374.869793] do_syscall_64+0x38/0xc0
> > [ 374.869797] entry_SYSCALL_64_after_hwframe+0x44/0xae
> > [ 374.869800] RIP: 0033:0x7f0328fde50b
> > [ 374.869802] Code: 0f 1e fa 48 8b 05 85 39 0d 00 64 c7 00 26 00
> > 00 00 48 c7 c0 ff ff ff ff c3 66 0f 1f 44 00 00 f3 0f 1e fa b8 10
> > 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 55 39 0d 00 f7
> > d8 64 89 01 48
> > [ 374.869803] RSP: 002b:00007ffec4a3f278 EFLAGS: 00000246
> > ORIG_RAX: 0000000000000010
> > [ 374.869805] RAX: ffffffffffffffda RBX: 00007ffec4a3f2bc RCX:
> > 00007f0328fde50b
> > [ 374.869807] RDX: 00007ffec4a3f2bc RSI: 00000000c00464af RDI:
> > 0000000000000005
> > [ 374.869808] RBP: 00000000c00464af R08: 0000000000000000 R09:
> > 0000000000000000
> > [ 374.869809] R10: fffffffffffffdea R11: 0000000000000246 R12:
> > 00007ffec4a3f360
> > [ 374.869810] R13: 0000000000000005 R14: 00007ffec4a3f400 R15:
> > 0000000000000000
> > [ 374.869819] </TASK>
> > [ 374.869820] irq event stamp: 259173
> > [ 374.869821] hardirqs last enabled at (259179):
> > [<ffffffff8113a437>] __up_console_sem+0x67/0x70
> > [ 374.869824] hardirqs last disabled at (259184):
> > [<ffffffff8113a41c>] __up_console_sem+0x4c/0x70
> > [ 374.869827] softirqs last enabled at (257220):
> > [<ffffffff810c104d>] irq_exit_rcu+0xdd/0x130
> > [ 374.869841] softirqs last disabled at (259195):
> > [<ffffffff810c104d>] irq_exit_rcu+0xdd/0x130
> > [ 374.869843] ---[ end trace 0000000000000000 ]---
> > [ 374.892030] Console: switching to colour frame buffer device
> > 240x67
> > [ 374.920158] ------------[ cut here ]------------
> > [ 374.920161] WARNING: CPU: 2 PID: 6696 at
> > drivers/gpu/drm/i915/gem/i915_gem_object.h:171
> > __i915_vma_unbind+0xdf/0xf0 [i915]
> > [ 374.920298] Modules linked in: vgem drm_shmem_helper fuse
> > snd_hda_codec_hdmi smsc75xx usbnet mii mei_hdcp
> > x86_pkg_temp_thermal snd_hda_intel snd_intel_dspcfg snd_hda_codec
> > snd_hwdep coretemp snd_hda_core snd_pcm mei_me mei i915 drm_buddy
> > crct10dif_pclmul crc32_pclmul ttm ghash_clmulni_intel drm_dp_helper
> > i2c_i801 drm_kms_helper i2c_smbus intel_lpss_pci syscopyarea
> > sysfillrect sysimgblt fb_sys_fops prime_numbers
> > [ 374.920327] CPU: 2 PID: 6696 Comm: kms_busy Tainted: G W
> > 5.17.0-rc1-drm-tip-test+ #26
> > [ 374.920329] Hardware name: Intel Corporation Alder Lake Client
> > Platform/AlderLake-P DDR5 RVP, BIOS
> > ADLPFWI1.R00.2162.A00.2104190450 04/19/2021
> > [ 374.920331] RIP: 0010:__i915_vma_unbind+0xdf/0xf0 [i915]
> > [ 374.920418] Code: 15 32 1c 5c e2 85 d2 0f 84 5c ff ff ff 48 8b
> > b8 38 01 00 00 be ff ff ff ff 48 83 c7 68 e8 a9 e0 8a e1 85 c0 0f
> > 85 3f ff ff ff <0f> 0b e9 38 ff ff ff 41 bc f5 ff ff ff eb 86 66 90
> > 0f 1f 44 00 00
> > [ 374.920420] RSP: 0018:ffffc900022f3ba0 EFLAGS: 00010246
> > [ 374.920422] RAX: 0000000000000000 RBX: ffff88810c205f40 RCX:
> > 0000000000000000
> > [ 374.920424] RDX: 0000000080000000 RSI: ffffffff822dc04f RDI:
> > ffffffff82339ebf
> > [ 374.920425] RBP: ffff88810c205f40 R08: 00000000ffffffff R09:
> > 0000000000000000
> > [ 374.920426] R10: 0000000000000001 R11: ffffffffa023ba80 R12:
> > ffff888140ecd318
> > [ 374.920427] R13: ffff888140ecd000 R14: 00000000ffffffff R15:
> > ffff888140ecd048
> > [ 374.920428] FS: 0000000000000000(0000)
> > GS:ffff88849f300000(0000) knlGS:0000000000000000
> > [ 374.920430] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> > [ 374.920431] CR2: 00007f032940af28 CR3: 0000000006612001 CR4:
> > 0000000000770ee0
> > [ 374.920432] DR0: 0000000000000000 DR1: 0000000000000000 DR2:
> > 0000000000000000
> > [ 374.920433] DR3: 0000000000000000 DR6: 00000000ffff07f0 DR7:
> > 0000000000000400
> > [ 374.920435] PKRU: 55555554
> > [ 374.920436] Call Trace:
> > [ 374.920437] <TASK>
> > [ 374.920439] __i915_vm_close+0xab/0x190 [i915]
> > [ 374.920513] intel_dpt_destroy+0x29/0x60 [i915]
> > [ 374.920608] intel_user_framebuffer_destroy+0x48/0x50 [i915]
> > [ 374.920697] drm_fb_release+0x108/0x1c0
> > [ 374.920702] ? find_held_lock+0x2b/0x80
> > [ 374.920710] drm_file_free.part.0+0x1a4/0x260
> > [ 374.920716] drm_release_noglobal+0x1c/0xa0
> > [ 374.920719] __fput+0xa3/0x260
> > [ 374.920724] task_work_run+0x59/0xa0
> > [ 374.920729] do_exit+0x382/0xc00
> > [ 374.920735] do_group_exit+0x33/0xb0
> > [ 374.920737] get_signal+0x15e/0xe00
> > [ 374.920744] arch_do_signal_or_restart+0xf0/0x7f0
> > [ 374.920754] exit_to_user_mode_prepare+0x148/0x1d0
> > [ 374.920758] syscall_exit_to_user_mode+0x19/0x50
> > [ 374.920762] do_syscall_64+0x48/0xc0
> > [ 374.920765] entry_SYSCALL_64_after_hwframe+0x44/0xae
> > [ 374.920768] RIP: 0033:0x7f0328fde50b
> > [ 374.920769] Code: Unable to access opcode bytes at RIP
> > 0x7f0328fde4e1.
> > [ 374.920770] RSP: 002b:00007ffec4a3f278 EFLAGS: 00000246
> > [ 374.920772] RAX: 0000000000000000 RBX: 00007ffec4a3f2bc RCX:
> > 00007f0328fde50b
> > [ 374.920774] RDX: 00007ffec4a3f2bc RSI: 00000000c00464af RDI:
> > 0000000000000005
> > [ 374.920775] RBP: 00000000c00464af R08: 0000000000000000 R09:
> > 0000000000000000
> > [ 374.920776] R10: fffffffffffffdea R11: 0000000000000246 R12:
> > 00007ffec4a3f360
> > [ 374.920777] R13: 0000000000000005 R14: 00007ffec4a3f400 R15:
> > 0000000000000000
> > [ 374.920784] </TASK>
> > [ 374.920785] irq event stamp: 365965
> > [ 374.920786] hardirqs last enabled at (365971):
> > [<ffffffff8113a437>] __up_console_sem+0x67/0x70
> > [ 374.920789] hardirqs last disabled at (365976):
> > [<ffffffff8113a41c>] __up_console_sem+0x4c/0x70
> > [ 374.920792] softirqs last enabled at (365380):
> > [<ffffffff81a8c945>] unix_release_sock+0xf5/0x4f0
> > [ 374.920795] softirqs last disabled at (365378):
> > [<ffffffff81a8c91e>] unix_release_sock+0xce/0x4f0
> > [ 374.920796] ---[ end trace 0000000000000000 ]---
> > [ 374.920813] ------------[ cut here ]------------
> > [ 374.920814] WARNING: CPU: 2 PID: 6696 at
> > drivers/gpu/drm/i915/gem/i915_gem_object.h:171
> > __i915_vma_evict+0x2b0/0x330 [i915]
> > [ 374.920972] Modules linked in: vgem drm_shmem_helper fuse
> > snd_hda_codec_hdmi smsc75xx usbnet mii mei_hdcp
> > x86_pkg_temp_thermal snd_hda_intel snd_intel_dspcfg snd_hda_codec
> > snd_hwdep coretemp snd_hda_core snd_pcm mei_me mei i915 drm_buddy
> > crct10dif_pclmul crc32_pclmul ttm ghash_clmulni_intel drm_dp_helper
> > i2c_i801 drm_kms_helper i2c_smbus intel_lpss_pci syscopyarea
> > sysfillrect sysimgblt fb_sys_fops prime_numbers
> > [ 374.921003] CPU: 2 PID: 6696 Comm: kms_busy Tainted: G W
> > 5.17.0-rc1-drm-tip-test+ #26
> > [ 374.921005] Hardware name: Intel Corporation Alder Lake Client
> > Platform/AlderLake-P DDR5 RVP, BIOS
> > ADLPFWI1.R00.2162.A00.2104190450 04/19/2021
> > [ 374.921006] RIP: 0010:__i915_vma_evict+0x2b0/0x330 [i915]
> > [ 374.921095] Code: 00 00 00 e8 d2 3c 2e e1 e9 84 fe ff ff 48 8b
> > b8 38 01 00 00 be ff ff ff ff 48 83 c7 68 e8 08 e2 8a e1 85 c0 0f
> > 85 91 fd ff ff <0f> 0b e9 8a fd ff ff 0f 0b e9 ca fd ff ff e8 2d e3
> > 8a e1 85 c0 0f
> > [ 374.921097] RSP: 0018:ffffc900022f3b80 EFLAGS: 00010246
> > [ 374.921102] RAX: 0000000000000000 RBX: 0000000000000000 RCX:
> > 0000000000000000
> > [ 374.921103] RDX: 0000000080000000 RSI: ffffffff822dc04f RDI:
> > ffffffff82339ebf
> > [ 374.921104] RBP: ffff88810c205f40 R08: 00000000ffffffff R09:
> > 0000000000000001
> > [ 374.921105] R10: 0000000000000001 R11: ffff88810156ddc8 R12:
> > ffff88813fcc6940
> > [ 374.921107] R13: ffff888140ecd000 R14: 00000000ffffffff R15:
> > ffff888140ecd048
> > [ 374.921108] FS: 0000000000000000(0000)
> > GS:ffff88849f300000(0000) knlGS:0000000000000000
> > [ 374.921109] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> > [ 374.921111] CR2: 00007f032940af28 CR3: 0000000006612001 CR4:
> > 0000000000770ee0
> > [ 374.921112] DR0: 0000000000000000 DR1: 0000000000000000 DR2:
> > 0000000000000000
> > [ 374.921113] DR3: 0000000000000000 DR6: 00000000ffff07f0 DR7:
> > 0000000000000400
> > [ 374.921114] PKRU: 55555554
> > [ 374.921115] Call Trace:
> > [ 374.921116] <TASK>
> > [ 374.921118] __i915_vma_unbind+0x6c/0xf0 [i915]
> > [ 374.921207] __i915_vm_close+0xab/0x190 [i915]
> > [ 374.921284] intel_dpt_destroy+0x29/0x60 [i915]
> > [ 374.921377] intel_user_framebuffer_destroy+0x48/0x50 [i915]
> > [ 374.921469] drm_fb_release+0x108/0x1c0
> > [ 374.921472] ? find_held_lock+0x2b/0x80
> > [ 374.921480] drm_file_free.part.0+0x1a4/0x260
> > [ 374.921485] drm_release_noglobal+0x1c/0xa0
> > [ 374.921487] __fput+0xa3/0x260
> > [ 374.921491] task_work_run+0x59/0xa0
> > [ 374.921495] do_exit+0x382/0xc00
> > [ 374.921500] do_group_exit+0x33/0xb0
> > [ 374.921503] get_signal+0x15e/0xe00
> > [ 374.921510] arch_do_signal_or_restart+0xf0/0x7f0
> > [ 374.921519] exit_to_user_mode_prepare+0x148/0x1d0
> > [ 374.921522] syscall_exit_to_user_mode+0x19/0x50
> > [ 374.921525] do_syscall_64+0x48/0xc0
> > [ 374.921528] entry_SYSCALL_64_after_hwframe+0x44/0xae
> > [ 374.921531] RIP: 0033:0x7f0328fde50b
> > [ 374.921532] Code: Unable to access opcode bytes at RIP
> > 0x7f0328fde4e1.
> > [ 374.921533] RSP: 002b:00007ffec4a3f278 EFLAGS: 00000246
> > [ 374.921535] RAX: 0000000000000000 RBX: 00007ffec4a3f2bc RCX:
> > 00007f0328fde50b
> > [ 374.921536] RDX: 00007ffec4a3f2bc RSI: 00000000c00464af RDI:
> > 0000000000000005
> > [ 374.921538] RBP: 00000000c00464af R08: 0000000000000000 R09:
> > 0000000000000000
> > [ 374.921539] R10: fffffffffffffdea R11: 0000000000000246 R12:
> > 00007ffec4a3f360
> > [ 374.921540] R13: 0000000000000005 R14: 00007ffec4a3f400 R15:
> > 0000000000000000
> > [ 374.921547] </TASK>
> > [ 374.921548] irq event stamp: 366515
> > [ 374.921549] hardirqs last enabled at (366521):
> > [<ffffffff8113a437>] __up_console_sem+0x67/0x70
> > [ 374.921552] hardirqs last disabled at (366526):
> > [<ffffffff8113a41c>] __up_console_sem+0x4c/0x70
> > [ 374.921555] softirqs last enabled at (365380):
> > [<ffffffff81a8c945>] unix_release_sock+0xf5/0x4f0
> > [ 374.921556] softirqs last disabled at (365378):
> > [<ffffffff81a8c91e>] unix_release_sock+0xce/0x4f0
> > [ 374.921558] ---[ end trace 0000000000000000 ]---
>
> The bug on vm_close is a separate bug, and would probably best be
> fixed in a separate patch.
>
> Could I get a r-b on this? It should fix some issues, even if the
> unbind there is a separate bug.
>
> ~Maarten
>
Recognizing that it doesn't fix the vm_close issue,
Reviewed-by: Thomas Hellström <thomas.hellstrom at linux.intel.com>
More information about the Intel-gfx
mailing list