「GPGPU」の版間の差分
(同期) |
(同期) |
||
19行目: | 19行目: | ||
* {{Pkg|opencl-nvidia}}: NVidia の GPU で実行 (NVidia の公式ランタイム) |
* {{Pkg|opencl-nvidia}}: NVidia の GPU で実行 (NVidia の公式ランタイム) |
||
* {{Pkg|opencl-mesa}}: AMD の GPU で mesa ドライバーを使って実行 (開発中、効果のほどは保証できません) |
* {{Pkg|opencl-mesa}}: AMD の GPU で mesa ドライバーを使って実行 (開発中、効果のほどは保証できません) |
||
− | * {{AUR|opencl-catalyst}}: AMD の GPU で実行 (AMD の公式ランタイム) |
+ | * {{AUR|opencl-catalyst}}: AMD の GPU で実行 (AMD の公式ランタイム、ただし今後廃止予定) |
+ | * {{AUR|amdgpu-pro-opencl}}:AMD の GPU で実行 (AMD の公式ランタイム、Ubuntu のパッケージから自動生成) |
||
* {{AUR|intel-opencl-runtime}}: CPU で実行 (Intel の公式ランタイム、ただし Intel の CPU である必要はありません) |
* {{AUR|intel-opencl-runtime}}: CPU で実行 (Intel の公式ランタイム、ただし Intel の CPU である必要はありません) |
||
* {{AUR|pocl}}: CPU で実行 (LLVM ベースの OpenCL 実装) |
* {{AUR|pocl}}: CPU で実行 (LLVM ベースの OpenCL 実装) |
||
46行目: | 47行目: | ||
* {{Pkg|ocl-icd}}: 推奨、基本的に最新です。 |
* {{Pkg|ocl-icd}}: 推奨、基本的に最新です。 |
||
* AMD による {{AUR|libopencl}}: OpenCL のバージョン 2.0 を提供します。目下 AMD によって制限的なライセンスで配布されているため、公式リポジトリに入れることはできません。 |
* AMD による {{AUR|libopencl}}: OpenCL のバージョン 2.0 を提供します。目下 AMD によって制限的なライセンスで配布されているため、公式リポジトリに入れることはできません。 |
||
− | * {{AUR|intel-opencl-runtime}}: |
+ | * Intel による {{AUR|intel-opencl-runtime}}: OpenCL 1.2 を提供します。 |
{{Note|ICD ローダーのベンダーの名前が出るのはローダーを識別する必要があるときだけです。他の場合、ベンダーの名前は関係ありません。ICD ローダーはベンダーに依存しないため (正しく実装されてさえいれば) 相互に交換して使うことができます。}} |
{{Note|ICD ローダーのベンダーの名前が出るのはローダーを識別する必要があるときだけです。他の場合、ベンダーの名前は関係ありません。ICD ローダーはベンダーに依存しないため (正しく実装されてさえいれば) 相互に交換して使うことができます。}} |
||
66行目: | 67行目: | ||
Mesa の OpenCL サポートは開発中です (http://www.x.org/wiki/GalliumStatus/ を参照)。AMD Radeon カードは r600g ドライバーによってサポートされています。 |
Mesa の OpenCL サポートは開発中です (http://www.x.org/wiki/GalliumStatus/ を参照)。AMD Radeon カードは r600g ドライバーによってサポートされています。 |
||
− | Arch Linux では OpenCL のサポートは別のパッケージになっています: {{Pkg|opencl-mesa}}。使い方は http://dri.freedesktop.org/wiki/GalliumCompute/ を見て |
+ | Arch Linux では OpenCL のサポートは別のパッケージになっています: {{Pkg|opencl-mesa}}。使い方は http://dri.freedesktop.org/wiki/GalliumCompute/ を見てください。 |
− | |||
− | [http://pkgbuild.com/~lcarlier/mesa-git/ lordheavy のリポジトリ] を使うこともできます。以下のパッケージをインストールしてください: |
||
− | * {{AUR|mesa-dri-git}} |
||
− | * {{AUR|opencl-mesa-git}} |
||
− | * {{AUR|libclc-git}} |
||
− | |||
− | 驚くべきことに、radeon+r600g を使った場合 Catalyst 13.11 Beta1 と比べて 20% 高速に pyrit が動作します (他の7つの CPU コアでもテスト): |
||
− | {{bc|<nowiki>catalyst #1: 'OpenCL-Device 'Barts'': 21840.7 PMKs/s (RTT 2.8) |
||
− | radeon+r600g #1: 'OpenCL-Device 'AMD BARTS'': 26608.1 PMKs/s (RTT 3.0)</nowiki>}} |
||
− | 執筆時点では (2013年10月30日)、このパフォーマンスを得るためには [http://people.freedesktop.org/~tstellar/pyrit-perf/0001-XXX-clover-Calculate-the-optimal-work-group-size.patch] と [http://people.freedesktop.org/~tstellar/pyrit-perf/0001-radeon-llvm-Specify-the-DataLayout-when-running-opti.patch] のパッチを Mesa のコミット ac81b6f2be8779022e8641984b09118b57263128 上にあてる必要があります。パッチがあたってない最新の LLVM トランクを使用しました (SVN rev 193660)。 |
||
====NVIDIA==== |
====NVIDIA==== |
||
113行目: | 104行目: | ||
** CUDA SDK。CUDA と OpenCL のプログラムの多数のサンプルやコードが含まれています。 |
** CUDA SDK。CUDA と OpenCL のプログラムの多数のサンプルやコードが含まれています。 |
||
− | カーネルモジュールと CUDA の "driver" ライブラリは {{Pkg|nvidia}} と {{Pkg|opencl-nvidia}} に入っています。"runtime" ライブラリと CUDA ツールキットは {{Pkg|cuda}} パッケージでインストール可能です。このライブラリは[https://projects.archlinux.org/svntogit/community.git/commit/trunk?h=packages/cuda&id=1b62c8bcb9194b2de1b750bd62a8dce1e7e549f5 64ビット版]だけが存在します。 |
+ | カーネルモジュールと CUDA の "driver" ライブラリは {{Pkg|nvidia}} と {{Pkg|opencl-nvidia}} に入っています。"runtime" ライブラリと CUDA ツールキットは {{Pkg|cuda}} パッケージでインストール可能です。このライブラリは[https://projects.archlinux.org/svntogit/community.git/commit/trunk?h=packages/cuda&id=1b62c8bcb9194b2de1b750bd62a8dce1e7e549f5 64ビット版]だけが存在します。{{ic|cuda-gdb}} を使うには {{aur|ncurses5-compat-libs}} のインストールが必要です。{{Bug|46598}} を参照。 |
===開発=== |
===開発=== |
||
119行目: | 110行目: | ||
{{Pkg|cuda}} パッケージは全てのコンポーネントを {{ic|/opt/cuda}} ディレクトリにインストールします。CUDA のコードをコンパイルするときはコンパイラのインクルードパスに {{ic|/opt/cuda/include}} を追加してください。例えばコンパイラのフラグやオプションに {{ic|-I/opt/cuda/include}} を加えることで追加できます。NVIDIA による {{ic|gcc}} ラッパーである {{ic|nvcc}} を使うには、{{ic|/opt/cuda/bin}} をパスに追加してください。 |
{{Pkg|cuda}} パッケージは全てのコンポーネントを {{ic|/opt/cuda}} ディレクトリにインストールします。CUDA のコードをコンパイルするときはコンパイラのインクルードパスに {{ic|/opt/cuda/include}} を追加してください。例えばコンパイラのフラグやオプションに {{ic|-I/opt/cuda/include}} を加えることで追加できます。NVIDIA による {{ic|gcc}} ラッパーである {{ic|nvcc}} を使うには、{{ic|/opt/cuda/bin}} をパスに追加してください。 |
||
− | {{ic|/opt/cuda/ |
+ | {{ic|/opt/cuda/samples}} にインストールされたサンプルをコンパイルしてコンパイルされたサンプルを実行することで、インストールが成功したこと、CUDA が動作していることを確認できます (サンプルディレクトリで {{ic|make}} を実行するだけでコンパイルできます、ただし、コンパイルする前に {{ic|/opt/cuda/samples}} ディレクトリをホームディレクトリにコピーしておいた方が良いでしょう)。インストールが問題ないことを確認するときは {{ic|deviceQuery}} と呼ばれるサンプルのどれかを実行するのがふさわしいと思われます。 |
− | {{Note|CUDA |
+ | {{Note|CUDA 8.0 は GCC 6 と互換性がありません ({{Bug|49272}} を参照)。したがって {{Pkg|cuda}} パッケージは {{Pkg|gcc5}} に依存しており、{{ic|nvcc}} から古いバージョンが使われるように {{ic|/opt/cuda/bin/}} にシンボリックリンクが作成されます。ホストコードをコンパイルする際は同じバージョンの GCC が使われるようにビルドシステムを設定する必要があります。}} |
===言語バインディング=== |
===言語バインディング=== |
||
140行目: | 131行目: | ||
* [[Bitcoin]] |
* [[Bitcoin]] |
||
* [[GIMP]] (実験段階 - [http://www.h-online.com/open/news/item/GIMP-2-8-RC-1-arrives-with-GPU-acceleration-1518417.html] を参照) |
* [[GIMP]] (実験段階 - [http://www.h-online.com/open/news/item/GIMP-2-8-RC-1-arrives-with-GPU-acceleration-1518417.html] を参照) |
||
+ | * {{Pkg|opencv}} |
||
* {{Pkg|pyrit}} |
* {{Pkg|pyrit}} |
||
* {{Pkg|darktable}} - OpenCL 機能を使うには GPU に最低でも 1GB のメモリが搭載されていて ''Image support'' が必要です (clinfo コマンドの出力で確認できます)。 |
* {{Pkg|darktable}} - OpenCL 機能を使うには GPU に最低でも 1GB のメモリが搭載されていて ''Image support'' が必要です (clinfo コマンドの出力で確認できます)。 |
||
* {{Pkg|aircrack-ng}} |
* {{Pkg|aircrack-ng}} |
||
− | * {{AUR|john-opencl}} |
||
* {{AUR|cuda_memtest}} - GPU memtest。名前とは裏腹に、CUDA と OpenCL の両方をサポートしています。 |
* {{AUR|cuda_memtest}} - GPU memtest。名前とは裏腹に、CUDA と OpenCL の両方をサポートしています。 |
||
− | * |
+ | * [[Blender]] - Nvidia GPU 向けの CUDA のサポートと AMD GPU 向けの OpenCL のサポート。詳細は[http://blender.org/manual/render/cycles/features.html#features こちら]。 |
==参照== |
==参照== |
2017年2月16日 (木) 00:00時点における版
関連記事
GPGPU は General-purpose computing on graphics processing units の略で GPU による汎目的計算を意味します。Linux では、現在2つの GPGPU フレームワークが存在します: OpenCL と CUDA。
目次
OpenCL
概要
OpenCL (Open Computing Language) は非営利団体である Khronos グループによって開発されている、オープンでロイヤルティフリーの並列プログラミングフレームワークです。
OpenCL の仕様書には一般環境として必要なプログラミング言語と、プログラマーがこの環境で呼び出せる C API が書かれています。
Arch Linux では複数のパッケージを用意しています。
OpenCL を使用するプログラムを実行するには、あなたのハードウェアに対応しているランタイムをインストールする必要があります:
- opencl-nvidia: NVidia の GPU で実行 (NVidia の公式ランタイム)
- opencl-mesa: AMD の GPU で mesa ドライバーを使って実行 (開発中、効果のほどは保証できません)
- opencl-catalystAUR: AMD の GPU で実行 (AMD の公式ランタイム、ただし今後廃止予定)
- amdgpu-pro-openclAUR:AMD の GPU で実行 (AMD の公式ランタイム、Ubuntu のパッケージから自動生成)
- intel-opencl-runtimeAUR: CPU で実行 (Intel の公式ランタイム、ただし Intel の CPU である必要はありません)
- poclAUR: CPU で実行 (LLVM ベースの OpenCL 実装)
OpenCL を使って開発したい場合、他にもパッケージをインストールする必要があります:
- ocl-icd: OpenCL ICD ローダーの実装、最新の OpenCL の仕様に沿っています。
- opencl-headers: OpenCL C/C++ API ヘッダー。
ベンダーの SDK には様々なツールやサポートライブラリが含まれています:
- intel-opencl-sdkAUR: Intel の OpenCL SDK (旧バージョン、最新の OpenCL SDK は INDE や Intel Media Server Studio に含まれています)
- amdapp-sdkAUR: AMD の OpenCL SDK
- cuda: NVidia の GPU SDK、OpenCL 1.1 のサポートを含んでいます。
OpenCL ICD ローダー (libOpenCL.so)
OpenCL ICD ローダーはプラットフォームに依存しないライブラリで、OpenCL API によって特定のデバイスのドライバーをロードすることができます。ほとんどの OpenCL ベンダーはそれぞれ独自の OpenCL ICD ローダーを提供しており、他のベンダーの OpenCL 実装でも問題なく動作するはずです。残念ながら、大抵のベンダーは完全に最新の ICD ローダーを提供してくれはいません。そのため、Arch Linux ではこのライブラリを別のプロジェクトから用意することで (ocl-icd) 最新の OpenCL API の実装が機能するようにしています。
他の ICD ローダーライブラリは各メーカーの SDK の一部としてインストールされます。ocl-icd パッケージに含まれている ICD ローダーが使われいることを確認したい場合、/etc/ld.so.conf.d
にファイルを作成して /usr/lib
を動的プログラムローダーの検索ディレクトリに追加します:
/etc/ld.so.conf.d/00-usrlib.conf
/usr/lib
全ての SDK は ld.so.conf.d
ファイルでランタイムのライブラリディレクトリを検索パスに追加するため上記の設定をする必要があります。
様々な OpenCL ICD が含まれているパッケージ:
- ocl-icd: 推奨、基本的に最新です。
- AMD による libopenclAUR: OpenCL のバージョン 2.0 を提供します。目下 AMD によって制限的なライセンスで配布されているため、公式リポジトリに入れることはできません。
- Intel による intel-opencl-runtimeAUR: OpenCL 1.2 を提供します。
実装
あなたの環境で有効になっている OpenCL 実装を確認するには、次のコマンドを使います:
$ ls /etc/OpenCL/vendors
AMD
AMD の OpenCL 実装は AMD APP SDK として知られています。以前は AMD Stream SDK または ATi Stream とも呼ばれていました。
Arch Linux では、現在 AMD APP SDK は AUR の amdapp-sdkAUR としてインストールすることができます。このパッケージは /opt/AMDAPP
にインストールされ、SDK ファイルとは別に、多数のサンプルコードも含まれています (/opt/AMDAPP/SDK/samples/
)。システム上の OpenCL プラットフォームやデバイスをリストアップして、それぞれの詳しい情報を表示する clinfo
ユーティリティも入っています。
AMD APP SDK 自体にも CPU の OpenCL ドライバーが含まれているため、(ベンダーの如何を問わず) CPU デバイスで OpenCL を実行するのに追加のドライバーは必要ありません。GPU の OpenCL ドライバーは (任意の依存パッケージである) catalystAUR パッケージに入っています。
コードは (依存パッケージになっている) llvm を使ってコンパイルされます。
Mesa (Gallium)
Mesa の OpenCL サポートは開発中です (http://www.x.org/wiki/GalliumStatus/ を参照)。AMD Radeon カードは r600g ドライバーによってサポートされています。
Arch Linux では OpenCL のサポートは別のパッケージになっています: opencl-mesa。使い方は http://dri.freedesktop.org/wiki/GalliumCompute/ を見てください。
NVIDIA
NVIDIA の実装は公式リポジトリの opencl-nvidia からインストールできます。nvidia カーネルモジュールが動作する NVIDIA GPU のみをサポートしています (nouveau はまだ OpenCL をサポートしていません)。
Intel
Intel の実装は、シンプルに Intel OpenCL SDK という名前が付けられており、Intel の CPU (主に Core と Xeon) と GPU だけに最適化された OpenCL パフォーマンスを発揮します。パッケージは AUR からインストールできます: intel-opencl-sdkAUR。ランタイムは別のパッケージとして AUR にあります: intel-opencl-runtimeAUR。Ivy Bridge 以降の新しいハードウェアに搭載されている統合グラフィックハードウェアのための OpenCL は AUR の beignetAUR から入手できます。
POCL
CPU で動作する LLVM ベースの実装です。poclAUR でインストールできます。
開発
OpenCL 開発に必要なパッケージは概要セクションに記載しています。完全な SDK のインストールは任意です (ランタイム実装によります、大抵はベンダーの SDK の一部として含まれています)。あなたのアプリケーションを libOpenCL.so
にリンクしてください。
言語バインディング
- C++: Khronos によるバインディングが公式の仕様書 (バージョン 1.2) に存在します。opencl-headers に含まれています。
- C++/Qt: Qt Labs に QtOpenCL という名前の実験的なバインディングがあります - 詳しくは ブログエントリ を参照
- JavaScript/HTML5: WebCL
- Python: PyOpenCL という同じ名前を持った2つのバインディングが存在します。片方は [extra] に入っています: python-pyopencl。もう片方については sourceforge を見て下さい。
- D: cl4d
- Haskell: OpenCLRaw パッケージを AUR からインストールできます: haskell-openclraw-gitAUR
- Java: JOCL (JogAmp の一部)
- Mono/.NET: Open Toolkit
- Go: OpenCL bindings for Go
- Racket: raco でインストールすることができるネイティブインターフェイスが PLaneT にあります。
CUDA
CUDA (Compute Unified Device Architecture) は NVIDIA による、プロプライエタリでクローズドソースの並列計算アーキテクチャ・フレームワークです。NVIDIA の GPU を必要とします。CUDA は複数のコンポーネントから構成されます:
- 必須:
- プロプライエタリの NVIDIA カーネルモジュール
- CUDA "driver" と "runtime" ライブラリ
- 任意:
- 追加ライブラリ: CUBLAS, CUFFT, CUSPARSE など。
- CUDA ツールキット。
nvcc
コンパイラが含まれています。 - CUDA SDK。CUDA と OpenCL のプログラムの多数のサンプルやコードが含まれています。
カーネルモジュールと CUDA の "driver" ライブラリは nvidia と opencl-nvidia に入っています。"runtime" ライブラリと CUDA ツールキットは cuda パッケージでインストール可能です。このライブラリは64ビット版だけが存在します。cuda-gdb
を使うには ncurses5-compat-libsAUR のインストールが必要です。FS#46598 を参照。
開発
cuda パッケージは全てのコンポーネントを /opt/cuda
ディレクトリにインストールします。CUDA のコードをコンパイルするときはコンパイラのインクルードパスに /opt/cuda/include
を追加してください。例えばコンパイラのフラグやオプションに -I/opt/cuda/include
を加えることで追加できます。NVIDIA による gcc
ラッパーである nvcc
を使うには、/opt/cuda/bin
をパスに追加してください。
/opt/cuda/samples
にインストールされたサンプルをコンパイルしてコンパイルされたサンプルを実行することで、インストールが成功したこと、CUDA が動作していることを確認できます (サンプルディレクトリで make
を実行するだけでコンパイルできます、ただし、コンパイルする前に /opt/cuda/samples
ディレクトリをホームディレクトリにコピーしておいた方が良いでしょう)。インストールが問題ないことを確認するときは deviceQuery
と呼ばれるサンプルのどれかを実行するのがふさわしいと思われます。
言語バインディング
- Fortran: PGI CUDA Fortran Compiler
- Haskell: accelerate パッケージ に CUDA バックエンドがあります
- Java: JCuda
- Mathematica: CUDAlink
- Mono/.NET: CUDA.NET, CUDAfy.NET
- Perl: Kappa, CUDA-Minimal
- Python: python-pycuda または Kappa
- Ruby, Lua: Kappa
ドライバーの問題
複数の GPU が載っている環境で CUDA プログラムを実行する場合、パーミッション問題を解決するためにレガシーなドライバー nvidia-304xx または nvidia-304xx-lts を使う必要があるかもしれません。
OpenCL と CUDA のアクセラレーションがあるソフトウェア
- Bitcoin
- GIMP (実験段階 - [1] を参照)
- opencv
- pyrit
- darktable - OpenCL 機能を使うには GPU に最低でも 1GB のメモリが搭載されていて Image support が必要です (clinfo コマンドの出力で確認できます)。
- aircrack-ng
- cuda_memtestAUR - GPU memtest。名前とは裏腹に、CUDA と OpenCL の両方をサポートしています。
- Blender - Nvidia GPU 向けの CUDA のサポートと AMD GPU 向けの OpenCL のサポート。詳細はこちら。