
明らかに私は初心者の Ubuntu ユーザーなので、ひどい間違いをしたり、必要な知識が不足していたりしてもご容赦ください :D
期待される動作
Dell XPS13
最近インストールした を実行しているラップトップがあり、理想的には外部ディスプレイの出力を使用して、eGPUUbuntu 20.04 focal
でビデオエクスペリエンスを向上したいと考えています。Nvidia GTX 1660 SUPER
Razor Core X
実際の行動
外部ディスプレイに黒い画面が表示されるだけで、何も表示されませんでした。
私が試したこと
BIOS で Thunderbolt サポートを有効にし、セキュリティを要求しないように設定したので、接続するとすぐに認識されます。ubuntu-driver devices
主に nvidia ドライバーの 440 バージョンである、によってリストされているドライバーをインストールしました。
ubuntu-drivers devices
== /sys/devices/pci0000:00/0000:00:1c.4/0000:03:00.0/0000:04:01.0/0000:06:00.0/0000:07:01.0/0000:08:00.0 ==
modalias : pci:v000010DEd000021C4sv00001462sd0000C758bc03sc00i00
vendor : NVIDIA Corporation
model : TU116 [GeForce GTX 1660 SUPER]
manual_install: True
driver : nvidia-driver-440 - distro non-free recommended
driver : nvidia-driver-440-server - distro non-free
driver : xserver-xorg-video-nouveau - distro free builtin
実行しましたが 、パスワードを正しく入力しているにもかかわらずsudo ubuntu-driver autoinstall
、ログイン画面が繰り返し表示されます。reboot
eGPU を取り外すと、ログイン画面を通過できます。
再接続して実行すると、nvidia-smi
次のようになります:
sudo nvidia-smi
[sudo] password for andrei:
Tue Sep 8 17:55:42 2020
+-----------------------------------------------------------------------------+
| NVIDIA-SMI 440.100 Driver Version: 440.100 CUDA Version: 10.2 |
|-------------------------------+----------------------+----------------------+
| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |
| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |
|===============================+======================+======================|
| 0 GeForce GTX 166... Off | 00000000:3C:00.0 Off | N/A |
| 0% 40C P0 12W / 130W | 0MiB / 5944MiB | 0% Default |
+-------------------------------+----------------------+----------------------+
+-----------------------------------------------------------------------------+
| Processes: GPU Memory |
| GPU PID Type Process name Usage |
|=============================================================================|
| No running processes found |
+-----------------------------------------------------------------------------+
その他の注意事項:
- 私は全くない
/etc/X11/xorg.conf
- 次のよう
/usr/lib/modprobe.d/nvidia-graphics-drivers.conf
になります:
blacklist nouveau
blacklist lbm-nouveau
alias nouveau off
alias lbm-nouveau off
私も実行するnvidia-settings
と、次のようになります:
ERROR: Unable to load info from any available system
(nvidia-settings:4382): GLib-GObject-CRITICAL **: 18:09:30.505: g_object_unref: assertion 'G_IS_OBJECT (object)' failed
** Message: 18:09:30.507: PRIME: Requires offloading
** Message: 18:09:30.507: PRIME: is it supported? yes
** Message: 18:09:30.534: PRIME: Usage: /usr/bin/prime-select nvidia|intel|on-demand|query
** Message: 18:09:30.534: PRIME: on-demand mode: "1"
** Message: 18:09:30.534: PRIME: is "on-demand" mode supported? yes
外部ディスプレイに出力がありません。
さらに、Ubuntu グラフィック ドライバー リポジトリでも試しsudo apt-add-repository ppa:graphics-drivers/ppa
、新しく推奨されたドライバーを使用して上記のプロセスを繰り返しましたnvidia-driver-450
が、結果は同様で、主にログインできないか、ログイン画面がちらつき、残念ながら外部ビデオ カードからの出力はありませんでした。
egpu-switcher
また、「nvidia-config which , I guess mainly tried to create/modify the
/etc/X11/xorg.conf」の使用も試みましたが、外部ディスプレイに出力されませんでした (同じケーブルをラップトップに直接接続すると機能するため、これは機能します :)。
もし誰かが、私にとって、そして言及したすべてのハードウェアとソフトウェアにとって、この苦しみをハッピーエンドで終わらせる何かを提案してくれるなら、とてもありがたいです :)
ありがとう!
アップデート
実行すると、nvidia-settings
次のログが記録されます:
ERROR: Unable to load info from any available system
(nvidia-settings:20812): GLib-GObject-CRITICAL **: 01:58:56.002: g_object_unref: assertion 'G_IS_OBJECT (object)' failed
** Message: 01:58:56.005: PRIME: Requires offloading
** Message: 01:58:56.005: PRIME: is it supported? yes
** Message: 01:58:56.039: PRIME: Usage: /usr/bin/prime-select nvidia|intel|on-demand|query
** Message: 01:58:56.039: PRIME: on-demand mode: "1"
** Message: 01:58:56.039: PRIME: is "on-demand" mode supported? yes
答え1
長い戦いの末、私は実際にこのコメントに基づいて問題を解決することができました:https://forums.developer.nvidia.com/t/nvidia-xconfig-doesnt-do-what-i-want-it-to-nor-does-nvidia-settings/107883/7
したがって、このコンテキストでは があなたを助けることができないことを理解することが重要だと思いますxorg.conf
。 何をしても、 があった間は結果を得ることができませんでしたxorg.conf
。
私にとって効果的だったのは次の通りです:
- 試した可能性のあるすべての nvidia のものを削除します: sudo apt --purge remove 'nvidia-*'
- Nvidia の Web サイトから最新の Nvidia ドライバーをダウンロードし、実行可能にします。
- リカバリモードで再起動し(またはaxサーバーを実行せずに)、システムにGPUが見つからないと表示された場合でもドライバーインストーラーを実行します。
/etc/X11/xorg.conf
持っているものがあれば削除してくださいreboot
通常はnvidia-prime
まだインストールされていない場合はインストールしてくださいsudo prime-select nvidia
/usr/share/X11/xorg.conf.d/10-amdgpu.conf
ドライバーをアップデートして置き換えるmodesetting
Section "OutputClass"
Identifier "AMDgpu"
MatchDriver "amdgpu"
Driver "modesetting"
EndSection
- 次のように更新します:
Section "OutputClass"
Identifier "nvidia"
MatchDriver "nvidia-drm"
Driver "nvidia"
Option "AllowEmptyInitialConfiguration"
ModulePath "/usr/lib/x86_64-linux-gnu/nvidia/xorg"
Option "PrimaryGPU" "Yes"
Option "AllowExternalGpus" "True"
EndSection
- と に
optimus.desktop
次の内容を含む2 つのファイルを作成します。/etc/xdg/autostart/
/usr/share/gdm/greeter/autostart/
[Desktop Entry]
Type=Application
Name=Optimus
Exec=sh -c "xrandr --setprovideroutputsource modesetting 0; xrandr --auto"
NoDisplay=true
X-GNOME-Autostart-Phase=DisplayServer
(@generix はそこで言っています modesetting NVIDIA-0;
が、私の場合はそのようには機能しませんでした。ただし、modesetting 0;
)では機能します。
reboot
次のコマンドを実行してすべてが正常であるかどうかをテストします。nvidia
__NV_PRIME_RENDER_OFFLOAD=1 __GLX_VENDOR_LIBRARY_NAME=nvidia glxinfo | grep vendor
を含む行が返されない場合は正常ではありません。私の場合は、次のようになります。
server glx vendor string: NVIDIA Corporation
client glx vendor string: NVIDIA Corporation
OpenGL vendor string: NVIDIA Corporation
nvidia-smi
もう 1 つのチェックは、実行すると少なくともいくつかのプロセスがリストされるかどうかです。
そして、私が望んでいた通り、外部ディスプレイで NVIDIA GPU からの信号を取得できました :)
ありがとう ;)
答え2
また見つかったソリューション@bluehipy のおかげで、Ubuntu 20.04 を実行している Acer Predator Helios 300 を外部モニターで動作させ、ディープラーニング作業で問題が発生していた NVIDIA/CUDA スタックを適切にインストールするのに非常に役立ちました。
私がこのスレッドを見つけたのは、実際に Acer Predator Helios 300 を返品し、機械学習 / データ サイエンス モデルをローカルでデバッグし、実際にクラウドでトレーニングする場合に、eGPU を搭載した Dell XPS 13 が「シン クライアント」タイプのワークフローで機能するかどうかを確認しようと考えていたときでした。
それで、他の誰かが自分のラップトップを動作させるのに苦労しているなら、元の手順に少し調整を加えてみてはどうでしょうか?
前提条件:
sudo apt install gcc make mesa-utils mpich
NVIDIA ドライバーをインストールする
私にとって効果的だったのは次の通りです:
試した可能性のあるすべての NVIDIA のものを削除します。
sudo apt --purge remove nvidia-*
元の手順では最新のドライバーをダウンロードするように書かれていましたが、ドライバーのバージョンは最新のCUDAツールキットインストールするときにそれが何なのかを確認してください。最新のNVIDIAドライバーで動作するかもしれませんか?古いドライバーを確認するCUDA ツールキット ドライバーのバージョンと一致する可能性が最も高くなります。たとえば、これらの手順の時点で一致するバージョンは 470.57.02 (NVIDIA-Linux-x86_64-470.57.02.run) でした。
リカバリモードで再起動し(またはaxサーバーを実行せずに)、システムにGPUが見つからないと表示された場合でもドライバーインストーラーを実行します(ルートにドロップし、など
cd ../home/username/Downloads
)./NVIDIA-Linux-x86_64-470.74.run
。/etc/X11/xorg.conf
持っているものがあれば削除してください再起動(
e
Ubuntuのgrubメニューを押して、nomodeset
最後に)nvidia-primeがまだインストールされていない場合はインストールしてください
sudo prime-select nvidia
/usr/share/X11/xorg.conf.d/10-amdgpu.conf
ドライバーを置き換えて更新するmodesetting
Section "OutputClass"
Identifier "AMDgpu"
MatchDriver "amdgpu"
Driver "modesetting"
EndSection
sudo gedit /usr/share/X11/xorg.conf.d/10-nvidia.conf
次のようなnvidia configファイル( )を作成します。
Section "OutputClass"
Identifier "nvidia"
MatchDriver "nvidia-drm"
Driver "nvidia"
Option "AllowEmptyInitialConfiguration"
ModulePath "/usr/lib/x86_64-linux-gnu/nvidia/xorg"
Option "PrimaryGPU" "Yes"
Option "AllowExternalGpus" "True"
EndSection
10とoptimus.desktop
に次の内容を含む2 つのファイルを作成します。/etc/xdg/autostart/
/usr/share/gdm/greeter/autostart/
[Desktop Entry]
Type=Application
Name=Optimus
Exec=sh -c "xrandr --setprovideroutputsource modesetting 0; xrandr --auto"
NoDisplay=true
X-GNOME-Autostart-Phase=DisplayServer
grubを変更するそうすれば、nomodeset が常に存在するようになります。
sudo gedit /etc/default/grub
リブート
次のコマンドを実行して、すべてが正常であるかどうかをテストします。
__NV_PRIME_RENDER_OFFLOAD=1 __GLX_VENDOR_LIBRARY_NAME=nvidia glxinfo | grep vendor
nvidia-smi
少なくともいくつかのプロセスがリストされるかどうかを確認してください。
| NVIDIA-SMI 470.57.02 Driver Version: 470.57.02 CUDA Version: 11.4 | GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC
| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M.
| 0 NVIDIA GeForce ... Off | 00000000:01:00.0 On | N/A
| N/A 42C P8 14W / N/A | 264MiB / 5946MiB | 1% Default
CUDAツールキットをインストールする
最新のCUDAツールキット指示の時点では、cuda_11.4.2_470.57.02_linux.run
NVIDIAドライバを再インストールせずにインストールされていました
wget https://developer.download.nvidia.com/compute/cuda/11.4.2/local_installers/cuda_11.4.2_470.57.02_linux.run
sudo sh cuda_11.4.2_470.57.02_linux.run
CUDAのインストールを確認する
見るhttps://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html#install-samples
前提条件:(すべてのサンプルを適切にコンパイルしたい場合)から:
sudo apt-get install g++ freeglut3-dev build-essential libx11-dev \
libxmu-dev libxi-dev libglu1-mesa libglu1-mesa-dev libfreeimage-dev
例えば、次./deviceQuery
の戻り値:
CUDA Device Query (Runtime API) version (CUDART static linking)
Detected 1 CUDA Capable device(s)
Device 0: "NVIDIA GeForce RTX 3060 Laptop GPU"
CUDA Driver Version / Runtime Version 11.4 / 11.4
CUDA Capability Major/Minor version number: 8.6
Total amount of global memory: 5947 MBytes (6235422720 bytes)
(030) Multiprocessors, (128) CUDA Cores/MP: 3840 CUDA Cores
GPU Max Clock rate: 1425 MHz (1.42 GHz)
...
deviceQuery, CUDA Driver = CUDART, CUDA Driver Version = 11.4, CUDA Runtime Version = 11.4, NumDevs = 1
Result = PASS
cudnn インストール
ガイドを見るhttps://docs.nvidia.com/deeplearning/cudnn/インストールガイド/index.html
CUDA 11.4 用の cuDNN v8.2.4 (2021 年 9 月 2 日) をダウンロード
-> Linux (x86_64) 用 cuDNN ライブラリ、例:cudnn-11.4-linux-x64-v8.2.4.15.tgz
答え3
私も、Ubuntu Mate 20.4 を実行する NUC と、NVidia RTX 2060 Super を搭載した Razor Core X を使用した同様のセットアップを持っています。
基本的に、私もあなたと同じ状況で、何も機能しませんでした。その後、何かを台無しにしてしまい、Ubuntu を再インストールする必要がありました。ただし、eGPU ケースを接続した状態でこれを行いました。インストール中に、NVidia 440 ドライバーが自動的にインストールされました。
この時点で、私は次の投稿を見つけました:
https://egpu.io/forums/thunderbolt-linux-setup/ubuntu-19-04-easy-to-use-setup-script-for-your-egpu/
リポジトリで提供されているスクリプトを使用して、ついに GPU を動作させることができました。CUDA にアクセスでき、eGPU で 2 つの外部モニターも使用できます。
このスクリプトがあなたにも役立つことを願っています。幸運を祈ります。