Bug 84182

Summary: [HSW] i915: Freeze after DPMS
Product: DRI Reporter: Harald Judt <h.judt>
Component: DRM/IntelAssignee: Intel GFX Bugs mailing list <intel-gfx-bugs>
Status: CLOSED WORKSFORME QA Contact: Intel GFX Bugs mailing list <intel-gfx-bugs>
Severity: normal    
Priority: medium CC: alpine.art.de, gary.c.wang, intel-gfx-bugs, mails.bugs.freedesktop.org-2009, przanoni, shan-fu.chiou, ullysses.a.eoff
Version: XOrg git   
Hardware: x86-64 (AMD64)   
OS: Linux (All)   
Whiteboard:
i915 platform: HSW i915 features: display/DP

Description Harald Judt 2014-09-22 12:58:24 UTC
I have two screens attached to a Lenovo Thinkpad T440s: One via MiniDP->HDMI->DVI, one via VGA.

Freeze occurred on DPMS update, with the error message below. SSH access was still possible, but I had to reboot the machine to get display working again.

00:02.0 VGA compatible controller: Intel Corporation Haswell-ULT Integrated Graphics Controller (rev 09) (prog-if 00 [VGA controller])
        Subsystem: Lenovo Device 220c
        Flags: bus master, fast devsel, latency 0, IRQ 56
        Memory at e0000000 (64-bit, non-prefetchable) [size=4M]
        Memory at c0000000 (64-bit, prefetchable) [size=512M]
        I/O ports at 3000 [size=64]
        Expansion ROM at <unassigned> [disabled]
        Capabilities: [90] MSI: Enable+ Count=1/1 Maskable- 64bit-
        Capabilities: [d0] Power Management version 2
        Capabilities: [a4] PCI Advanced Features
        Kernel driver in use: i915

[34697.699738] ------------[ cut here ]------------
[34697.699750] WARNING: CPU: 2 PID: 2205 at drivers/gpu/drm/i915/intel_display.c:3313 intel_crtc_wait_for_pending_flips+0xe3/0x13b()
[34697.699752] Modules linked in: cifs uvcvideo xhci_hcd vboxnetadp(O) vboxnetflt(O) vboxdrv(O) tun videobuf2_vmalloc videobuf2_memops videobuf2_core v4l2_common videodev usbhid iwlmvm mac80211 iwlwifi rtsx_pci_sdmmc mmc_core cfg80211 ehci_pci ehci_hcd usbcore rtsx_pci usb_common psmouse x86_pkg_temp_thermal coretemp microcode i2c_i801 processor snd_hda_codec_hdmi snd_hda_codec_realtek snd_hda_codec_generic snd_hda_intel snd_hda_controller snd_hda_codec evdev thermal battery snd_hwdep snd_pcm snd_timer ac thinkpad_acpi snd [last unloaded: uvcvideo]
[34697.699800] CPU: 2 PID: 2205 Comm: X Tainted: G           O  3.16.0+ #160
[34697.699802] Hardware name: LENOVO 20AQS00900/20AQS00900, BIOS GJET77WW (2.27 ) 05/20/2014
[34697.699804]  0000000000000000 ffff8802333e7c30 ffffffff8159d4e1 0000000000000000
[34697.699808]  ffff8802333e7c68 ffffffff81066511 ffffffff813d91b4 0000000000000000
[34697.699812]  ffff880235f6c000 ffff880233cb9010 ffff880235f6b000 ffff8802333e7c78
[34697.699816] Call Trace:
[34697.699823]  [<ffffffff8159d4e1>] dump_stack+0x4e/0x7a
[34697.699828]  [<ffffffff81066511>] warn_slowpath_common+0x7a/0x93
[34697.699834]  [<ffffffff813d91b4>] ? intel_crtc_wait_for_pending_flips+0xe3/0x13b
[34697.699838]  [<ffffffff810665c9>] warn_slowpath_null+0x15/0x17
[34697.699842]  [<ffffffff813d91b4>] intel_crtc_wait_for_pending_flips+0xe3/0x13b
[34697.699849]  [<ffffffff8108d7db>] ? finish_wait+0x60/0x60
[34697.699853]  [<ffffffff813dbb78>] intel_crtc_disable_planes+0x2b/0x148
[34697.699857]  [<ffffffff813dc7d5>] haswell_crtc_disable+0x3c/0x239
[34697.699861]  [<ffffffff813dcfd3>] intel_crtc_update_dpms+0x5c/0x6d
[34697.699865]  [<ffffffff813e026d>] intel_connector_dpms+0x43/0x4e
[34697.699872]  [<ffffffff813906fc>] drm_mode_obj_set_property_ioctl+0x20f/0x2ac
[34697.699876]  [<ffffffff813907c4>] drm_mode_connector_property_set_ioctl+0x2b/0x2d
[34697.699880]  [<ffffffff81383149>] drm_ioctl+0x381/0x3fb
[34697.699884]  [<ffffffff81390799>] ? drm_mode_obj_set_property_ioctl+0x2ac/0x2ac
[34697.699890]  [<ffffffff81157184>] ? rcu_read_unlock+0x23/0x23
[34697.699896]  [<ffffffff8114f039>] do_vfs_ioctl+0x361/0x425
[34697.699900]  [<ffffffff81157182>] ? rcu_read_unlock+0x21/0x23
[34697.699902]  [<ffffffff8115735a>] ? __fget+0x6a/0x74
[34697.699906]  [<ffffffff8114f135>] SyS_ioctl+0x38/0x5f
[34697.699911]  [<ffffffff815a4d12>] system_call_fastpath+0x16/0x1b
[34697.699913] ---[ end trace 327686bcdbcc8117 ]---
Comment 1 Franz Fellner 2014-09-29 07:38:42 UTC
Same backtrace here, didn't realise this may be caused by DPMS update.

