前言

很久之前,就给自己新买的笔记本装上了Manjaro。可惜由于笔记本是双显卡,总会有些奇奇怪怪的问题。 (参见下文题外话,关于Windows 10上双显卡的“优秀表现”) Manjaro上的问题就是,无法识别外置显示器,只能搁置。看着黑的发亮的显示器,真是十分让人恼火。 Ubuntu 上不需要修改任何设置,直接就能识别外接显示器。 后来经过一阵探索,才在Manjaro上用上了外置显示器。


背景

还是老规矩,我先介绍一下这个问题的背景。 解决方法请翻到解决方法一节。
环境:
intel 集成显卡 + Nvidia 独立显卡,目前笔记本主流配置。但 HDMI 接口实际上是与 Nvidia 显卡相连接的,默认驱动无法对 N 卡输出。
症状:

  • 无法接外接显示器,接上后无论是系统设置还是inxi -Fx都无法识别外置显示器。
  • 检查启动日志,发现虽然开机时检测到了显示器,但后面就没有继续显示了。

如果你的是外接显卡坞+显示器,这篇教程不适合你。不过有网友(感谢@sunlitforest)用另一种方法操作成功了,详情请看这里

分析问题

参照ArchWiki上面的说法),让Optimus显卡在linux里面有三种实现方法:

  1. BIOS里面禁用掉一个显卡。缺点:难以切换显卡。
  2. 用nouveau的PRIME功能。但是性能没有专有驱动好,睡眠和挂起也会出现问题。
  3. 用Bumblebee。不过Bumblebee很难支持双显示器。
  4. 用专有驱动。
  5. 用nvidia-xrun,让X服务器跑在n卡上。(貌似和1一样,但是1是硬件层面上的禁用。)

解决方法

我找到了Manjaro论坛里面的一个帖子。(作者Jonathon,是Manjaro开发团队的)
刚开始没有成功,后来在朋友的提醒下,发现原来我缺了一些步骤! 我照着这个帖子的步骤原封不动地操作,成功了。所以,接下来一定要按照步骤严格操作。
以下内容均为本人的中文翻译。原帖在此 - How To Set up PRIME with NVIDIA proprietary driver

原帖前言

如何在Optimus的笔记本上开启PRIME:

方法 优点 缺点
bumblebee(Render offload) 按需使用独立显卡,Manjaro默认配置 有一定的开销,对性能有所影响
PRIME 直接使用独立显卡,性能更强 两块显卡都一直供电,需要手动配置
optimus-manager 显卡切换更简单 暂不成熟,还在开发中
video-hybrid-intel-nvidia-440xx-prime NVIDIA 官方支持的 render offload. 在译者机器上仍有 bug,不建议用

Note:最简单的方法就是在主板设置里面禁用集成显卡,如果可以就直接禁用掉。 optimus-manager可以实现两块显卡的半自动切换,但是目前仍然不太成熟。 免责声明:NVIDIA Optimus在Linux下目前一团糟,硬件设置千差万别。所以这个教程可能有不适用之处,建议参考ArchWiki获取更多信息。

1 移除Bumblebee

如果你选择了non-free驱动,mhwd将会自动安装bumblebee。 bumblebee很碍事,所以我们得先干掉它。

  1. sudo mhwd -r pci nonfree 0300

2 安装NVIDIA驱动

  1. sudo mhwd -i pci video-nvidia-440xx

2020年3月25日注:经过本人测试,这两步操作也可以通过系统设置里面的“硬件设定”来完成。video-nvidia-440xx仍然适用于本教程

3 修改MHWD设置

mhwd会自动生成一些设置。这里我们需要重新手动配置,这样PRIME才能生效。

另起炉灶

首先要删掉/etc/X11/xorg.conf.d/90-mhwd.conf (如果你不放心可以mv嘛。) 然后新建一个文件/etc/X11/xorg.conf.d/optimus.conf

  1. Section "Module"
  2. Load "modesetting"
  3. EndSection
  4. Section "Device"
  5. Identifier "nvidia"
  6. Driver "nvidia"
  7. BusID "PCI:1:0:0"
  8. Option "AllowEmptyInitialConfiguration"
  9. EndSection

注意:BusID一栏需要根据自己的电脑配置进行修改。BusID的值是这么查询的:lspci | grep -E "VGA|3D"

禁用模块

