「Uvesafb」の版間の差分
(→Uvesafb cannot reserve memory: 情報を更新) |
(項目を整理) |
||
80行目: | 80行目: | ||
独自のカーネルをコンパイルする場合は、uvesafb をカーネルにコンパイルし、後で v86d を実行することもできます。この場合、オプションは {{ic|1=video=uvesafb:''options''}} の形式で [[カーネルパラメータ]] として渡すことができます。 |
独自のカーネルをコンパイルする場合は、uvesafb をカーネルにコンパイルし、後で v86d を実行することもできます。この場合、オプションは {{ic|1=video=uvesafb:''options''}} の形式で [[カーネルパラメータ]] として渡すことができます。 |
||
− | |||
− | == Uvesafb と 915resolution == |
||
− | |||
− | 以下では、より複雑なシナリオについて説明します。ワイドスクリーンラップトップ用の多くのインテルビデオチップセットには、バグのあるBIOSが搭載されていることが知られています。これは、ワイドスクリーンのメインのネイティブ解像度をサポートしていません。このため、ブート時にBIOSにパッチを適用し、Xサーバーがワイドスクリーンの解像度を使用できるようにするために、915resolutionが作成されました。今日、Xサーバーは915resolutionの助けなしでこれを行うことができます。ただし、915resolutionをuvesafbと組み合わせると、Xを起動することなく、ワイドスクリーンフレームバッファーを取得できます。この場合、915resolutionを実行した後でuvesafbをロードして、uvesafbが適切な解像度に頼れるようにする必要があります。 |
||
− | |||
− | === 915resolution-static === |
||
− | |||
− | このシナリオでは、915解像度を静的にコンパイルする必要があります(initramfsに置かれるので、外部ライブラリにリンクすることはできません。)。したがって、 [community] リポジトリで915 resolutionパッケージを使用することはできません。代わりに、AURで {{AUR|915resolution-static}}{{Broken package link|{{aur-mirror|915resolution-static}}}} {{aur-mirror | 915resolution-static}}}}を探してください。 これは915解像度を静的にコンパイルし、915解像度フックを提供しますので、uvesafbをロードする前に915解像度を実行して、パッチされた解像度を得ることができます。makepkgと[[pacman]]を使って915 resolution-staticをインストールしてください。 |
||
− | |||
− | === 解像度 === |
||
− | |||
− | 交換するBIOSモードと取得する解像度を定義するには、915resolutionフックを編集する必要があります。あなたは915resolutionのすべてのオプションについての情報を得ることができます。 |
||
− | |||
− | $ 915resolution -h |
||
− | |||
− | {{ic|/lib/initcpio/hooks/915resolution}} を編集して915resolutionのオプションを変更します。 |
||
− | |||
− | run_hook () |
||
− | { |
||
− | msg -n ":: Patching the VBIOS..." |
||
− | /usr/sbin/915resolution 5c 1280 800 |
||
− | msg "done." |
||
− | } |
||
− | |||
− | デフォルトとして、5cは、置き換えるBIOSモードのコードです。次のコマンドを使用して、使用可能なBIOSビデオモードのリストを取得できます {{ic|915resolution -l}} |
||
− | {{Note|915resolutionはそれを新しいユーザー定義モードに置き換えるので、(フレームバッファーでもXでも)不要なモードのコードを選択する必要があります。上記の例では、{{ic|1280 800}} が新しい望ましい解像度です。}} |
||
− | |||
− | === HOOKS === |
||
− | |||
− | 915resolutionフックを追加し、その後、{{ic | /etc/mkinitcpio.conf}}のHOOKSにv86dフックを追加します。keymap、resume from suspension、をfilesystemのフックの前に置きます。 |
||
− | HOOKS="base udev 915resolution v86d ..." |
||
− | |||
− | 次に、mkinitcpioを使用してinitramfsを再生成する必要があります(次のコマンドを設定に合わせて調整してください) |
||
− | |||
− | mkinitcpio -p linux |
||
== トラブルシューティング == |
== トラブルシューティング == |
||
123行目: | 88行目: | ||
もしくは {{ic|1=video=vesa:off vga=normal}} を [[カーネルコマンドライン]] に追加してみてください。 |
もしくは {{ic|1=video=vesa:off vga=normal}} を [[カーネルコマンドライン]] に追加してみてください。 |
||
− | |||
− | === Error: "pci_root PNP0A08:00 address space collision + Uvesafb cannot reserve memory" === |
||
− | |||
− | これは2.6.34-ARCHカーネルを搭載したAcer Aspire One 751hで発生します。他のシステムでも発生するかどうかは不明です。別のフレームバッファーがuvesafbのセットアップに干渉しない場合でも、uvesafbは必要なメモリー領域を予約できません。 |
||
− | |||
− | この問題は、ブートローダーの設定でカーネルパラメータに以下を追加することで修正できます。 |
||
− | |||
− | pci=nocrs |
||
== 参照 == |
== 参照 == |
2023年10月26日 (木) 12:50時点における版
他のフレームバッファドライバーと違って、uvesafb は v86d と呼ばれるユーザースペースの仮想化デーモンを必要とします。x86 の上で x86 のコードをエミュレートするのは馬鹿げているようにも見えますが、他のアーキテクチャでフレームバッファコードを使用したいという場合に大事になります (特に x86 以外のアーキテクチャ)。カーネル 2.6.24 では新しいフレームバッファドライバーが追加されました。標準の vesafb よりも多くの機能が存在します:
- 遅延時間後の正しいブランクとハードウェアの復帰
- システム BIOS のようにカスタム解像度をサポート。
vesafb と同じ数だけのハードウェアをサポートします。
目次
インストール
AUR から uvesafb-dkmsAUR パッケージを インストール してください。
設定
フレームバッファ関連のカーネルブートパラメータは全てブートローダーの設定から削除して vesafb フレームバッファがロードされないようにしてください。
$ grep vga /proc/cmdline $ grep -ir vga /etc/modprobe.d/
上記のコマンドで何も返ってこないようにする必要があります。vga=
オプションを記述している場合は、削除してください。
ブートマネージャー
GRUB
まず /etc/default/grub
を編集して GRUB_GFXPAYLOAD_LINUX=keep
行をコメントアウトし
GRUB legacy
uvesafb が正しく動作するように /boot/grub/menu.lst
の kernel 行から vga=xxx
という記述を全て削除してください。
mkinitcpio フック
v86d フックを /etc/mkinitcpio.conf
の HOOKS に追加します。これにより、ブート時に uvesafb が引き継ぐことができます。
HOOKS="base udev v86d ..."
解像度の定義
uvesafb の設定は /usr/lib/modprobe.d/uvesafb.conf
で定義します:
mode_option
のドキュメントは [1] にあります。
パッケージが更新されたときにカスタマイズした設定が上書きされないように、ファイルを /etc/modprobe.d/uvesafb.conf
にコピーしてください:
# cp /usr/lib/modprobe.d/uvesafb.conf /etc/modprobe.d/uvesafb.conf
そして /etc/mkinitcpio.conf
の FILES セクションのエントリに設定ファイルを追加します:
FILES="/etc/modprobe.d/uvesafb.conf"
変更を有効にするには、initramfs を再生成 し、システムを再起動します。
解像度の最適化
次のコマンドを使うことで使用できる解像度を全てリストアップできます:
$ cat /sys/bus/platform/drivers/uvesafb/uvesafb.0/vbe_modes
返ってきたエントリを使って /usr/lib/modprobe.d/uvesafb.conf
を修正しましょう。
現在の解像度のチェック
以下のコマンドを使うことで現在のフレームバッファの解像度を表示できます。設定が反映されているかどうか確認するのに使ってください:
$ cat /sys/devices/virtual/graphics/fbcon/subsystem/fb0/virtual_size
$ cat /sys/class/graphics/fb0/virtual_size
カーネルモジュールパラメータ
独自のカーネルをコンパイルする場合は、uvesafb をカーネルにコンパイルし、後で v86d を実行することもできます。この場合、オプションは video=uvesafb:options
の形式で カーネルパラメータ として渡すことができます。
トラブルシューティング
Uvesafb cannot reserve memory
vga=xxx
カーネルパラメータを削除するのを忘れてないか確認してください -- この設定が残っていると UVESA フレームバッファが標準の VESA フレームバッファで上書きされてしまいます。
もしくは video=vesa:off vga=normal
を カーネルコマンドライン に追加してみてください。