00:02.0 VGA compatible controller: Intel Corporation 2nd Generation Core Processor Family Integrated Graphics Controller (rev 09) (prog-if 00 [VGA controller])
        Subsystem: ASRock Incorporation Device 0122
        Flags: bus master, fast devsel, latency 0, IRQ 16
        Memory at fe000000 (64-bit, non-prefetchable) [size=4M]
        Memory at c0000000 (64-bit, prefetchable) [size=256M]
        I/O ports at f000 [size=64]
        Expansion ROM at <unassigned> [disabled]
        Capabilities: [90] MSI: Enable- Count=1/1 Maskable- 64bit-
        Capabilities: [d0] Power Management version 2
        Capabilities: [a4] PCI Advanced Features
        Kernel driver in use: i915
Comment 2 Harald Judt 2014-09-29 09:28:59 UTC
A week ago, I switched to using only one external monitor (on the VGA port). Since then, I have not suffered from this bug. So it could be this only occurs when using a monitor connected via MiniDP->HDMI->DVI. Or only when two monitors are connected, of course.

I'll try connecting a single monitor via MiniDP->HDMI->DVI and using this setup for a week.
Comment 3 Franz Fellner 2014-10-07 09:04:26 UTC
The monitor here is connected directly via DVI->DVI. The board offers HDMI, but that's not used.
I think this is a regression in 10.3.0. I got these freezes directly after booting with the upgraded mesa. I then downgraded to 10.2.8 (on 1. October) and since then never experienced this issue again.
Comment 4 Paulo Zanoni 2014-10-08 18:02:21 UTC
Hi

What are the exact steps to reproduce, and how often do you get the bug when you do these steps? All that is needed is to wait until the machine enters DPMS state?

Can you please boot passing drm.debug=0xe as a Kernel argument (you can do that in grub), reproduce the bug, then attach the output of dmesg here?

I find it weird that you have a VGA port on an ULT machine. Can you please post the output of the "xrandr" command?

Just a notice: we are aware that some converters (e.g., DP->HDMI, HDMI->DVI, etc.) sometimes may cause problems. Not all converters cause this behavior, so if you could try to test other converters (or a DP monitor), it would be nice to know .

Thanks,
Paulo
Comment 5 Franz Fellner 2014-10-25 09:38:23 UTC
This happened again yesterday, with mesa-10.2.8 - so no regression, at least not in mesa.
It happened while viewing a video in fullscreen, which also was the first time I saw this happen. But this also happened during regular use without any multimedia application running. It even happened after a fresh reboot, no window open and absolutely no activity.
This particular machine is running most recent kde desktop.

But I had this also on my Laptop, a Lenovo ThinkPad L520, no external monitor plugged in. I am running awesome WM with compton. It happened while watching a Video, also fullscreen, in flash + firefox (if that matters). I manually turned off dpms and screensaver using xset.

The only solution to get the monitor repainted again is to switch to another TTY (CTRL+ALT+Fx). It will take ~2 minutes until I see the terminal login. I then can switch back to my Xsession, everything seems to work fine, then.

