「カーネルモード設定」の版間の差分
細 |
(同期) |
||
2行目: | 2行目: | ||
[[Category:カーネル]] |
[[Category:カーネル]] |
||
[[Category:X サーバー]] |
[[Category:X サーバー]] |
||
− | [[en:Kernel |
+ | [[en:Kernel mode setting]] |
− | [[es:Kernel |
+ | [[es:Kernel mode setting]] |
− | [[hu:Kernel |
+ | [[hu:Kernel mode setting]] |
− | [[ |
+ | [[ru:Kernel mode setting]] |
− | [[zh- |
+ | [[zh-cn:Kernel mode setting]] |
+ | [[zh-tw:Kernel mode setting]] |
||
{{Related articles start}} |
{{Related articles start}} |
||
− | {{ |
+ | {{Related|ATI}} |
+ | {{Related|AMDGPU}} |
||
− | {{Related2|Intel Graphics|Intel Graphics}} |
||
+ | {{Related|Intel Graphics}} |
||
− | {{Related2|Nouveau|Nouveau}} |
||
+ | {{Related|Nouveau}} |
||
{{Related articles end}} |
{{Related articles end}} |
||
17行目: | 19行目: | ||
Linux カーネルの KMS 機能ではフレームバッファでのネイティブ解像度や素早いコンソール (tty) 切り替えができるようになります。KMS を使うと、歪みを消去したり 3D パフォーマンスの上昇、カーネル空間の電力節約などをもたらす新しい技術 (DRI2 など) が有効になります。 |
Linux カーネルの KMS 機能ではフレームバッファでのネイティブ解像度や素早いコンソール (tty) 切り替えができるようになります。KMS を使うと、歪みを消去したり 3D パフォーマンスの上昇、カーネル空間の電力節約などをもたらす新しい技術 (DRI2 など) が有効になります。 |
||
− | {{Note|プロプライエタリの [[NVIDIA |
+ | {{Note|プロプライエタリの [[NVIDIA]] と [[AMD Catalyst]] ドライバにもカーネルモードセッティング機能はありますが、カーネル固有の機能は使っていないため、高解像度コンソールのための fbdev ドライバがありません。}} |
== 背景 == |
== 背景 == |
||
25行目: | 27行目: | ||
== インストール == |
== インストール == |
||
まず、''どの''方法を使うにせよ、以下を''常時''無効にする必要があります: |
まず、''どの''方法を使うにせよ、以下を''常時''無効にする必要があります: |
||
− | * ブートローダ内のあらゆる |
+ | * ブートローダ内のあらゆる {{ic|<nowiki>vga=</nowiki>}} オプション。KMS によるネイティブ解像度と衝突します。 |
− | * フレームバッファを有効にするあらゆる |
+ | * フレームバッファを有効にするあらゆる {{ic|<nowiki>video=</nowiki>}} 行。ドライバと衝突します。 |
* 他のフレームバッファドライバ ([[uvesafb]] など)。 |
* 他のフレームバッファドライバ ([[uvesafb]] など)。 |
||
=== Late KMS start=== |
=== Late KMS start=== |
||
− | [[Intel Graphics|Intel]], [[ |
+ | [[Intel Graphics|Intel]], [[Nouveau]], [[ATI]], [[AMDGPU]] ドライバでは既に全てのチップセットで KMS が自動的に有効になっています。そのため手動でインストールする必要はありません。 |
− | プロプライエタリの [[ |
+ | プロプライエタリの [[NVIDIA]], [[AMD Catalyst]] ドライバはオープンドライバスタックを使いません。KMS を使うにはオープンソースドライバに代えてください。 |
=== Early KMS start === |
=== Early KMS start === |
||
− | 起動中にできるだけ早く KMS をロードするには、[[ATI|radeon]] (ATI/AMD カード向け)、[[Intel Graphics|i915]] (Intel 内蔵グラフィック向け)、[[Nouveau|nouveau]] (Nvidia カード向け) の内どれかのモジュールを、{{ic|/etc/mkinitcpio.conf}} の {{ic|MODULES}} 行に追加します。例えば: |
+ | 起動中にできるだけ早く KMS をロードするには、[[ATI|radeon]]/[[AMDGPU|amdgpu]] (ATI/AMD カード向け)、[[Intel Graphics|i915]] (Intel 内蔵グラフィック向け)、[[Nouveau|nouveau]] (Nvidia カード向け) の内どれかのモジュールを、{{ic|/etc/mkinitcpio.conf}} の {{ic|MODULES}} 行に追加します。例えば: |
{{hc|/etc/mkinitcpio.conf|2=MODULES="... i915 ..."}} |
{{hc|/etc/mkinitcpio.conf|2=MODULES="... i915 ..."}} |
||
+ | |||
+ | {{Note|Intel ユーザーは ACPI のエラーを出さないために {{ic|i915}} の前に {{ic|intel_agp}} を追加する必要があるかもしれません。}} |
||
+ | |||
(生来の解像度に当てはまらない) カスタム EDID ファイルを使っている場合、同じように initramfs に埋め込む必要があります: |
(生来の解像度に当てはまらない) カスタム EDID ファイルを使っている場合、同じように initramfs に埋め込む必要があります: |
||
43行目: | 48行目: | ||
2=FILES="/usr/lib/firmware/edid/your_edid.bin"}} |
2=FILES="/usr/lib/firmware/edid/your_edid.bin"}} |
||
− | その後カーネルイメージを再生成してください (詳しくは [[ |
+ | その後カーネルイメージを再生成してください (詳しくは [[mkinitcpio]] を参照して下さい): |
− | + | # mkinitcpio -p <カーネルプリセットの名前; 例 ''linux''> |
|
==トラブルシューティング== |
==トラブルシューティング== |
||
===フォントが小さすぎる=== |
===フォントが小さすぎる=== |
||
− | [[フォント#デフォルトフォントを変更|デフォルトフォントを変更する方法]]を見てコンソールフォントを大きなフォントに代えてください。[community] にある |
+ | [[フォント#デフォルトフォントを変更|デフォルトフォントを変更する方法]]を見てコンソールフォントを大きなフォントに代えてください。[community] にある Terminus フォント ({{Pkg|terminus-font}}) には様々なサイズが含まれています。 |
===ブートロードの問題と dmesg=== |
===ブートロードの問題と dmesg=== |
||
+ | 古いシステムでは接続されたディスプレイデバイスのポーリングが重荷になることがあります。ポーリングは定期的に実行されるため、ハードウェアによっては最悪の場合、数百ミリ秒近く時間を取られます。動画を再生するときなど、絵面が止まってしまいます。10秒毎にディスプレイの出力が固まってしまうようなときは、ポーリングを無効化することで解決するかもしれません。 |
||
− | Polling for connected display devices on older systems can be quite expensive. Poll will happen periodically and can in worst cases take several hundred milliseconds, depending on the hardware. This will cause visible stalls, for example in video playback. These stalls might happen even when your video is on HDP output but you have other non HDP outputs in your hw configuration. If you experience stalls in display output occurring every 10 seconds, disabling polling might help. |
||
− | 起動中に 0x00000010 (2) のエラーコードが表示される場合 (10行近く表示され、最後にエラーコードが含まれているでしょう)、{{ic|/etc/modprobe.d/modprobe.conf}} に次の行を加えて下さい: |
+ | 起動中に {{ic|0x00000010 (2)}} のエラーコードが表示される場合 (10行近く表示され、最後にエラーコードが含まれているでしょう)、{{ic|/etc/modprobe.d/modprobe.conf}} に次の行を加えて下さい: |
options drm_kms_helper poll=0 |
options drm_kms_helper poll=0 |
||
==モードの強制と EDID== |
==モードの強制と EDID== |
||
− | {{Note|This section is a WIP. Improvements and corrections are more than welcome}} |
||
あなたの使っているモニターや TV が正しい [[Wikipedia:EDID|EDID]] データを送信しない、またはそれに類似した問題が発生している場合、実効解像度が自動的に設定されなかったり全く画面が表示されなかったりすることがあります。カーネルには EDID のバイナリデータをロードする仕組みがあり、最も一般的な4つの解像度を設定するデータも提供しています。 |
あなたの使っているモニターや TV が正しい [[Wikipedia:EDID|EDID]] データを送信しない、またはそれに類似した問題が発生している場合、実効解像度が自動的に設定されなかったり全く画面が表示されなかったりすることがあります。カーネルには EDID のバイナリデータをロードする仕組みがあり、最も一般的な4つの解像度を設定するデータも提供しています。 |
||
65行目: | 69行目: | ||
もしあなたが EDID ファイルを持っているならば話は簡単です。持っていない場合、組み込まれている EDID バイナリ (もしくはカーネルコンパイルで生成するバイナリ、詳細は [http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/plain/Documentation/EDID/HOWTO.txt ここ] を参照) のどれか一つを使うか自分で EDID を作って下さい。 |
もしあなたが EDID ファイルを持っているならば話は簡単です。持っていない場合、組み込まれている EDID バイナリ (もしくはカーネルコンパイルで生成するバイナリ、詳細は [http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/plain/Documentation/EDID/HOWTO.txt ここ] を参照) のどれか一つを使うか自分で EDID を作って下さい。 |
||
− | (例えばモニタの Windows ドライバから |
+ | (例えばモニタの Windows ドライバから抽出したり {{Pkg|read-edid}} の {{ic|get-edid}} コマンドを使って取得した) EDID ファイルを持っている場合、{{ic|/usr/lib/firmware}} の下に {{ic|edid}} ディレクトリを作成して: |
# mkdir /usr/lib/firmware/edid |
# mkdir /usr/lib/firmware/edid |
||
73行目: | 77行目: | ||
起動時にロードするために、カーネルコマンドラインで次を指定してください: |
起動時にロードするために、カーネルコマンドラインで次を指定してください: |
||
− | + | drm_kms_helper.edid_firmware=edid/your_edid.bin |
|
特定の接続だけで使うように指定することも可能です: |
特定の接続だけで使うように指定することも可能です: |
||
− | + | drm_kms_helper.edid_firmware=VGA-1:edid/your_edid.bin |
|
内蔵の4つの解像度を使うには、下の表を見て名前を指定してください: |
内蔵の4つの解像度を使うには、下の表を見て名前を指定してください: |
||
100行目: | 104行目: | ||
また、カーネルの {{ic|Documentation/EDID}} ソースに含まれている makefile を使って自分で EDID を組み立てることもできます。完全な情報は [http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/EDID/HOWTO.txt ここ] や [https://www.osadl.org/Single-View.111+M591850c02b5.0.html そこ] で読めます。 |
また、カーネルの {{ic|Documentation/EDID}} ソースに含まれている makefile を使って自分で EDID を組み立てることもできます。完全な情報は [http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/EDID/HOWTO.txt ここ] や [https://www.osadl.org/Single-View.111+M591850c02b5.0.html そこ] で読めます。 |
||
+ | {{Warning|以下の方法は不完全です。Xorg は指定された解像度を使用しなかったりします。上の方法を使うことを推奨します。ただし {{ic|1=video=}} コマンドラインで解像度を指定するのは場合によっては役立ちます。}} |
||
− | {{Warning|The method described below is somehow incomplete because e.g. Xorg does not take into account the resolution specified, so users are encouraged to use the method described above; however, specifying resolution with {{ic|1=video=}} command line may be useful in some scenarios}} |
||
[http://nouveau.freedesktop.org/wiki/KernelModeSetting the nouveau wiki] より: |
[http://nouveau.freedesktop.org/wiki/KernelModeSetting the nouveau wiki] より: |
||
129行目: | 133行目: | ||
コネクタの名前・状態を取得するために、次のワンライナーを使うことができます: |
コネクタの名前・状態を取得するために、次のワンライナーを使うことができます: |
||
− | {{hc|<nowiki>for p in /sys/class/drm/*/status; do con=${p%/status}; echo -n "${con#*/card?-}: "; cat $p; done</nowiki>| |
+ | {{hc|<nowiki>$ for p in /sys/class/drm/*/status; do con=${p%/status}; echo -n "${con#*/card?-}: "; cat $p; done</nowiki>| |
DVI-I-1: connected |
DVI-I-1: connected |
||
HDMI-A-1: disconnected |
HDMI-A-1: disconnected |
||
141行目: | 145行目: | ||
{{ic|nomodeset}} カーネルパラメータと共に、Intel のグラフィックカードでは {{ic|1=i915.modeset=0}} を Nvidia のグラフィックカードでは {{ic|1=nouveau.modeset=0}} をそれぞれ追加する必要があります。Nvidia の Optimus デュアルグラフィック環境では、3つのカーネルパラメータ全てを追加してください (つまり {{ic|1="nomodeset i915.modeset=0 nouveau.modeset=0"}})。 |
{{ic|nomodeset}} カーネルパラメータと共に、Intel のグラフィックカードでは {{ic|1=i915.modeset=0}} を Nvidia のグラフィックカードでは {{ic|1=nouveau.modeset=0}} をそれぞれ追加する必要があります。Nvidia の Optimus デュアルグラフィック環境では、3つのカーネルパラメータ全てを追加してください (つまり {{ic|1="nomodeset i915.modeset=0 nouveau.modeset=0"}})。 |
||
− | {{Note|KMS を無効にすると動作しない [[ |
+ | {{Note|KMS を無効にすると動作しない [[Xorg]] ドライバがあります。詳しくはあなたの使っているドライバの wiki ページを見て下さい。}} |
2016年2月17日 (水) 16:58時点における版
関連記事
Kernel Mode Setting (KMS) は、ユーザースペースではなくカーネル空間でディスプレイの解像度・色深度を設定する方法です。
Linux カーネルの KMS 機能ではフレームバッファでのネイティブ解像度や素早いコンソール (tty) 切り替えができるようになります。KMS を使うと、歪みを消去したり 3D パフォーマンスの上昇、カーネル空間の電力節約などをもたらす新しい技術 (DRI2 など) が有効になります。
目次
背景
昔、ビデオカードをセットアップするのは X サーバーの仕事でした。このため、バーチャルコンソールで派手なグラフィックを使うことは簡単ではありませんでした。また、X から バーチャルコンソール へ切り替えると (Ctrl+Alt+F1
)、X サーバーはカーネルにビデオカードのコントロールを移さなくてはならず、動作が重くなりチラツキが生じていました。同じ"痛々しい"挙動はコントロールを X サーバーに戻すときも起こりました (Ctrl+Alt+F7
)。
Kernel Mode Setting (KMS) によって、現在カーネルはビデオカードのモードを設定することができます。これによって、起動時からの派手なグラフィックや、バーチャルコンソールと X の早い切り替えなどが可能になりました。
インストール
まず、どの方法を使うにせよ、以下を常時無効にする必要があります:
- ブートローダ内のあらゆる
vga=
オプション。KMS によるネイティブ解像度と衝突します。 - フレームバッファを有効にするあらゆる
video=
行。ドライバと衝突します。 - 他のフレームバッファドライバ (uvesafb など)。
Late KMS start
Intel, Nouveau, ATI, AMDGPU ドライバでは既に全てのチップセットで KMS が自動的に有効になっています。そのため手動でインストールする必要はありません。
プロプライエタリの NVIDIA, AMD Catalyst ドライバはオープンドライバスタックを使いません。KMS を使うにはオープンソースドライバに代えてください。
Early KMS start
起動中にできるだけ早く KMS をロードするには、radeon/amdgpu (ATI/AMD カード向け)、i915 (Intel 内蔵グラフィック向け)、nouveau (Nvidia カード向け) の内どれかのモジュールを、/etc/mkinitcpio.conf
の MODULES
行に追加します。例えば:
/etc/mkinitcpio.conf
MODULES="... i915 ..."
(生来の解像度に当てはまらない) カスタム EDID ファイルを使っている場合、同じように initramfs に埋め込む必要があります:
/etc/mkinitcpio.conf
FILES="/usr/lib/firmware/edid/your_edid.bin"
その後カーネルイメージを再生成してください (詳しくは mkinitcpio を参照して下さい):
# mkinitcpio -p <カーネルプリセットの名前; 例 linux>
トラブルシューティング
フォントが小さすぎる
デフォルトフォントを変更する方法を見てコンソールフォントを大きなフォントに代えてください。[community] にある Terminus フォント (terminus-font) には様々なサイズが含まれています。
ブートロードの問題と dmesg
古いシステムでは接続されたディスプレイデバイスのポーリングが重荷になることがあります。ポーリングは定期的に実行されるため、ハードウェアによっては最悪の場合、数百ミリ秒近く時間を取られます。動画を再生するときなど、絵面が止まってしまいます。10秒毎にディスプレイの出力が固まってしまうようなときは、ポーリングを無効化することで解決するかもしれません。
起動中に 0x00000010 (2)
のエラーコードが表示される場合 (10行近く表示され、最後にエラーコードが含まれているでしょう)、/etc/modprobe.d/modprobe.conf
に次の行を加えて下さい:
options drm_kms_helper poll=0
モードの強制と EDID
あなたの使っているモニターや TV が正しい EDID データを送信しない、またはそれに類似した問題が発生している場合、実効解像度が自動的に設定されなかったり全く画面が表示されなかったりすることがあります。カーネルには EDID のバイナリデータをロードする仕組みがあり、最も一般的な4つの解像度を設定するデータも提供しています。
もしあなたが EDID ファイルを持っているならば話は簡単です。持っていない場合、組み込まれている EDID バイナリ (もしくはカーネルコンパイルで生成するバイナリ、詳細は ここ を参照) のどれか一つを使うか自分で EDID を作って下さい。
(例えばモニタの Windows ドライバから抽出したり read-edid の get-edid
コマンドを使って取得した) EDID ファイルを持っている場合、/usr/lib/firmware
の下に edid
ディレクトリを作成して:
# mkdir /usr/lib/firmware/edid
それからバイナリを /usr/lib/firmware/edid
ディレクトリにコピーしてください。
起動時にロードするために、カーネルコマンドラインで次を指定してください:
drm_kms_helper.edid_firmware=edid/your_edid.bin
特定の接続だけで使うように指定することも可能です:
drm_kms_helper.edid_firmware=VGA-1:edid/your_edid.bin
内蔵の4つの解像度を使うには、下の表を見て名前を指定してください:
解像度 | 指定する名前 |
1024x768 | edid/1024x768.bin |
1280x1024 | edid/1280x1024.bin |
1600x1200 (カーネル 3.10 以上) | edid/1600x1200.bin |
1680x1050 | edid/1680x1050.bin |
1920x1080 | edid/1920x1080.bin |
KMS を初期に実行するようにしている場合は、カスタム EDID ファイルを initramfs に含めないと起動時に問題が発生します。
また、カーネルの Documentation/EDID
ソースに含まれている makefile を使って自分で EDID を組み立てることもできます。完全な情報は ここ や そこ で読めます。
the nouveau wiki より:
カーネルコマンドラインから強制的にモードを選ぶこともできます。残念ながら、DRM に関するコマンドラインオプションはあまりドキュメント化されていません。使い方の簡単な説明はここにあります:
- http://cgit.freedesktop.org/nouveau/linux-2.6/tree/Documentation/fb/modedb.txt
- http://cgit.freedesktop.org/nouveau/linux-2.6/tree/drivers/gpu/drm/drm_fb_helper.c
フォーマットは:
video=<conn>:<xres>x<yres>[M][R][-<bpp>][@<refresh>][i][m][eDd]
- <conn>: コネクタ、例: DVI-I-1。利用できる接続は
/sys/class/drm/
を見て下さい。 - <xres> x <yres>: 解像度
- M: compute a CVT mode?
- R: reduced blanking?
- -<bpp>: 色深度
- @<refresh>: リフレッシュレート
- i: インターレース化 (non-CVT mode)
- m: 余白
- e: 出力強制 ON
- d: 出力強制 OFF
- D: デジタル出力強制 ON (e.g. DVI-I connector)
"video" を使うことでアウトプットのモードを上書きすることができます、例えば、DVI 出力、1024x768、85 Hz、TV 出力オフに強制するには:
video=DVI-I-1:1024x768@85 video=TV-1:d
コネクタの名前・状態を取得するために、次のワンライナーを使うことができます:
$ for p in /sys/class/drm/*/status; do con=${p%/status}; echo -n "${con#*/card?-}: "; cat $p; done
DVI-I-1: connected HDMI-A-1: disconnected VGA-1: disconnected
モードセッティングを無効にする
Catalyst ドライバを使っているときなど、ブランクスクリーンになったりディスプレイに "no signal" エラーがでたりするなどの理由で KMS を無効にしたい時があるかもしれません。KMS を無効にするには、カーネルパラメータに nomodeset
を追加します。詳しくはカーネルパラメータを見て下さい。
nomodeset
カーネルパラメータと共に、Intel のグラフィックカードでは i915.modeset=0
を Nvidia のグラフィックカードでは nouveau.modeset=0
をそれぞれ追加する必要があります。Nvidia の Optimus デュアルグラフィック環境では、3つのカーネルパラメータ全てを追加してください (つまり "nomodeset i915.modeset=0 nouveau.modeset=0"
)。