PRIME依赖于nvidia-drm,但mhwd在默认情况下会禁用它,我们需要手动启用。 此外,为了确保nvidia驱动正常开启,我们还需要禁用其他一些模块。 所以,我们需要对/etc/modprobe.d动动手脚。
首先,我们得把mhwd自动生成的黑名单删掉。 (译者注:不放心的话,就把后缀名改掉,因为modprobe.d里面所有conf结尾的文件都会被执行) 比如这样:视情况而定,你的配置可能不同

  1. ls /etc/modprobe.d/mhwd*
  2. sudo rm /etc/modprobe.d/mhwd-gpu.conf
  3. sudo rm /etc/modprobe.d/mhwd-nvidia.conf

然后我们要新建一个黑名单,屏蔽一些其他的模块。 新建一个文件,什么名字都可以,conf结尾就行 写入:/etc/modprobe.d/nvidia.conf

  1. blacklist nouveau
  2. blacklist nvidiafb
  3. blacklist rivafb

4 开启 modeset

创建一个新文件,/etc/modprobe.d/nvidia-drm.conf

  1. options nvidia_drm modeset=1

5 设置启动脚本

我们要设置一下桌面环境的输出源。这是最难的部分,可能会花掉很长时间。 如果你现在重启,桌面环境的输出可能会有一些问题。
我们需要写一个启动脚本,让桌面环境加载的时候能够正确选择输出源。

注意,视你的具体环境(DM)执行下列的某一个步骤,不要执行所有步骤。


针对 LightDM (xfce默认) 创建一个文件,/usr/local/bin/optimus.sh

  1. #!/bin/sh
  2. xrandr --setprovideroutputsource modesetting NVIDIA-0
  3. xrandr --auto

然后按照国际惯例(hhh),让它可写可执行:chmod a+rx /usr/local/bin/optimus.sh 现在你还得把它设置为启动脚本。 编辑/etc/lightdm/lightdm.conf,然后在[Seat:* ]这一节设置 display-setup-script=/usr/local/bin/optimus.sh


针对 GDM (Gnome默认)
创建一个文件/usr/local/share/optimus.desktop

  1. [Desktop Entry]
  2. Type=Application
  3. Name=Optimus
  4. Exec=sh -c "xrandr --setprovideroutputsource modesetting NVIDIA-0; xrandr --auto"
  5. NoDisplay=true
  6. X-GNOME-Autostart-Phase=DisplayServer

(Exec处也可以替换成一个脚本,写一个就像LightDM里面一样的脚本)
然后建立连接,让它随着GDM启动。

  1. sudo ln -s /usr/local/share/optimus.desktop /usr/share/gdm/greeter/autostart/optimus.desktop
  2. sudo ln -s /usr/local/share/optimus.desktop /etc/xdg/autostart/optimus.desktop

针对 SDDM (KDE 默认)
创建一个文件:/usr/share/sddm/scripts/Xsetup

  1. #!/bin/sh
  2. xrandr --setprovideroutputsource modesetting NVIDIA-0
  3. xrandr --auto

然后用chmod让它变为可执行的文件。

6 最后的工作

译者注:如果以上的工作都已经完成,我建议你再做一步。 我当时没有做这一步,之后重启发现内核模块加载错误。 所以还是建议,编译一下内核。

  1. sudo mkinitcpio -P linux

最后重启,大功告成。

验证是否成功

如果以上你都设置正确了,当你重启之后,可以敲glxinfo | grep -i vendor 然后看看是不是像下面这样的信息。

  1. $ glxinfo | grep -i vendor
  2. server glx vendor string: NVIDIA Corporation
  3. client glx vendor string: NVIDIA Corporation
  4. OpenGL vendor string: NVIDIA Corporation

如果是,说明你已经设置成功,可以欢呼了! 当然我有双显示器,一看显示器亮了就知道了2333

最后

这个奇怪的问题(点击查看)当时也困扰了我很久 打开任务管理器没有任何占用,为啥还是一卡一卡的? 后来才知道,噢,原来是双显卡的坑。 听说最近19H1来了?反正我不想用Windows了。 自从Windows 7 之后我就没用过没bug的系统!
希望我的这篇博文能帮到各位看官。 :) 新开的评论区(Gitment),有问题可以在下面留言哦。
(2019-8 更新:感谢评论区的小伙伴的支持哦)

参考资料

How To Set up PRIME with NVIDIA proprietary driver
Optimus - ArchWik

https://amazingrise.net/2019/04/20/manjaro-optimus-dual-monitor/#%e5%89%8d%e8%a8%80-