I did not yet find a regular pattern to trigger this bug, it seems to happen quite randomly.
Comment 6 Harald Judt 2014-11-07 17:48:53 UTC
I encounter the same error on another desktop machine, using the same monitor connected via a DP->DVI adapter. Backtrace:

kernel: ------------[ cut here ]------------
kernel: WARNING: CPU: 0 PID: 24018 at drivers/gpu/drm/i915/intel_display.c:3313 intel_crtc_wait_for_pending_flips+0xe0/0x133()
kernel: Modules linked in: cfg80211 vboxnetadp(O) vboxnetflt(O) vboxdrv(O) cpufreq_ondemand snd_hda_codec_realtek snd_hda_codec_hdmi snd_hda_codec_generic snd_hda_intel snd_hda_controller snd_hda_codec e1000e snd_hwdep x86_pkg_temp_thermal snd_pcm coretemp sr_mod psmouse microcode cdrom snd_timer i2c_i801 ptp snd pps_core fan thermal battery processor
kernel: CPU: 0 PID: 24018 Comm: X Tainted: G           O  3.16.0+ #164
kernel: Hardware name: LENOVO 10AHS0NG00/SHARKBAY, BIOS FBKT75AUS 04/01/2014
kernel:  0000000000000000 ffff8801d736fc30 ffffffff81553866 0000000000000000
kernel:  ffff8801d736fc68 ffffffff81039595 ffffffff8138eb1c 0000000000000000
kernel:  ffff8802153f2000 ffff880215387d50 ffff8802150f2800 ffff8801d736fc78
kernel: Call Trace:
kernel:  [<ffffffff81553866>] dump_stack+0x4e/0x7a
kernel:  [<ffffffff81039595>] warn_slowpath_common+0x7a/0x93
kernel:  [<ffffffff8138eb1c>] ? intel_crtc_wait_for_pending_flips+0xe0/0x133
kernel:  [<ffffffff8103964d>] warn_slowpath_null+0x15/0x17
kernel:  [<ffffffff8138eb1c>] intel_crtc_wait_for_pending_flips+0xe0/0x133
kernel:  [<ffffffff8105f2c5>] ? finish_wait+0x60/0x60
kernel:  [<ffffffff813914c0>] intel_crtc_disable_planes+0x2b/0x148
kernel:  [<ffffffff81392114>] haswell_crtc_disable+0x3c/0x237
kernel:  [<ffffffff81392906>] intel_crtc_update_dpms+0x5c/0x6d
kernel:  [<ffffffff81395b76>] intel_connector_dpms+0x43/0x4e
kernel:  [<ffffffff81346739>] drm_mode_obj_set_property_ioctl+0x20f/0x2a9
kernel:  [<ffffffff813467fe>] drm_mode_connector_property_set_ioctl+0x2b/0x2d
kernel:  [<ffffffff813393d3>] drm_ioctl+0x381/0x3f9
kernel:  [<ffffffff813467d3>] ? drm_mode_obj_set_property_ioctl+0x2a9/0x2a9
kernel:  [<ffffffff81113987>] do_vfs_ioctl+0x351/0x415
kernel:  [<ffffffff8111b763>] ? __fget+0x6a/0x74
kernel:  [<ffffffff81113a83>] SyS_ioctl+0x38/0x5f
kernel:  [<ffffffff81559892>] system_call_fastpath+0x16/0x1b
kernel: ---[ end trace 36351689a27913b3 ]---

lspci -v:
00:02.0 VGA compatible controller: Intel Corporation Xeon E3-1200 v3/4th Gen Core Processor Integrated Graphics Controller (rev 06) (prog-if 00 [VGA controller])
        Subsystem: Lenovo Device 309f
        Flags: bus master, fast devsel, latency 0, IRQ 40
        Memory at f7800000 (64-bit, non-prefetchable) [size=4M]
        Memory at e0000000 (64-bit, prefetchable) [size=256M]
        I/O ports at f000 [size=64]
        Expansion ROM at <unassigned> [disabled]
        Capabilities: [90] MSI: Enable+ Count=1/1 Maskable- 64bit-
        Capabilities: [d0] Power Management version 2
        Capabilities: [a4] PCI Advanced Features
        Kernel driver in use: i915

kernel: 3.16.0

I have not tried the debug parameter, but will enable it at the next opportunity.
Comment 7 Jani Nikula 2015-10-23 10:08:56 UTC
Timeout, closing. Please reopen (and attach dmesg with drm.debug=14) if the problem persists with latest kernels.

Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.