AMDGPU
AMDGPU 是 Graphics Core Next 系列 AMD Radeon 图形卡的开源图形驱动程序。
选择正确的驱动[编辑 | 编辑源代码]
请根据您的显卡,参考Xorg#AMD选择合适的显卡驱动。目前驱动支持从 Southern Islands (SI) 到最新的显卡,而AMD没有计划支持 GCN 架构之前的显卡。如果您使用的是 AMD 不支持的显卡,可以选择使用开源的 ATI 驱动。
安装[编辑 | 编辑源代码]
安装这个mesa包 软件包,它提供用于3D加速的DRI驱动程序。
- 对于32位程序,请从multilib仓库中安装lib32-mesa包软件包以获得支持。
- 对于 DDX 驱动支持(可提供对Xorg的2D加速),可以安装xf86-video-amdgpu包 软件包。
- 对于 Vulkan 支持:
- 首先尝试仅安装vulkan-radeon包驱动:尽管vulkan-driver 提供的第一个选择不是它(因为可选按照字母顺序排序),该驱动解决了一些amdvlk包经常被报告的问题。
- 当安装amdvlk包后,会作为默认vulkan驱动。如果需要同时安装两个驱动(比如存在问题),参见Vulkan#通过环境变量选择
- 对应安装的原生驱动,可选择性安装 lib32-vulkan-radeon包 或 lib32-amdvlk包 软件包来获得32位应用程序支持。
想要开启硬件视频加速,可以安装libva-mesa-driver包和lib32-libva-mesa-driver包软件包来支持 VA-API,安装mesa-vdpau包和lib32-mesa-vdpau包软件包支持VDPAU。
实验版本[编辑 | 编辑源代码]
对于某些用户来说使用 mesa 的上游实验构建可能是值得的。
安装 mesa-gitAUR 软件包,它提供用于3D加速的DRI驱动程序。
- 对于32位程序支持,请从 AUR 或者 mesa-git 仓库安装 lib32-mesa-gitAUR
- 对于 DDX 驱动支持(可提供对Xorg的2D加速),安装xf86-video-amdgpu-gitAUR软件包。
- 如果您使用 mesa-git 仓库并且要启用 Vulkan 支持,请安装 vulkan-radeon-git 软件包。可选安装 lib32-vulkan-radeon-git 来支持32位应用程序。如果您用的是来自 AUR 的 mesa-gitAUR 软件包,则不需要进行该操作。
开启 Southern Islands (SI) 和 Sea Islands (CIK) 支持[编辑 | 编辑源代码]
linux包 软件包 可以让 AMDGPU 支持 the Southern Islands(HD 7000 系列,也被称作SI,比如 GCN1)和 Sea Islands (HD 8000 系列,也被称作CIK,比如 GCN2)显卡。amdgpu
内核驱动程序需要在radeon之前加载。可以通过运行lspci -k
来检查加载了哪个内核驱动程序。示例输出如下:
$ lspci -k | grep -A 3 -E "(VGA|3D)"
01:00.0 VGA compatible controller: Advanced Micro Devices, Inc. [AMD/ATI] Curacao PRO [Radeon R7 370 / R9 270/370 OEM] Subsystem: Gigabyte Technology Co., Ltd Device 226c Kernel driver in use: amdgpu Kernel modules: radeon, amdgpu
如果 amdgpu
驱动没有被加载使用,可以跟着下面的内容进行处理。
加载 amdgpu 内核驱动[编辑 | 编辑源代码]
amdgpu
和 radeon
两个模块都需要设置的内核参数是 cik_support=
和 si_support=
。
它们需要在内核参数或 modprobe 配置文件中进行设置,具体参数取决于显卡的 GCN 版本。
如果不确定您拥有的是哪个版本的显卡,那么也可以同时使用这两个参数。
[..] amdgpu 0000:01:00.0: Use radeon.cik_support=0 amdgpu.cik_support=1 to override
.在内核命令行中设置内核模块参数[编辑 | 编辑源代码]
设置以下内核参数之一:
- Southern Islands (SI):
radeon.si_support=0 amdgpu.si_support=1
- Sea Islands (CIK):
radeon.cik_support=0 amdgpu.cik_support=1
指定正确的模块加载顺序[编辑 | 编辑源代码]
当内核启用 AMDGPU 对 SI/CIK 显卡的支持时,radeon驱动可能会在amdgpu
驱动之前加载。
确保amdgpu
在Mkinitcpio#MODULES数组中被设置为第一个模块,例如MODULES=(amdgpu radeon)
。
设置内核参数[编辑 | 编辑源代码]
对于 Southern Islands (SI) 使用 si_support=1
内核参数,对于 Sea Islands (CIK) 使用 cik_support=1
:
/etc/modprobe.d/amdgpu.conf
options amdgpu si_support=1 options amdgpu cik_support=1
/etc/modprobe.d/radeon.conf
options radeon si_support=0 options radeon cik_support=0
确保 modconf
添加到 HOOKS
数组中在 /etc/mkinitcpio.conf
和 Mkinitcpio#创建和启用镜像。
编译支持 amdgpu 驱动的内核[编辑 | 编辑源代码]
在构建或者编译内核的时候,需要在配置中设置 CONFIG_DRM_AMDGPU_SI=Y
和/或者 CONFIG_DRM_AMDGPU_CIK=Y
。
在系统启动时候完全禁用 radeon 内核驱动模块[编辑 | 编辑源代码]
内核可能仍会根据涉及的具体图形芯片探测并加载 radeon 模块,但在确认 amdgpu 正常工作后,radeon 模块就不需要加载了。 在每个步骤之间重新启动以确认它在移动到下一步之前有效:
- 在内核命令行添加模块参数以确保
amdgpu
按预期工作, - 使用
MODULES=(amdgpu)
mkinitcpio 方法但不要将radeon
添加到配置中, - 在登录桌面后测试
modprobe -r radeon
命令确保能够在卸载radeon
内核模块后不影响系统图形界面的运行, - 将
radeon
模块列入黑名单,以免在第二阶段启动期间被内核探测:
/etc/modprobe.d/radeon.conf
blacklist radeon
当上面的配置生效之后,命令 lsmod
和 dmesg
的输出现在应该只会显示 amdgpu 驱动模块被加载的消息,不会存在 radeon 驱动模块的消息。系统中的 /sys/module/radeon
目录应该也不存在。如果存在,则说明配置没有生效,radeon 驱动模块仍然被系统加载了。
ACO编译器[编辑 | 编辑源代码]
ACO编译器是一个由 Valve Corporation开发的开源着色器(shader)编译器,可直接与LLVM编译器、AMDVLK 驱动程序以及Windows 10竞争。与 LLVM 和 AMDVLK 相比,它提供更短的编译时间,并且在玩游戏时表现更好。
一些基准性能测试可以在GitHub和 Phoronix (1) (2) (3)中看到。
加载[编辑 | 编辑源代码]
应该会在系统启动时自动加载。
如果没有自动加载:
- 如果需要的话,确保 #开启 Southern Islands (SI) and Sea Islands (CIK) 支持。
- 确保你已经安装最新的 linux-firmware包 软件包。
- 确保你没有将
nomodeset
或vga=
作为内核参数,因为amdgpu
需要内核级显示模式设置。 - 确保你没有禁用
amdgpu
通过使用内核模块黑名单。
尽管驱动有可能自动加载,但是加载可能会发生在 X 服务器需要它的时间点之后。这种情况下请参考内核级显示模式设置#KMS 早启动。
Xorg 配置[编辑 | 编辑源代码]
Xorg 会自动加载驱动程序,并且使用显示器的 EDID 来设置原始分辨率。只有在调整驱动程序时才需要配置。
如果你想手动配置,新建 /etc/X11/xorg.conf.d/20-amdgpu.conf
文件,并在其中添加以下内容:
/etc/X11/xorg.conf.d/20-amdgpu.conf
Section "OutputClass" Identifier "AMD" MatchDriver "amdgpu" Driver "amdgpu" EndSection
使用此部分配置,您可以启用功能并调整驱动程序设置,请在设置驱动程序选项之前先查看 amdgpu(4)。
无撕裂渲染[编辑 | 编辑源代码]
TearFree使用硬件翻页机制控制撕裂预防。默认情况下,如果旋转画面输出、使用RandR变换和RandR 1.4 从属输出时,TearFree会被启用,其他情况下默认关闭。你可以通过指定true
或false
来控制此配置保持启用/关闭:
Option "TearFree" "true"
DRI 级别[编辑 | 编辑源代码]
DRI 设置要启用的最大 DRI 级别。DRI2 的有效值为“2”,DRI3 的有效值为“3”。如果 Xorg 版本 >= 1.18.3,则 DRI3 的默认值为“3”,否则使用 DRI2:
Option "DRI" "3"
可变刷新率[编辑 | 编辑源代码]
参考可变刷新率。
10-bit 色深[编辑 | 编辑源代码]
较新的 AMD 卡支持 10bpc 颜色,但默认为 24 位颜色,必须明确启用 30 位颜色。 如果应用程序也支持,启用它可以减少渐变中的可见条带/伪影。 要检查您的显示器是否支持它,请在您的 Xorg 日志文件中搜索“EDID”(例如 /var/log/Xorg.0.log
或 ~/ .local/share/xorg/Xorg.0.log
):
[ 336.695] (II) AMDGPU(0): EDID for output DisplayPort-0 [ 336.695] (II) AMDGPU(0): EDID for output DisplayPort-1 [ 336.695] (II) AMDGPU(0): Manufacturer: DEL Model: a0ec Serial#: 123456789 [ 336.695] (II) AMDGPU(0): Year: 2018 Week: 23 [ 336.695] (II) AMDGPU(0): EDID Version: 1.4 [ 336.695] (II) AMDGPU(0): Digital Display Input [ 336.695] (II) AMDGPU(0): 10 bits per channel
要检查它当前是否启用可以通过搜索“Depth”:
[ 336.618] (**) AMDGPU(0): Depth 30, (--) framebuffer bpp 32 [ 336.618] (II) AMDGPU(0): Pixel depth = 30 bits stored in 4 bytes (32 bpp pixmaps)
使用默认配置,log 会显示 depth 为 24,并且 24 位色彩存储在 4 个字节中。
要检查 10 bits色深是否工作,请退出 Xorg(如果它正在运行)并运行 Xorg -retro
这将显示黑白网格,然后按 Ctrl-Alt-F1
和 { {ic|Ctrl-C}} 退出 X,然后运行 Xorg -depth 30 -retro
。 如果这些命令能正常执行,那么就说明10位色深生效了。
要通过 startx
以 10 位色深启动,请使用 startx -- -depth 30
。 要永久启用它,请添加到(如果没有指定文件则新建):
/etc/X11/xorg.conf.d/20-amdgpu.conf
Section "Screen" Identifier "asdf" DefaultDepth 30 EndSection
降低输出延迟[编辑 | 编辑源代码]
如果您想最大程度地减少延迟,您可以禁用翻页(page fliping)和无撕裂(tear free):
/etc/X11/xorg.conf.d/20-amdgpu.conf
Section "OutputClass" Identifier "AMD" MatchDriver "amdgpu" Driver "amdgpu" Option "EnablePageFlip" "off" Option "TearFree" "false" EndSection
参考游戏#降低_DRI_延迟来降低显示延迟。
特性[编辑 | 编辑源代码]
视频加速[编辑 | 编辑源代码]
参考硬件视频加速.
性能监控[编辑 | 编辑源代码]
GPU性能监控通常用于检查温度以及 GPU 的 P-states。
命令行界面[编辑 | 编辑源代码]
- amdgpu_top — 显示AMDGPU使用率的工具
- nvtop — AMD、Intel 和 NVIDIA 的 GPU 进程监控
- radeontop — GPU 利用率查看器,包括总活动百分比和单个块
图形用户界面[编辑 | 编辑源代码]
- amdgpu_top — 显示AMDGPU使用率的工具
- AmdGuid — 完全用Rust编写的一个基本的图形用户界面风扇控制工具
- TuxClocker — Qt5监控和超频工具。
手动[编辑 | 编辑源代码]
检查GPU的P-states,执行:
$ cat /sys/class/drm/card0/device/pp_od_clk_voltage
监控GPU,执行:
# watch -n 0.5 cat /sys/kernel/debug/dri/0/amdgpu_pm_info
检查GPU利用率,执行:
$ cat /sys/class/drm/card0/device/gpu_busy_percent
检查GPU频率,执行:
$ cat /sys/class/drm/card0/device/pp_dpm_sclk
检查GPU温度,执行:
$ cat /sys/class/drm/card0/device/hwmon/hwmon*/temp1_input
检查显存频率,执行:
$ cat /sys/class/drm/card0/device/pp_dpm_mclk
检查显存占用,执行:
$ cat /sys/class/drm/card0/device/mem_info_vram_used
检查显存大小,执行:
$ cat /sys/class/drm/card0/device/mem_info_vram_total
超频[编辑 | 编辑源代码]
从 Linux 4.17 开始, 只要开启了相关功能,就可以通过 /sys/class/drm/card0/device/pp_od_clk_voltage
调整显卡的频率和电压。
启动参数[编辑 | 编辑源代码]
需要通过附加内核参数 amdgpu.ppfeaturemask=0xffffffff
来解锁在 sysfs 中对其的访问限制。
并非所有比特位都有定义,随着时间的推移可能会添加新功能。设置所有 32 位可能会(在将来的更新中)启用不稳定的功能,这些功能可能会导致屏幕闪烁或无法从挂起中恢复等问题。结合默认的 ppfeaturemask 设置 PP_OVERDRIVE_MASK 位 0x4000 应该就足够了。 要为系统计算一个合理的参数,可以执行:
$ printf 'amdgpu.ppfeaturemask=0x%x\n' "$(($(cat /sys/module/amdgpu/parameters/ppfeaturemask) | 0x4000))"
手动(默认)[编辑 | 编辑源代码]
/sys/class/drm/...
之类的路径只是符号链接,可能会在重新启动之间发生变化。永久位置可以在 /sys/devices/
中找到,例如 /sys/devices/pci0000:00/0000:00:01.0/0000:01:00.0/
。想要得到可靠的结果可能要相应地调整命令。要深入了解所有可能的选项,请参阅amdgpu功耗与发热控制内核文档。
可以为最大 P-state 7 设置 GPU 核心频率, 以 Polaris GPU 为例可以执行下面的命令设置为 1209MHz 频率和 900mV 电压:
# echo "s 7 1209 900" > /sys/class/drm/card0/device/pp_od_clk_voltage
同样的操作可以应用于 VRAM,例如 Polaris 5xx 系列卡上的最大 P-state 2:
# echo "m 2 1850 850" > /sys/class/drm/card0/device/pp_od_clk_voltage
执行下面的命令让修改生效:
# echo "c" > /sys/class/drm/card0/device/pp_od_clk_voltage
要检查超频是否成功,可以读取 3D 负载下的时钟和电压:
# watch -n 0.5 cat /sys/kernel/debug/dri/0/amdgpu_pm_info
可以使用下面的命令重置为默认设置:
# echo "r" > /sys/class/drm/card0/device/pp_od_clk_voltage
如果要避免深度节能 P-states 引起的闪烁、伪影和卡顿之类的问题,也可以禁止驱动程序切换到某些 P-states。要让显卡强制使用最高的 VRAM P-state,同时允许 GPU 本身以较低的频率运行,首先找到最高的可用P-state,然后设置:
# cat /sys/class/drm/card0/device/pp_dpm_mclk
0: 96Mhz * 1: 456Mhz 2: 675Mhz 3: 1000Mhz
# echo "manual" > /sys/class/drm/card0/device/power_dpm_force_performance_level # echo "3" > /sys/class/drm/card0/device/pp_dpm_mclk
仅允许三个最高的 GPU pstates:
# echo "5 6 7" > /sys/class/drm/card0/device/pp_dpm_sclk
执行下面命令可以限制GPU的极限功耗(参数以 50 瓦为例):
# echo 50000000 > /sys/class/drm/card0/device/hwmon/hwmon0/power1_cap
辅助工具[编辑 | 编辑源代码]
如果不想(或不敢)完全通过手动超频 GPU,社区提供了一些超频工具来帮助超频和监控 AMD 显卡。
命令行工具[编辑 | 编辑源代码]
- amdgpu-clocks — 用于监控和设置 AMD GPU 自定义电源状态的脚本。它还提供了一个 Systemd 服务,可以在系统启动时自动置。
图形界面工具[编辑 | 编辑源代码]
- TuxClocker — Qt5 监控和超频工具。
- CoreCtrl — 一个 GUI 超频工具,具有类似 WattMan 的 UI,支持每个应用程序配置文件。
- LACT — 一个GTK工具,可显示信息和控制你的AMD GPU。
开机启动[编辑 | 编辑源代码]
如果希望设置在开机时自动应用,可以参考这个 Reddit 帖子来实现开机时自动配置和启用设定。
电源配置[编辑 | 编辑源代码]
AMDGPU 通过电源配置提供多种优化,最常用的一种是 OpenCL 密集型应用程序的计算模式。下面的命令可以列出所有的可用电源配置:
cat /sys/class/drm/card0/device/pp_power_profile_mode
NUM MODE_NAME SCLK_UP_HYST SCLK_DOWN_HYST SCLK_ACTIVE_LEVEL MCLK_UP_HYST MCLK_DOWN_HYST MCLK_ACTIVE_LEVEL 0 BOOTUP_DEFAULT: - - - - - - 1 3D_FULL_SCREEN: 0 100 30 0 100 10 2 POWER_SAVING: 10 0 30 - - - 3 VIDEO: - - - 10 16 31 4 VR: 0 11 50 0 100 10 5 COMPUTE *: 0 5 30 10 60 25 6 CUSTOM: - - - - - -
card0
标识机器中的特定 GPU,如果有多个 GPU,要确保找到正确的路径。要使用特定的电源配置文件,首先应该启用对它们的手动控制:
# echo "manual" > /sys/class/drm/card0/device/power_dpm_force_performance_level
然后通过写入与其关联的 NUM 字段来选择电源配置文件,例如下面的命令可以启用计算运行(COMPUTE):
# echo "5" > /sys/class/drm/card0/device/pp_power_profile_mode
启用 GPU 显示缩放[编辑 | 编辑源代码]
为了避免使用显示器内置的缩放器,而要使用 GPU 自己的缩放器,在不使用显示器的原始分辨率时,可以用下面的命令实现:
$ xrandr --output "<output>" --set "scaling mode" "<scaling mode>"
"scaling mode"
可以设置的值有: None, Full, Center, Full aspect
- 要显示可用的输出和设置,执行:
$ xrandr --prop
- 要为每个有效显示输出都设置
scaling mode = Full aspect
,使用下面的命令:
$ for output in $(xrandr --prop | grep -E -o -i "^[A-Z\-]+-[0-9]+"); do xrandr --output "$output" --set "scaling mode" "Full aspect"; done
排除故障[编辑 | 编辑源代码]
模块参数[编辑 | 编辑源代码]
amdgpu模块含有一些使用掩码的配置参数(modinfo amdgpu | grep mask
),这些参数文档请参阅内核源码
Xorg 或应用程序无法启动[编辑 | 编辑源代码]
- "(EE) AMDGPU(0): [DRI2] DRI2SwapBuffers: drawable has no back or front?" error after opening glxgears, can open Xorg server but OpenGL apps crash.
- "(EE) AMDGPU(0): Given depth (32) is not supported by amdgpu driver" error, Xorg won't start.
在 Xorg 下将屏幕颜色深度设置为 16 或 32 会导致异常或崩溃。为避免这种情况,可以通过往配置的Screen区块添加设置来使用标准的 24 位屏幕颜色深度:
/etc/X11/xorg.conf.d/10-screen.conf
Section "Screen" Identifier "Screen" DefaultDepth 24 SubSection "Display" Depth 24 EndSubSection EndSection
屏幕伪影和频率问题[编辑 | 编辑源代码]
由于 GPU 时钟速度的管理方式存在问题,动态电源管理可能会在显示器运行高刷新率(120+hz)时导致屏幕伪影 .org/show_bug.cgi?id=96868[1]。
一个规避的办法 [2] 是手动将 /sys/class/drm/card0/device/power_dpm_force_performance_level
设置为 high
或 low
要使设置持久化生效,可以创建一个 udev 规则:
/etc/udev/rules.d/30-amdgpu-pm.rules
KERNEL=="card0", SUBSYSTEM=="drm", DRIVERS=="amdgpu", ATTR{device/power_dpm_force_performance_level}="high"
执行下面的命令检查 KERNEL 参数名称:
$ udevadm info --attribute-walk /sys/class/drm/card0 | grep "KERNEL="
另一个图形界面的解决方案 [3]是用 radeon-profile-gitAUR 和 radeon-profile-daemon-gitAUR 来管理 power_dpm。
Chromium 伪影[编辑 | 编辑源代码]
如果在使用 Chromium 时看到伪影,可以尝试强制使用基于 vulkan 的后端。在 chrome://flags
中启用 #ignore-gpu-blocklist
和 #enable-vulkan
。
R9 390 系列性能不佳或不稳定[编辑 | 编辑源代码]
如果在使用 AMD R9 390 系列显卡时遇到问题 [4],可以在内核参数中设置radeon.cik_support=0 radeon.si_support=0 amdgpu .cik_support=1 amdgpu.si_support=1 amdgpu.dpm=1 amdgpu.dc=1
来强制使用 amdgpu 驱动模块而不是 radeon 驱动模块。
如果还不起作用,请尝试通过在内核参数中设置:radeon.cik_support=0 radeon.si_support=0 amdgpu.cik_support=1 amdgpu.si_support=1
来禁用动态电源管理(DPM)。
因内核错误"[drm] IP block:gmc_v8_0 is hung!"画面冻结[编辑 | 编辑源代码]
如果在执行 GPU 密集型任务期间遇到冻结和内核崩溃,并出现内核错误"[drm] IP block:gmc_v8_0 is hung!" [5]时,一个规避的方法是在内核参数中设置 amdgpu.vm_update_mode=3
来强制使用 CPU 完成 GPUVM 页面表更新。 这里列出了这个方法的缺点 [6]。
光标损坏[编辑 | 编辑源代码]
如果遇到鼠标光标有时无法正确显示的问题,可以在 /etc/X11/xorg.conf.d/20-amdgpu.conf
配置文件的 "OutputClass""
部分设置 Option "SWCursor" "True"
。Wayland下设置环境变量KWIN_FORCE_SW_CURSOR=1
。
如果在使用 xrandr
进行缩放时光标闪烁或消失,可以通过设置 TearFree
属性来修复它:xrandr --output HDMI-A-0 --set TearFree on
。
在KDE中遇到白屏或闪烁[编辑 | 编辑源代码]
当改变分辨率或连接外接显示器时屏幕出现闪烁或白屏,在内核参数中加入amdgpu.sg_display=0
。
在 Vega 显卡上玩游戏时系统冻结或崩溃[编辑 | 编辑源代码]
由于 GPU 核心频率的管理方式存在问题,使用显卡驱动的动态电源管理可能会导致系统在玩游戏时完全冻结。[8] 一个规避方法是禁用动态电源管理, 更多细节可以参考 ATI#动态电源管理。
火狐浏览器 WebRenderer 损坏[编辑 | 编辑源代码]
当用户强制启用 WebRenderer 时,可能会出现伪影和其他异常(例如无法选择扩展选项)。解决方法是回退到 OpenGL 合成。
两倍速或花栗鼠(chipmunk)音频,或连接 4K@60Hz 设备时无音频[编辑 | 编辑源代码]
这有时是由 AMDGPU 设备和通过 HDMI 连接的 4K 显示器之间的通信问题引起的。一种可能的规避方法是通过显示器的内置设置启用 HDR 或“超高清深色”。在许多基于 Android 的电视上,这对应着将相关选项设置为“标准”(Standard)而不是“最佳”(Optimal)。
独立显卡的电源管理/动态重新激活问题[编辑 | 编辑源代码]
如果遇到内核驱动已经加载,但游戏时独立显卡不可用或在使用时独立显卡被禁用(类似于 [9]) 的问题,可以通过设置内核参数 amdgpu.runpm=0
来防止独显在运行时动态断电。
kfd: amdgpu: TOPAZ not supported in kfd[编辑 | 编辑源代码]
在系统日志或内核消息密钥环中打印危急级别的错误消息
kfd: amdgpu: TOPAZ not supported in kfd
如果没有使用 Radeon Open Compute 的计划,可以安全的忽略这个问题。因为旧显卡不支持 TOPAZ。[10] [11]
MCLK锁定在最大(1000MHz)或最小(96MHz)频率导致的高待机功耗或低游戏性能问题(6.4内核)[编辑 | 编辑源代码]
在高分辨率和刷新率的设置下,MCLK(vram,显存频率)可能会锁定在最高值(1000MHz)[12] [13] ,造成GPU待机功耗过高。使用Linux 6.4.x内核,MCLK锁定在最低频率(96MHz)影响游戏性能[14] [15]。
这可能是因为显示器没有为受影响的分辨率和刷新率设置使用一个低V-Blank值的协调视频时序(Coordinated Video Timings, CVT),参考这篇内容来解决。
未能挂起(suspend)到内存[编辑 | 编辑源代码]
当系统进入S3状态后,amdgpu
内核模块会尝试缓存显存数据到内存中,以避免显存不能充分刷新,显存中的数据老化导致数据丢失。
如果你使用了大量显存而空闲内存不足,这会导致挂起失败。因为IO子系统可能会在此之前挂起,不论是否有足够的swap空间该问题都可能发生。
你可能会看到类似的消息:
kernel: systemd-sleep: page allocation failure: order:0, mode:0x100c02(GFP_NOIO|__GFP_HIGHMEM|__GFP_HARDWALL), nodemask=(null),cpuset=/,mems_allowed=0 kernel: Call Trace: kernel: <TASK> kernel: dump_stack_lvl+0x47/0x60 kernel: warn_alloc+0x165/0x1e0 kernel: __alloc_pages_slowpath.constprop.0+0xd7d/0xde0 kernel: __alloc_pages+0x32d/0x350 kernel: ttm_pool_alloc+0x19f/0x600 [ttm 0bd92a9d9dccc3a4f19554535860aaeda76eb4f4]
通过一个用户空间服务可解决该问题,该服务能够在系统挂起前将足够的内存交换到SWAP,确保能够申请到足够的内存用以显存缓存。
关机和挂起(suspend)失败[编辑 | 编辑源代码]
hid_sensor_*_3d这类内核模块能够造成系统在启动、关机和挂起时死锁。进程列表里将会显示了多个udev-worker
实例,导致系统睡眠时冻结。
你会看到类似消息:
kernel: PM: suspend entry (deep) kernel: Filesystems sync: 0.002 seconds kernel: Freezing user space processes kernel: Freezing user space processes failed after 20.004 seconds (1 tasks refusing to freeze, wq_busy=0): kernel: task:(udev-worker) state:D stack:0 pid:479 tgid:479 ppid:422 flags:0x00004006 kernel: Call Trace: kernel: <TASK> kernel: __schedule+0x3db/0x1520 kernel: ? srso_alias_return_thunk+0x5/0xfbef5 kernel: ? __wake_up_common+0x78/0xa0 kernel: ? srso_alias_return_thunk+0x5/0xfbef5
要解决该问题,将有问题的模块添加到黑名单中,创建配置文件如/etc/modprobe.d/blacklist-hid_sensors.conf
:
blacklist hid_sensor_accel_3d blacklist hid_sensor_gyro_3d blacklist hid_sensor_magn_3d