воскресенье, 23 августа 2020 г.

Черный экран при выходе из hibernate

Иногда после выхода из спящего режима нет изображения на экране ноутбука. Чаще это случается если ноутбук ушел в спящий режим подключенным к док-станции (в этом случае изображение выводится на два внешних монитора, а экран ноутбука отключен), а выходит из спящего режима будучи отключенным от док-станции. В такой момент можно подключиться по SSH и сделать перезагрузку или попытаться переключиться в консоль и затем обратно в иксы. Иногда последнее помогает, но не всегда. Не помню конда это началось, но из-за нехватки времени и спонтанности ошибки решение откладывалось до лучших времен. Сегодня воспроизвелось еще раз и пора с этим разобраться.

Подключился по SSH и первым делом попробовал вывести список подключенных мониторов через xrandr (сначала нужно вытащить значение XAUTHORITY и для этого у меня есть скриптик grabenv)

$ eval $(grabenv xfdesktop)
$ xrandr -q

но вместо вывода списка xrandr завис а в лог сыплются ошибки вида

[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CRTC:55:pipe B] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CRTC:69:pipe C] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CONNECTOR:96:DP-2] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [PLANE:42:plane 1B] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [PLANE:56:plane 1C] flip_done timed out
------------[ cut here ]------------
vblank wait timed out on crtc 2
WARNING: CPU: 2 PID: 1011 at drivers/gpu/drm/drm_vblank.c:1092 drm_wait_one_vblank+0x15a/0x170 [drm]
Modules linked in: rfcomm xt_nat xt_tcpudp veth xt_conntrack ipt_MASQUERADE nf_conntrack_netlink xfrm_user xfrm_algo nft_counter xt_addrtype nft_compat nft_cha
 nls_cp437 videobuf2_memops btusb iwlmvm dell_smbios btrtl videobuf2_v4l2 vfat snd_hwdep btbcm dcdbas fat intel_rapl_perf joydev btintel videobuf2_common dell_
 x_tables autofs4 ext4 crc16 mbcache jbd2 crc32c_generic fscrypto ecb algif_skcipher af_alg dm_crypt dm_mod hid_generic usbhid hid crct10dif_pclmul crc32_pclmu
CPU: 2 PID: 1011 Comm: Xorg Tainted: G        W  OE     4.19.0-10-amd64 #1 Debian 4.19.132-1
Hardware name: Dell Inc. Latitude E7270/0K4CNR, BIOS 1.22.8 10/08/2019
RIP: 0010:drm_wait_one_vblank+0x15a/0x170 [drm]
Code: e9 0f 0b e9 39 ff ff ff 48 89 e6 4c 89 f7 e8 0d 00 38 e9 45 85 e4 0f 85 1b ff ff ff 89 ee 48 c7 c7 50 99 16 c0 e8 f0 69 33 e9 <0f> 0b e9 06 ff ff ff e8 d
RSP: 0018:ffffbe6482e63a60 EFLAGS: 00010286
RAX: 0000000000000000 RBX: ffff9f1c779a0000 RCX: 0000000000000006
RDX: 0000000000000007 RSI: 0000000000000086 RDI: ffff9f1c85b166b0
RBP: 0000000000000002 R08: 0000000000000521 R09: 0000000000000004
R10: 0000000000000000 R11: 0000000000000001 R12: 0000000000000000
R13: 0000000000001735 R14: ffff9f1c7821eaf8 R15: ffff9f1c7ee1d800
FS:  00007fd8691cff00(0000) GS:ffff9f1c85b00000(0000) knlGS:0000000000000000
CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
CR2: 00007f03580140f8 CR3: 000000023aaa2005 CR4: 00000000003606e0
DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
Call Trace:
 ? finish_wait+0x80/0x80
 skl_update_crtcs+0x1e5/0x320 [i915]
 ? __finish_swait+0x31/0x50
 intel_atomic_commit_tail+0x35d/0xd40 [i915]
 intel_atomic_commit+0x2a7/0x2e0 [i915]
 ? drm_mode_getcrtc+0x180/0x180 [drm]
 drm_atomic_helper_set_config+0x75/0x80 [drm_kms_helper]
 drm_mode_setcrtc+0x18d/0x6d0 [drm]
 ? unix_stream_recvmsg+0x53/0x70
 ? drm_mode_getcrtc+0x180/0x180 [drm]
 drm_ioctl_kernel+0xa1/0xf0 [drm]
 drm_ioctl+0x205/0x3a0 [drm]
 ? drm_mode_getcrtc+0x180/0x180 [drm]
 ? hrtimer_start_range_ns+0x1b7/0x2c0
 do_vfs_ioctl+0xa4/0x630
 ? __sys_recvmsg+0x83/0xa0
 ksys_ioctl+0x60/0x90
 __x64_sys_ioctl+0x16/0x20
 do_syscall_64+0x53/0x110
 entry_SYSCALL_64_after_hwframe+0x44/0xa9
RIP: 0033:0x7fd8698ff427
Code: 00 00 90 48 8b 05 69 aa 0c 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 c
RSP: 002b:00007fff7d0aa338 EFLAGS: 00003246 ORIG_RAX: 0000000000000010
RAX: ffffffffffffffda RBX: 0000000000000008 RCX: 00007fd8698ff427
RDX: 00007fff7d0aa370 RSI: 00000000c06864a2 RDI: 000000000000000d
RBP: 00007fff7d0aa370 R08: 000000000000005a R09: 00007fd8681c4000
R10: 0000000000000000 R11: 0000000000003246 R12: 00000000c06864a2
R13: 000000000000000d R14: 00007fd8681c4000 R15: 0000000000000000
---[ end trace d3629140e770685d ]---
[drm:drm_atomic_helper_wait_for_flip_done [drm_kms_helper]] *ERROR* [CRTC:69:pipe C] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CRTC:69:pipe C] flip_done timed out
[drm:drm_atomic_helper_wait_for_flip_done [drm_kms_helper]] *ERROR* [CRTC:69:pipe C] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CRTC:69:pipe C] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [CONNECTOR:98:DP-3] flip_done timed out
[drm:drm_atomic_helper_wait_for_dependencies [drm_kms_helper]] *ERROR* [PLANE:56:plane 1C] flip_done timed out

Поиск по багтрекеру вывел на ошибку #93782 ([i9xx TV][BISECT] vblank wait timeout on crtc), которую вроде исправили начиная с ядер 5.x. Чтобы проверить это нужно установить ядро из бэкпортов

$ sudo apt-get update
$ sudo apt-get install -t buster-backports linux-image-amd64 linux-headers-amd64 firmware-misc-nonfree
$ sudo reboot

После нескольких циклов hibernate ошибка не воспроизвелась - посмотрю как будет дальше.

Комментариев нет:

Отправить комментарий