AMD Radeon Pro WX 4150 비디오 장치가 있는 Dell Precision 7530에서 실행되는 Xubuntu Bionic(18.04.3)에 문제가 있습니다. 최근에 AMD GPU Pro 드라이버를 설치했습니다.이 위치, 특히 파일 amdgpu-pro-19.30-934563-ubuntu-18.04.tar.xz
.
무슨 일이 일어나고 있나요?
- 암호화된 로그인 화면이 작동합니다.
- X는 노트북 디스플레이에서 잘 작동합니다
- 도크 연결 디스플레이(WD19DC 도크 사용)
작동하지 않는 것
- 노트북의 HDMI 출력
- 노트북의 Mini-DP 출력
- OpenGL
- 많은 Qt 앱(아마도 OpenGL이 손상되었기 때문일 것임)
특히 xrandr
노트북의 HDMI 및 DisplayPort 연결에 대해 알고 있지만 해당 포트에 연결할 때 아무것도 인식되지 않는다고 보고합니다.
또한 OpenGL 프레임워크 내에서는 아무것도 작동하지 않는 것 같습니다. 출력 glxinfo
:
name of display: :0.0
Error: couldn't find RGB GLX visual or fbconfig
출력 glxgears
:
Error: couldn't get an RGB, Double-buffered visual
디버깅 세부정보
lspci -vv
Intel 통합 그래픽 및 AMD 그래픽 표시 관련 라인 :
00:02.0 VGA compatible controller: Intel Corporation Device 3e9b (prog-if 00 [VGA controller])
Subsystem: Dell Device 0831
Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx+
Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- <TAbort- <MAbort- >SERR- <PERR- INTx-
Latency: 0, Cache Line Size: 64 bytes
Interrupt: pin A routed to IRQ 130
Region 0: Memory at b3000000 (64-bit, non-prefetchable) [size=16M]
Region 2: Memory at 60000000 (64-bit, prefetchable) [size=256M]
Region 4: I/O ports at 4000 [size=64]
[virtual] Expansion ROM at 000c0000 [disabled] [size=128K]
Capabilities: <access denied>
Kernel driver in use: i915
Kernel modules: i915
01:00.0 VGA compatible controller: Advanced Micro Devices, Inc. [AMD/ATI] Baffin [Radeon Pro WX 4130/4150] (prog-if 00 [VGA controller])
Subsystem: Dell Baffin [Polaris11]
Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx+
Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- <TAbort- <MAbort- >SERR- <PERR- INTx-
Latency: 0, Cache Line Size: 64 bytes
Interrupt: pin A routed to IRQ 143
Region 0: Memory at 4100000000 (64-bit, prefetchable) [size=4G]
Region 2: Memory at 4080000000 (64-bit, prefetchable) [size=2M]
Region 4: I/O ports at 3000 [size=256]
Region 5: Memory at b4200000 (32-bit, non-prefetchable) [size=256K]
Expansion ROM at b4240000 [disabled] [size=128K]
Capabilities: <access denied>
Kernel driver in use: amdgpu
Kernel modules: amdgpu
출력 dmesg | grep -i amdgpu
:
[ 2.094881] [drm] amdgpu kernel modesetting enabled.
[ 2.094883] [drm] amdgpu version: 5.0.73.19.30
[ 2.097461] amdgpu 0000:01:00.0: enabling device (0000 -> 0003)
[ 2.475623] amdgpu 0000:01:00.0: BAR 2: releasing [mem 0x80000000-0x801fffff 64bit pref]
[ 2.475624] amdgpu 0000:01:00.0: BAR 0: releasing [mem 0x70000000-0x7fffffff 64bit pref]
[ 2.475646] amdgpu 0000:01:00.0: BAR 0: assigned [mem 0x4100000000-0x41ffffffff 64bit pref]
[ 2.475651] amdgpu 0000:01:00.0: BAR 2: assigned [mem 0x4080000000-0x40801fffff 64bit pref]
[ 2.475674] amdgpu 0000:01:00.0: VRAM: 4096M 0x000000F400000000 - 0x000000F4FFFFFFFF (4096M used)
[ 2.475675] amdgpu 0000:01:00.0: GART: 256M 0x000000FF00000000 - 0x000000FF0FFFFFFF
[ 2.475868] [drm] amdgpu: 4096M of VRAM memory ready
[ 2.475869] [drm] amdgpu: 15796M of GTT memory ready.
[ 2.477995] amdgpu: [powerplay] hwmgr_sw_init smu backed is polaris10_smu
[ 3.151808] [drm:hwss_edp_wait_for_hpd_ready [amdgpu]] *ERROR* hwss_edp_wait_for_hpd_ready: wait timed out!
[ 3.755912] [drm:hwss_edp_wait_for_hpd_ready [amdgpu]] *ERROR* hwss_edp_wait_for_hpd_ready: wait timed out!
[ 4.177658] [drm] Initialized amdgpu 3.33.0 20150101 for 0000:01:00.0 on minor 1
[ 14.269498] amdgpu 0000:01:00.0: GPU pci config reset
[ 68.615509] [drm:hwss_edp_wait_for_hpd_ready [amdgpu]] *ERROR* hwss_edp_wait_for_hpd_ready: wait timed out!
[ 69.223488] [drm:hwss_edp_wait_for_hpd_ready [amdgpu]] *ERROR* hwss_edp_wait_for_hpd_ready: wait timed out!
출력은 다음과 같습니다 grep -i "glx\|amdgpu" Xorg.0.log
.
[ 70.624] (**) ModulePath set to "/opt/amdgpu-pro/lib/xorg/modules,/opt/amdgpu/lib/xorg/modules,/usr/lib/xorg/modules"
[ 70.643] (II) LoadModule: "glx"
[ 70.644] (II) Loading /opt/amdgpu-pro/lib/xorg/modules/extensions/libglx.so
[ 70.651] (II) Module glx: vendor="X.Org Foundation"
[ 70.651] (II) Applying OutputClass "AMDgpu" to /dev/dri/card1
[ 70.651] loading driver: amdgpu
[ 70.651] (==) Matched amdgpu as autoconfigured driver 0
[ 70.651] (II) LoadModule: "amdgpu"
[ 70.652] (II) Loading /opt/amdgpu/lib/xorg/modules/drivers/amdgpu_drv.so
[ 70.653] (II) Module amdgpu: vendor="X.Org Foundation"
[ 70.656] (II) Applying OutputClass "AMDgpu" to /dev/dri/card1
[ 70.656] loading driver: amdgpu
[ 70.656] (==) Matched amdgpu as autoconfigured driver 0
[ 70.656] (II) LoadModule: "amdgpu"
[ 70.656] (II) Loading /opt/amdgpu/lib/xorg/modules/drivers/amdgpu_drv.so
[ 70.656] (II) Module amdgpu: vendor="X.Org Foundation"
[ 70.656] (II) AMDGPU: Driver for AMD Radeon:
All GPUs supported by the amdgpu kernel driver
[ 70.675] (II) AMDGPU(G0): [KMS] Kernel modesetting enabled.
[ 71.254] (==) AMDGPU(G0): Depth 24, (--) framebuffer bpp 32
[ 71.254] (II) AMDGPU(G0): Pixel depth = 24 bits stored in 4 bytes (32 bpp pixmaps)
[ 71.254] (==) AMDGPU(G0): Default visual is TrueColor
[ 71.254] (==) AMDGPU(G0): RGB weight 888
[ 71.254] (II) AMDGPU(G0): Using 8 bits per RGB (8 bit DAC)
[ 71.254] (--) AMDGPU(G0): Chipset: "AMD Radeon (TM) Pro WX Series" (ChipID = 0x67e8)
[ 71.400] (II) AMDGPU(G0): glamor X acceleration enabled on AMD Radeon (TM) Pro WX Series
[ 71.400] (II) AMDGPU(G0): glamor detected, initialising EGL layer.
[ 71.400] (==) AMDGPU(G0): TearFree property default: auto
[ 71.400] (II) AMDGPU(G0): Output eDP-1-1 has no monitor section
[ 71.400] (II) AMDGPU(G0): Output DisplayPort-1-3 has no monitor section
[ 71.400] (II) AMDGPU(G0): Output DisplayPort-1-4 has no monitor section
[ 71.400] (II) AMDGPU(G0): Output DisplayPort-1-5 has no monitor section
[ 71.400] (II) AMDGPU(G0): Output HDMI-A-1-1 has no monitor section
[ 71.401] (II) AMDGPU(G0): EDID for output eDP-1-1
[ 71.401] (II) AMDGPU(G0): EDID for output DisplayPort-1-3
[ 71.401] (II) AMDGPU(G0): EDID for output DisplayPort-1-4
[ 71.401] (II) AMDGPU(G0): EDID for output DisplayPort-1-5
[ 71.401] (II) AMDGPU(G0): EDID for output HDMI-A-1-1
[ 71.401] (II) AMDGPU(G0): mem size init: gart size :3dadf1000 vram size: s:ffad1000 visible:bfc1cc00
[ 71.401] (II) AMDGPU(G0): Video RAM: 4188996 kByte
[ 71.401] (==) AMDGPU(G0): DPI set to (96, 96)
[ 71.401] (==) AMDGPU(G0): Using gamma correction (1.0, 1.0, 1.0)
[ 71.401] (II) AMDGPU(G0): [DRI2] Setup complete
[ 71.401] (II) AMDGPU(G0): [DRI2] DRI driver: radeonsi
[ 71.401] (II) AMDGPU(G0): [DRI2] VDPAU driver: radeonsi
[ 71.401] (II) AMDGPU(G0): Front buffer pitch: 4096 bytes
[ 71.402] (==) AMDGPU(G0): Backing store enabled
[ 71.402] (II) AMDGPU(G0): Direct rendering enabled
[ 71.451] (II) AMDGPU(G0): Use GLAMOR acceleration.
[ 71.451] (II) AMDGPU(G0): Acceleration enabled
[ 71.451] (==) AMDGPU(G0): DPMS enabled
[ 71.451] (==) AMDGPU(G0): Silken mouse enabled
[ 71.510] (II) Initializing extension GLX
[ 71.510] (II) AIGLX: Screen 0 is not DRI2 capable
[ 71.510] (EE) AIGLX: reverting to software rendering
[ 71.510] (II) GLX: no usable GL providers found for screen 0
마지막 세 줄은 잠재적인 문제를 나타냅니다.
많은 Qt 애플리케이션이 시작하려고 하면세그폴트아마도 OpenGL이 작동할 것으로 기대하기 때문일 것 입니다 dmesg
. 손상된 앱의 예: Wireshark, QDirStat 등. 아래는 Wireshark가 시작을 시도하는 경우의 예입니다.
[ 4574.568730] wireshark[12453]: segfault at 10 ip 00007f2ebfde6530 sp 00007ffdfeb2ea70 error 4 in libdrm_amdgpu.so.1.0.0[7f2ebfdde000+c000]
콘솔 출력은 다음과 같습니다 wireshark
.
screen 0 does not appear to be DRI2 capable
screen 0 does not appear to be DRI2 capable
amdgpu_device_initialize: amdgpu_get_auth (1) failed (-1)
Segmentation fault
gdb wireshark
segfault 이후 에 생성된 역추적은 다음과 같습니다 .
(gdb) r
Starting program: /usr/bin/wireshark
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
[New Thread 0x7fffde8ad700 (LWP 14468)]
screen 0 does not appear to be DRI2 capable
screen 0 does not appear to be DRI2 capable
amdgpu_device_initialize: amdgpu_get_auth (1) failed (-1)
Thread 1 "wireshark" received signal SIGSEGV, Segmentation fault.
0x00007fffdcde6530 in amdgpu_query_info () from /opt/amdgpu/lib/x86_64-linux-gnu/libdrm_amdgpu.so.1
(gdb) bt
#0 0x00007fffdcde6530 in amdgpu_query_info () from /opt/amdgpu/lib/x86_64-linux-gnu/libdrm_amdgpu.so.1
#1 0x00007fffd607654c in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#2 0x00007fffd6081248 in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#3 0x00007fffd5e88678 in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#4 0x00007fffd5eb388f in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#5 0x00007fffd51782c5 in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#6 0x00007fffd5cd354c in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#7 0x00007fffd6073c7b in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#8 0x00007fffd5d9106e in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#9 0x00007fffd5d91576 in ?? () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#10 0x00007fffd5d94709 in eglInitialize () from /usr/lib/x86_64-linux-gnu/dri/amdgpu_dri.so
#11 0x00007fffdd87f3c4 in ?? () from /usr/lib/x86_64-linux-gnu/qt5/plugins/xcbglintegrations/libqxcb-egl-integration.so
#12 0x00007fffe2e5b369 in QXcbConnection::QXcbConnection(QXcbNativeInterface*, bool, unsigned int, char const*) () from /usr/lib/x86_64-linux-gnu/libQt5XcbQpa.so.5
#13 0x00007fffe2e5e7fe in QXcbIntegration::QXcbIntegration(QStringList const&, int&, char**) () from /usr/lib/x86_64-linux-gnu/libQt5XcbQpa.so.5
#14 0x00007fffe31242ab in ?? () from /usr/lib/x86_64-linux-gnu/qt5/plugins/platforms/libqxcb.so
#15 0x00007ffff04c3add in QPlatformIntegrationFactory::create(QString const&, QStringList const&, int&, char**, QString const&) () from /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
#16 0x00007ffff04d4922 in QGuiApplicationPrivate::createPlatformIntegration() () from /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
#17 0x00007ffff04d545d in QGuiApplicationPrivate::createEventDispatcher() () from /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
#18 0x00007fffeff20885 in QCoreApplicationPrivate::init() () from /usr/lib/x86_64-linux-gnu/libQt5Core.so.5
#19 0x00007ffff04d6eef in QGuiApplicationPrivate::init() () from /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
#20 0x00007ffff0c9c659 in QApplicationPrivate::init() () from /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5
#21 0x00005555557f3ce1 in WiresharkApplication::WiresharkApplication(int&, char**) ()
#22 0x00005555556e7574 in main ()
내가 탐구한 가능한 설명이지만 여전히 그럴 수 있습니다.
- 경쟁하는 그래픽 드라이버 파일이나 패키지가 있습니다.
- 어딘가에 구성 파일이 잘못 설정되어 있습니다.
- 다른 설치/선택적 라이브러리가 다음의 기능에 영향을 미치고 있습니다.
amdgpu
- 다른 것
나는 설치하지 않았다엔터프라이즈 버전의 드라이버Ubuntu 18.04.2만 지원하고 dkms
Linux 5 커널(지난주에 출시된 드라이버도 포함)로 빌드되지 않기 때문입니다.
통합 그래픽 바이패스가 없는 두 가지 펌웨어 수준 구성을 시도했습니다. 바이패스가 비활성화된 경우(일반 모드) Intel GPU와 AMD GPU를 모두 구동할 수 있습니다. 개별 그래픽 바이패스가 활성화되면 Intel GPU가 바이패스되고 AMD GPU만 활성화됩니다. 전환과 관련하여 여러 가지 문제가 있지만 이 페이지의 문제는 두 구성 모두에 영향을 미칩니다.
Windows 10에서는 모든 것이 잘 작동하므로 하드웨어 문제는 아닌 것 같습니다.
답변1
많은 실험(완전히 새로운 Ubuntu 및 Xubuntu 설치)을 거친 후 전환 가능한 그래픽을 완전히 비활성화하는 해결 방법을 찾았습니다. Precision 7530 펌웨어 설정에서는 전환 가능 그래픽을 끄고 개별 카드만 사용할 수 있습니다. 그렇게 하면 OpenGL 관련 오류가 사라지고 Qt 앱이 충돌합니다.
Direct Discrete 모드(인텔 칩을 활성화하지만 우회)로는 충분하지 않았습니다. 전환을 완전히 꺼야 했고, 그 시점에서 Intel VGA 장치는 더 이상 Linux에 나타나지 않습니다.
이것은 정확히 해결책은 아니지만 해결 방법이며 대안보다 낫습니다.
편집하다: 이 구성에서는 전력 사용량이 훨씬 더 나쁩니다. 배터리 수명이 절반 정도 걸립니다. Intel 칩이 활성화된 상태에서 이 기능이 올바르게 작동하는 것은 여전히 좋은 일입니다.