i915 IVB hangup after resume from s2mem since v6.6.x

Saarinen, Jani jani.saarinen at intel.com
Tue Apr 30 06:57:50 UTC 2024


Hi, 
Please file bug at #1. Would be also good to check our existing bug as I can see we have IVB on our CI https://intel-gfx-ci.01.org/tree/drm-tip/index.html?hosts=ivb .
So results from suspend issues could be at https://intel-gfx-ci.01.org/tree/drm-tip/drmtip.html?testfilter=suspend&hosts=ivb . 

Br,
Jani

#1:  https://drm.pages.freedesktop.org/intel-docs/how-to-file-i915-bugs.html
> -----Original Message-----
> From: Intel-gfx <intel-gfx-bounces at lists.freedesktop.org> On Behalf Of
> Johannes Stezenbach
> Sent: Monday, 29 April 2024 22.34
> To: intel-gfx at lists.freedesktop.org
> Subject: i915 IVB hangup after resume from s2mem since v6.6.x
> 
> Hi,
> 
> I updated the Linux kernel on an old machine from v6.5.9 to current v6.8.8
> and found the display failed after resume from suspend to RAM. Then I tried
> v6.7.9 and v6.6.29, both also failed. v6.5.9 works.
> 
> - display connected via display port: hangup
> 
> - I also tried HDMI with v6.6.29: garbage (color noise) after wakeup,
>   after a bit of switching between Linux virtual consoles
>   the display came back to live, first flickering between
>   color noise and actual output, then stable output
> 
> CPU/GPU: Core i5-3550
> 00:02.0 VGA compatible controller: Intel Corporation Xeon E3-1200 v2/3rd
> Gen Core processor Graphics Controller (rev 09)
> 00:02.0 0300: 8086:0152 (rev 09)
> 
> 
> HDMI generates this error in kernel log:
> 
> [    C0] i915 0000:00:02.0: [drm] *ERROR* uncleared pch fifo underrun on pch
> transcoder A
> [    C0] i915 0000:00:02.0: [drm] *ERROR* PCH transcoder A FIFO underrun
> 
> 
> DP genrates this error spew on v6.6.29:
> 
>  [    C3] i915 0000:00:02.0: [drm] *ERROR* uncleared pch fifo underrun on
> pch transcoder A
>  [    C3] i915 0000:00:02.0: [drm] *ERROR* PCH transcoder A FIFO underrun
>  [ T3502] PM: suspend entry (deep)
> ...
>  [ T3927] ------------[ cut here ]------------  [ T3927] i915 0000:00:02.0:
> drm_WARN_ON((intel_de_read(dev_priv, intel_dp->output_reg) & (1 << 31))
> == 0)  [ T3927] WARNING: CPU: 2 PID: 3927 at
> drivers/gpu/drm/i915/display/g4x_dp.c:417
> intel_dp_link_down.isra.0+0x2e4/0x300
>  [ T3927] Modules linked in: mt76x0u mt76x0_common mt76x02_usb
> mt76_usb mt76x02_lib mt76 mac80211 kvm_intel cfg80211 kv>  [ T3927]
> CPU: 2 PID: 3927 Comm: kworker/u8:26 Not tainted 6.6.29 #1  [ T3927]
> Hardware name: System manufacturer System Product Name/P8H77-V, BIOS
> 1905 10/27/2014  [ T3927] Workqueue: events_unbound async_run_entry_fn
> [ T3927] RIP: 0010:intel_dp_link_down.isra.0+0x2e4/0x300
>  [ T3927] Code: 48 8b 5f 50 48 85 db 75 03 48 8b 1f e8 c5 0d 07 00 48 c7 c1 70
> 8c ac 89 48 89 da 48 c7 c7 f1 16 9d 89 4>  [ T3927] RSP:
> 0018:ffffa41d41b37a68 EFLAGS: 00010246  [ T3927] RAX: 0000000000000000
> RBX: ffff9df340d79380 RCX: 0000000000000000  [ T3927] RDX:
> 0000000000000000 RSI: 0000000000000000 RDI: 0000000000000000  [
> T3927] RBP: ffff9df346478000 R08: 0000000000000000 R09:
> 0000000000000000  [ T3927] R10: 0000000000000000 R11:
> 0000000000000000 R12: ffff9df34647ad68  [ T3927] R13: ffff9df34649e000
> R14: 0000000000000001 R15: 0000000000000000  [ T3927] FS:
> 0000000000000000(0000) GS:ffff9df64f800000(0000)
> knlGS:0000000000000000  [ T3927] CS:  0010 DS: 0000 ES: 0000 CR0:
> 0000000080050033  [ T3927] CR2: 00007f026e63418c CR3:
> 000000032bc50006 CR4: 00000000001706e0  [ T3927] Call Trace:
>  [ T3927]  <TASK>
>  [ T3927]  ? __warn+0x80/0x160
>  [ T3927]  ? intel_dp_link_down.isra.0+0x2e4/0x300
>  [ T3927]  ? report_bug+0x19e/0x1d0
>  [ T3927]  ? handle_bug+0x40/0x80
>  [ T3927]  ? exc_invalid_op+0x13/0x70
>  [ T3927]  ? asm_exc_invalid_op+0x16/0x20  [ T3927]  ?
> intel_dp_link_down.isra.0+0x2e4/0x300
>  [ T3927]  ? intel_dp_link_down.isra.0+0x2e4/0x300
>  [ T3927]  g4x_post_disable_dp+0x2e/0x120  [ T3927]
> intel_encoders_post_disable+0x72/0x90
>  [ T3927]  ilk_crtc_disable+0x80/0xe0
>  [ T3927]  intel_atomic_commit_tail+0x404/0xed0
>  [ T3927]  ? intel_atomic_commit+0x374/0x3c0  [ T3927]  ?
> intel_atomic_commit+0x30a/0x3c0  [ T3927]
> intel_atomic_commit+0x374/0x3c0  [ T3927]
> drm_atomic_commit+0x96/0xd0  [ T3927]  ?
> __pfx___drm_printfn_info+0x10/0x10
>  [ T3927]  drm_atomic_helper_disable_all+0x19a/0x1b0
>  [ T3927]  drm_atomic_helper_suspend+0xd5/0x240
>  [ T3927]  intel_display_driver_suspend+0x28/0x70
>  [ T3927]  i915_drm_suspend+0x42/0xf0
>  [ T3927]  pci_pm_suspend+0x73/0x170
>  [ T3927]  ? __pfx_pci_pm_suspend+0x10/0x10  [ T3927]
> dpm_run_callback+0x52/0x190  [ T3927]  __device_suspend+0xf3/0x4b0  [
> T3927]  ? process_one_work+0x1ad/0x510  [ T3927]
> async_suspend+0x1a/0x60  [ T3927]  async_run_entry_fn+0x30/0x160  [
> T3927]  ? process_one_work+0x1ad/0x510  [ T3927]
> process_one_work+0x219/0x510  [ T3927]  worker_thread+0x1d6/0x3e0  [
> T3927]  ? __pfx_worker_thread+0x10/0x10  [ T3927]  kthread+0xf6/0x130  [
> T3927]  ? __pfx_kthread+0x10/0x10  [ T3927]  ret_from_fork+0x30/0x50  [
> T3927]  ? __pfx_kthread+0x10/0x10  [ T3927]
> ret_from_fork_asm+0x1b/0x30  [ T3927]  </TASK>  [ T3927] ---[ end trace
> 0000000000000000 ]---  [ T3502] ACPI: PM: Preparing to enter system sleep
> state S3  [ T3502] ACPI: PM: Saving platform NVS memory  [ T3502] Disabling
> non-boot CPUs ...
> ...
>  [ T3502] ACPI: PM: Waking up from system sleep state S3  [ T3928] i915
> 0000:00:02.0: vgaarb: VGA decodes changed:
> olddecodes=io+mem,decodes=io+mem:owns=io+mem
>  [ T3502] PM: suspend exit
>  [    C0] i915 0000:00:02.0: [drm] *ERROR* uncleared pch fifo underrun on
> pch transcoder A
>  [    C0] i915 0000:00:02.0: [drm] *ERROR* PCH transcoder A FIFO underrun
>  [    C0] sysrq: Emergency Sync
>  [    T8] Emergency Sync complete
>  [    C0] sysrq: Emergency Remount R/O
> 
> 
> and on v6.8.8:
> 
>  [    C3] i915 0000:00:02.0: [drm] *ERROR* uncleared pch fifo underrun on
> pch transcoder A
>  [    C3] i915 0000:00:02.0: [drm] *ERROR* PCH transcoder A FIFO underrun
>  [T10083] PM: suspend entry (deep)
> ...
>  [T10083] ACPI: PM: Waking up from system sleep state S3  [T10083] serial
> 00:06: activated  [T10569] i915 0000:00:02.0: vgaarb: VGA decodes changed:
> olddecodes=io+mem,decodes=io+mem:owns=io+mem
> ...
>  [T10083] PM: suspend exit
>  [    C0] i915 0000:00:02.0: [drm] *ERROR* uncleared pch fifo underrun on
> pch transcoder A
>  [    C0] i915 0000:00:02.0: [drm] *ERROR* PCH transcoder A FIFO underrun
> ...
>  [   T37] INFO: task kworker/1:1:47 blocked for more than 122 seconds.
>  [   T37]       Not tainted 6.8.8 #1
>  [   T37] "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this
> message.
>  [   T37] task:kworker/1:1     state:D stack:0     pid:47    tgid:47    ppid:2
> flags:0x00004000
>  [   T37] Workqueue: i915-unordered i915_hotplug_work_func
>  [   T37] Call Trace:
>  [   T37]  <TASK>
>  [   T37]  __schedule+0x4c9/0x1810
>  [   T37]  ? find_held_lock+0x2b/0x90
>  [   T37]  ? find_held_lock+0x2b/0x90
>  [   T37]  schedule+0x49/0x150
>  [   T37]  schedule_preempt_disabled+0x18/0x30
>  [   T37]  __ww_mutex_lock.constprop.0+0x90e/0x12d0
>  [   T37]  ? modeset_lock+0x17d/0x1e0
>  [   T37]  ? modeset_lock+0x17d/0x1e0
>  [   T37]  modeset_lock+0x17d/0x1e0
>  [   T37]  drm_helper_probe_detect_ctx+0x7b/0x120
>  [   T37]  intel_hotplug_detect_connector+0x43/0x120
>  [   T37]  intel_hdmi_hotplug+0xe/0x30
>  [   T37]  i915_hotplug_work_func+0x2af/0x3e0
>  [   T37]  ? process_one_work+0x1ad/0x510
>  [   T37]  process_one_work+0x219/0x510
>  [   T37]  worker_thread+0x1d6/0x3e0
>  [   T37]  ? __pfx_worker_thread+0x10/0x10
>  [   T37]  kthread+0xf6/0x130
>  [   T37]  ? __pfx_kthread+0x10/0x10
>  [   T37]  ret_from_fork+0x30/0x50
>  [   T37]  ? __pfx_kthread+0x10/0x10
>  [   T37]  ret_from_fork_asm+0x1b/0x30
>  [   T37]  </TASK>
>  [   T37] INFO: task Xorg:3197 blocked for more than 122 seconds.
>  [   T37]       Not tainted 6.8.8 #1
>  [   T37] "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this
> message.
>  [   T37] task:Xorg            state:D stack:0     pid:3197  tgid:3197  ppid:3185
> flags:0x00400002
>  [   T37] Call Trace:
>  [   T37]  <TASK>
>  [   T37]  __schedule+0x4c9/0x1810
>  [   T37]  ? find_held_lock+0x2b/0x90
>  [   T37]  schedule+0x49/0x150
>  [   T37]  drm_vblank_work_flush+0x92/0xf0
>  [   T37]  ? __pfx_autoremove_wake_function+0x10/0x10
>  [   T37]  intel_wait_for_vblank_workers+0x4b/0x90
>  [   T37]  intel_atomic_commit_tail+0x747/0x1080
>  [   T37]  ? find_held_lock+0x2b/0x90
>  [   T37]  ? local_clock_noinstr+0x9/0xc0
>  [   T37]  ? _raw_spin_unlock+0x29/0x60
>  [   T37]  ? intel_atomic_commit+0x2f3/0x340
>  [   T37]  ? intel_atomic_commit+0x299/0x340
>  [   T37]  intel_atomic_commit+0x2f3/0x340
>  [   T37]  drm_atomic_commit+0x96/0xd0
>  [   T37]  ? __pfx___drm_printfn_info+0x10/0x10
>  [   T37]  drm_mode_gamma_set_ioctl+0x3c5/0x590
>  [   T37]  ? __pfx_drm_mode_gamma_set_ioctl+0x10/0x10
>  [   T37]  drm_ioctl_kernel+0xbc/0x110
>  [   T37]  drm_ioctl+0x284/0x500
>  [   T37]  ? __pfx_drm_mode_gamma_set_ioctl+0x10/0x10
>  [   T37]  __x64_sys_ioctl+0xa9/0xd0
>  [   T37]  do_syscall_64+0x7b/0x140
>  [   T37]  ? local_clock_noinstr+0x9/0xc0
>  [   T37]  ? lock_release+0x14a/0x400
>  [   T37]  ? trace_hardirqs_on_prepare+0x3c/0xb0
>  [   T37]  ? syscall_exit_to_user_mode+0x9c/0x1a0
>  [   T37]  ? do_syscall_64+0x87/0x140
>  [   T37]  ? do_syscall_64+0x87/0x140
>  [   T37]  ? do_syscall_64+0x87/0x140
>  [   T37]  ? trace_hardirqs_on_prepare+0x3c/0xb0
>  [   T37]  entry_SYSCALL_64_after_hwframe+0x78/0x80
>  [   T37] RIP: 0033:0x7f0a152195cb
>  [   T37] RSP: 002b:00007ffe12bd6410 EFLAGS: 00000246 ORIG_RAX:
> 0000000000000010
>  [   T37] RAX: ffffffffffffffda RBX: 0000000000000007 RCX: 00007f0a152195cb
>  [   T37] RDX: 00007ffe12bd64a0 RSI: 00000000c02064a5 RDI:
> 000000000000000f
>  [   T37] RBP: 00007ffe12bd64a0 R08: 0000564b17a70950 R09:
> 0000564b17a70b50
>  [   T37] R10: 0000564b17a70750 R11: 0000000000000246 R12:
> 00000000c02064a5
>  [   T37] R13: 000000000000000f R14: 0000000000000003 R15:
> 00007ffe12bd6560
>  [   T37]  </TASK>
>  [   T37]
>  [   T37] Showing all locks held in the system:
>  [   T37] 1 lock held by khungtaskd/37:
>  [   T37]  #0: ffffffff87d601c0 (rcu_read_lock){....}-{1:2}, at:
> debug_show_all_locks+0x32/0x110
>  [   T37] 6 locks held by kworker/1:1/47:
>  [   T37]  #0: ffff927000c09548 ((wq_completion)i915-unordered){....}-{0:0},
> at: process_one_work+0x1ad/0x510
>  [   T37]  #1: ffffb1d6801bbe50 ((work_completion)(&(&i915-
> >display.hotplug.hotplug_work)->work)){....}-{0:0}, at: proc>
>  [   T37]  #2: ffff9270074084f0 (&dev->mode_config.mutex){....}-{3:3}, at:
> i915_hotplug_work_func+0x58/0x3e0
>  [   T37]  #3: ffffffff87e4d680 (drm_connector_list_iter){....}-{0:0}, at:
> i915_hotplug_work_func+0x1fc/0x3e0
>  [   T37]  #4: ffffb1d6801bbce0 (crtc_ww_class_acquire){....}-{0:0}, at:
> drm_helper_probe_detect_ctx+0x4b/0x120
>  [   T37]  #5: ffff927007408590 (crtc_ww_class_mutex){....}-{3:3}, at:
> modeset_lock+0x17d/0x1e0
>  [   T37] 1 lock held by in:imklog/2976:
>  [   T37]  #0: ffff9270012698d8 (&f->f_pos_lock){....}-{3:3}, at:
> __fdget_pos+0x52/0x80
>  [   T37] 2 locks held by Xorg/3197:
>  [   T37]  #0: ffffb1d682027bf8 (crtc_ww_class_acquire){....}-{0:0}, at:
> drm_mode_gamma_set_ioctl+0x15d/0x590
>  [   T37]  #1: ffff927007408590 (crtc_ww_class_mutex){....}-{3:3}, at:
> modeset_lock+0x17d/0x1e0
>  [   T37] 2 locks held by kworker/u8:61/10605:
>  [   T37]  #0: ffff9270001da748 ((wq_completion)phy2){....}-{0:0}, at:
> process_one_work+0x1ad/0x510
>  [   T37]  #1: ffffb1d68213fe50 ((work_completion)(&(&dev->cal_work)-
> >work)){....}-{0:0}, at: process_one_work+0x1ad/0x>
>  [   T37]
>  [   T37] =============================================
> 
> 
> I hope you have ideas about fixes to try, bisect testing takes much time which
> I don't have...
> 
> 
> Best Regards,
> Johannes


More information about the Intel-gfx mailing list