[Intel-gfx] [PATCH v2] drm/i915: Unwind HW init after GVT setup failure
Michał Winiarski
michal.winiarski at intel.com
Tue Jul 10 15:44:05 UTC 2018
On Tue, Jul 10, 2018 at 03:38:21PM +0100, Chris Wilson wrote:
> Following intel_gvt_init() failure, we missed unwinding our setup
> leaving pointers dangling past the module unload. For our example, the
> pm_qos:
>
> [ 441.057615] top: 000000006b3baf1c, n: 0000000054d8ef33, p: 0000000097cdf1a2
> prev: 0000000054d8ef33, n: 0000000097cdf1a2, p: 000000006b3baf1c
> next: 0000000097cdf1a2, n: 000000006de8fc8b, p: 0000000081087253
> [ 441.057627] WARNING: CPU: 4 PID: 9277 at lib/plist.c:42 plist_check_prev_next+0x2d/0x40
> [ 441.057628] Modules linked in: i915(+) vgem snd_hda_codec_hdmi snd_hda_codec_realtek snd_hda_codec_generic x86_pkg_temp_thermal intel_powerclamp coretemp crct10dif_pclmul crc32_pclmul ghash_clmulni_intel snd_hda_codec snd_hwdep snd_hda_core e1000e snd_pcm mei_me mei prime_numbers [last unloaded: i915]
> [ 441.057652] CPU: 4 PID: 9277 Comm: drv_selftest Tainted: G U 4.18.0-rc4-CI-CI_DRM_4464+ #1
> [ 441.057653] Hardware name: System manufacturer System Product Name/Z170 PRO GAMING, BIOS 3402 04/26/2017
> [ 441.057656] RIP: 0010:plist_check_prev_next+0x2d/0x40
> [ 441.057657] Code: 08 48 39 f0 74 2b 49 89 f0 48 8b 4f 08 50 ff 32 52 48 89 fe 41 ff 70 08 48 8b 17 48 c7 c7 d8 ae 14 82 4d 8b 08 e8 63 0e 76 ff <0f> 0b 48 83 c4 20 c3 48 39 10 75 d0 f3 c3 0f 1f 44 00 00 41 54 55
> [ 441.057717] RSP: 0018:ffffc900003a3a68 EFLAGS: 00010082
> [ 441.057720] RAX: 0000000000000000 RBX: ffff8802193978c0 RCX: 0000000000000002
> [ 441.057721] RDX: 0000000080000002 RSI: ffffffff820c65a4 RDI: 00000000ffffffff
> [ 441.057722] RBP: ffff8802193978c0 R08: 0000000000000000 R09: 0000000000000001
> [ 441.057724] R10: ffffc900003a3a70 R11: 0000000000000000 R12: ffffffff82243de0
> [ 441.057725] R13: ffffffff82243de0 R14: ffff88021a6c78c0 R15: 0000000077359400
> [ 441.057726] FS: 00007fc23a4a9980(0000) GS:ffff880236d00000(0000) knlGS:0000000000000000
> [ 441.057728] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> [ 441.057729] CR2: 0000563e4503d038 CR3: 0000000138f86005 CR4: 00000000003606e0
> [ 441.057730] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> [ 441.057731] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
> [ 441.057732] Call Trace:
> [ 441.057736] plist_check_list+0x2e/0x40
> [ 441.057738] plist_add+0x23/0x130
> [ 441.057743] pm_qos_update_target+0x1bd/0x2f0
> [ 441.057771] i915_driver_load+0xec4/0x1060 [i915]
> [ 441.057775] ? trace_hardirqs_on_caller+0xe0/0x1b0
> [ 441.057800] i915_pci_probe+0x29/0x90 [i915]
> [ 441.057804] pci_device_probe+0xa1/0x130
> [ 441.057807] driver_probe_device+0x306/0x480
> [ 441.057810] __driver_attach+0xdb/0x100
> [ 441.057812] ? driver_probe_device+0x480/0x480
> [ 441.057813] ? driver_probe_device+0x480/0x480
> [ 441.057816] bus_for_each_dev+0x74/0xc0
> [ 441.057819] bus_add_driver+0x15f/0x250
> [ 441.057821] ? 0xffffffffa0696000
> [ 441.057823] driver_register+0x56/0xe0
> [ 441.057825] ? 0xffffffffa0696000
> [ 441.057827] do_one_initcall+0x58/0x370
> [ 441.057830] ? do_init_module+0x1d/0x1ea
> [ 441.057832] ? rcu_read_lock_sched_held+0x6f/0x80
> [ 441.057834] ? kmem_cache_alloc_trace+0x282/0x2e0
> [ 441.057838] do_init_module+0x56/0x1ea
> [ 441.057841] load_module+0x2435/0x2b20
> [ 441.057852] ? __se_sys_finit_module+0xd3/0xf0
> [ 441.057854] __se_sys_finit_module+0xd3/0xf0
> [ 441.057861] do_syscall_64+0x55/0x190
> [ 441.057863] entry_SYSCALL_64_after_hwframe+0x49/0xbe
> [ 441.057865] RIP: 0033:0x7fc239d75839
> [ 441.057866] Code: 00 f3 c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 1f f6 2c 00 f7 d8 64 89 01 48
> [ 441.057927] RSP: 002b:00007fffb7825d38 EFLAGS: 00000246 ORIG_RAX: 0000000000000139
> [ 441.057930] RAX: ffffffffffffffda RBX: 0000563e45035dd0 RCX: 00007fc239d75839
> [ 441.057931] RDX: 0000000000000000 RSI: 0000563e4502f8a0 RDI: 0000000000000004
> [ 441.057932] RBP: 0000563e4502f8a0 R08: 0000000000000004 R09: 0000000000000000
> [ 441.057933] R10: 00007fffb7825ea0 R11: 0000000000000246 R12: 0000000000000000
> [ 441.057934] R13: 0000563e4502f690 R14: 0000000000000000 R15: 000000000000003f
> [ 441.057940] irq event stamp: 231338
> [ 441.057943] hardirqs last enabled at (231337): [<ffffffff8193e3fc>] _raw_spin_unlock_irqrestore+0x4c/0x60
> [ 441.057944] hardirqs last disabled at (231338): [<ffffffff8193e26d>] _raw_spin_lock_irqsave+0xd/0x50
> [ 441.057947] softirqs last enabled at (231024): [<ffffffff81c0034f>] __do_softirq+0x34f/0x505
> [ 441.057949] softirqs last disabled at (231005): [<ffffffff8108c7b9>] irq_exit+0xa9/0xc0
> [ 441.057951] WARNING: CPU: 4 PID: 9277 at lib/plist.c:42 plist_check_prev_next+0x2d/0x40
>
> v2: Add a load failure point to intel_gvt_init() so that we always
> exercise this path in future.
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> Cc: Matthew Auld <matthew.auld at intel.com>
> Cc: Michał Winiarski <michal.winiarski at intel.com>
Reviewed-by: Michał Winiarski <michal.winiarski at intel.com>
-Michał
> ---
> drivers/gpu/drm/i915/i915_drv.c | 10 +++++++---
> drivers/gpu/drm/i915/intel_gvt.c | 3 +++
> 2 files changed, 10 insertions(+), 3 deletions(-)
More information about the Intel-gfx
mailing list