コンテンツにスキップ

「KMSCON」の版間の差分

提供: ArchWiki
削除された内容 追加された内容
Pkg/AUR テンプレートの更新
Oech3 (トーク | 投稿記録)
マージされたフォークを削除インストール
 
(5人の利用者による、間の12版が非表示)
9行目: 9行目:
[https://github.com/dvdhrm/kmscon プロジェクトの GitHub ページ]より:
[https://github.com/dvdhrm/kmscon プロジェクトの GitHub ページ]より:


:''Kmscon は linux のカーネルモードセッティング (KMS) を使ったシンプルなターミナルエミュレータです。カーネルの VT 実装をユーザスペースのコンソールで置き換えようという試みです。''
:''Kmscon は linux のカーネルモード設定 (KMS) を使ったシンプルなターミナルエミュレータです。カーネルの VT 実装をユーザスペースのコンソールで置き換えようという試みです。''


== 機能 ==
== 機能 ==
26行目: 26行目:
== インストール ==
== インストール ==


その名前にかかわらず、KMS は kmscon に絶対必要というわけではありません。Kmscon は次のビデオバックエンドをサポートしています: fbdev (Linux fbdev ビデオバックエンド), drm2d (Linux DRM ソフトウェアレンダリングバックエンド), drm3d (Linux DRM ハードウェアレンダリングバックエンド)。あなたの環境でこの中のどれかひとつでも利用できるようにしてください。
KMS は kmscon に絶対必要というわけではありません。Kmscon は次のビデオバックエンドをサポートしています: fbdev (Linux fbdev ビデオバックエンド), drm2d (Linux DRM ソフトウェアレンダリングバックエンド), drm3d (Linux DRM ハードウェアレンダリングバックエンド)。あなたの環境でこの中のどれかひとつでも利用できるようにしてください。


[[公式リポジトリ]]から {{AUR|kmscon}} をインストールしてください。もしくは、[[Arch User Repository|AUR]] から {{AUR|kmscon-git}} をインストールすることも可能です
{{AUR|kmscon}} もしくは開発版の {{AUR|kmscon-git}} をインストールしてください


TTY1 で kmscon を使えるようにするには、以下を実行してください:
TTY1 で kmscon を使えるようにするには、以下を実行してください:
{{bc|
{{bc|
# rm /etc/systemd/system/getty.target.wants/getty@tty1.service
# systemctl disable getty@tty1.service
# systemctl enable kmsconvt@tty1.service
# systemctl enable kmsconvt@tty1.service
}}
}}


全ての仮想端末で kmscon を有効にする場合は、root で、以下を実行してください:
== Getty (agetty) を置き換える ==


root で、以下を実行してください:
{{bc|
{{bc|
# ln -s /usr/lib/systemd/system/kmsconvt\@.service /etc/systemd/system/autovt\@.service
# ln -s /usr/lib/systemd/system/kmsconvt\@.service /etc/systemd/system/autovt\@.service
45行目: 44行目:


何らかの理由で kmscon が実行できないときは、代わりに getty@.service が起動されます。そのため問題が生じても動作を継続するためのフォールバックが常に存在します。さらに、VT が利用できない場合、このユニットは何も起動しません。
何らかの理由で kmscon が実行できないときは、代わりに getty@.service が起動されます。そのため問題が生じても動作を継続するためのフォールバックが常に存在します。さらに、VT が利用できない場合、このユニットは何も起動しません。

{{Warning|すべてのターミナルで agetty 置き換えた場合は、マシンを再起動する前に kmscon からプロンプトが表示されることを確認してください。そうでない場合は、ライブ CD からリカバリする必要があります。}}


== CJK サポート ==
== CJK サポート ==
66行目: 67行目:
== トラブルシューティング ==
== トラブルシューティング ==


* [[Xorg]] と kmscon の切り替えに問題が発生する場合は ExecStart に {{ic|--hwaccel --drm}} を追加するとよいかもしれません。
=== Xorg と kmscon の切り替えに問題が発生する ===

[[Xorg]] と kmscon の切り替えに問題が発生する場合は ExecStart に {{ic|--hwaccel --drm}} を追加するとよいかもしれません。
ExecStart=/usr/bin/kmscon "--vt=%I" --seats=seat0 --no-switchvt --font-name Terminus --font-size 12 --hwaccel --drm
ExecStart=/usr/bin/kmscon "--vt=%I" --seats=seat0 --no-switchvt --font-name Terminus --font-size 12 --hwaccel --drm

* バージョン 7 で、オーディオをコントロールできない場合、ユーザーを '''audio''' [[ユーザーとグループ#グループ管理|グループ]]に追加してください。ただしグループに追加すると[[Advanced Linux Sound Architecture#インストール|問題]]が発生します。
=== 音声を制御できない ===

バージョン 7 で、オーディオをコントロールできない場合、ユーザーを '''audio''' [[ユーザーとグループ#グループ管理|グループ]]に追加してください。ただしグループに追加すると[[Advanced Linux Sound Architecture#インストール|問題]]が発生します。

=== Vim で端末の出力が消去されない ===

Vim を開いたときに端末の出力が消えない場合があります。ファイルの編集は可能ですがテキストが変更するまで表示されません。回避策として、{{ic|1=TERM=vt220}} [[環境変数]]を設定してみてください。もしくは、{{Pkg|vi}} や [[Neovim]] などの vi ライクなテキストエディタを使ってください。
{{Note|{{ic|TERM}} を {{ic|vt220}} に設定した場合、カラーのサポートが利用できません。}}

=== 自動ログイン ===

これを {{ic|/etc/kmscon/kmscon.conf}} に追加することで、パスワードを要求せずにユーザーを自動的にログインさせることができます。

# Modify this command to do what you need
# Example: Login an user asking for user and password
login=/bin/bash --login
# Example: Login an user without asking for password
login=/bin/bash -c su <your_username>

=== HiDPI のサポート ===

{{ic|Ctrl++}}、{{ic|1=Ctrl+Shift+=}}、{{ic|Ctrl+-}} のショートカットを使用して、その場でフォントサイズを変更できます。また、{{ic|/etc/kmscon/kmscon.conf}} で 'font-dpi' と 'font-size' を設定することもできます。たとえば、'font-dpi=288' 288 は 96 * 3、つまり 300% のスケーリングです。96 がデフォルトです。

=== KMS コンソールからウィンドウマネージャーを起動できない ===

コマンドラインから [https://github.com/dvdhrm/kmscon/issues/65 startx] や [https://github.com/Cloudef/wlc/issues/206 sway] などを使用して Xorg や Wayland セッションを起動しようとすると失敗します。
この目的のために従来の非 KMS tty を使用するか、ログインマネージャーを利用してください。

2025年12月1日 (月) 21:13時点における最新版

関連記事

プロジェクトの GitHub ページより:

Kmscon は linux のカーネルモード設定 (KMS) を使ったシンプルなターミナルエミュレータです。カーネルの VT 実装をユーザスペースのコンソールで置き換えようという試みです。

機能

Kmscon はカーネル内蔵の linux コンソールの互換品として機能します。以下の機能が存在します:

  • vt220 から vt510 までの完全な実装。
  • 国際化の完全サポート:
    • Kmscon は CJK を含む、Unicode 文字を全て表示できます。
    • Kmscon は libxkbcommon を使って国際化キーボードを扱えるため、X キーボードでサポートされている全てのキーボードレイアウトを利用することが可能です。
  • ハードウェアアクセラレーションを使ったレンダリング。
  • Multi-seat 可能。
ノート root で kmscon コンソールにログインするには、pam_securetty モジュールを無効にする必要があります。/etc/pam.d/login 内の適切な行を削除・コメントアウトしてください。

インストール

KMS は kmscon に絶対必要というわけではありません。Kmscon は次のビデオバックエンドをサポートしています: fbdev (Linux fbdev ビデオバックエンド), drm2d (Linux DRM ソフトウェアレンダリングバックエンド), drm3d (Linux DRM ハードウェアレンダリングバックエンド)。あなたの環境でこの中のどれかひとつでも利用できるようにしてください。

kmsconAUR もしくは開発版の kmscon-gitAUR をインストールしてください。

TTY1 で kmscon を使えるようにするには、以下を実行してください:

# systemctl disable getty@tty1.service
# systemctl enable kmsconvt@tty1.service

全ての仮想端末で kmscon を有効にする場合は、root で、以下を実行してください:

# ln -s /usr/lib/systemd/system/kmsconvt\@.service /etc/systemd/system/autovt\@.service

これで systemd がそれぞれの VT で agetty の代わりに kmscon を起動するようになります。より正確に言うと、このコマンドは systemd-logind が新しい VT で getty@.service の代わりに kmsconvt@.service を使うようにさせます。getty@.service を使っている他のユニットやスクリプトにはこの変更が適用されません。

何らかの理由で kmscon が実行できないときは、代わりに getty@.service が起動されます。そのため問題が生じても動作を継続するためのフォールバックが常に存在します。さらに、VT が利用できない場合、このユニットは何も起動しません。

警告 すべてのターミナルで agetty 置き換えた場合は、マシンを再起動する前に kmscon からプロンプトが表示されることを確認してください。そうでない場合は、ライブ CD からリカバリする必要があります。

CJK サポート

Kmscon はデフォルトのフォントエンジン pango を通して CJK 文字のレンダリングをサポートしています。ただし、モノスペースフォントのエイリアスを適切な CJK フォントにマップするよう fontconfig を設定する必要があります。日本語ユーザーは、以下のテンプレートで日本語を表示できます:

/etc/fonts/conf.d/99-kmscon.conf
<?xml version="1.0"?>
<!DOCTYPE fontconfig SYSTEM "fonts.dtd">
<fontconfig>
<match>
        <test name="family"><string>monospace</string></test>
        <edit name="family" mode="prepend" binding="strong">
                <string>DejaVu Sans Mono</string>
                <string>IPAGothic</string>
        </edit>
</match>
</fontconfig>

ttf-dejavuotf-ipafont をインストールしてください。両方とも公式リポジトリに含まれています。

トラブルシューティング

Xorg と kmscon の切り替えに問題が発生する

Xorg と kmscon の切り替えに問題が発生する場合は ExecStart に --hwaccel --drm を追加するとよいかもしれません。

 ExecStart=/usr/bin/kmscon "--vt=%I" --seats=seat0 --no-switchvt --font-name Terminus --font-size 12 --hwaccel --drm

音声を制御できない

バージョン 7 で、オーディオをコントロールできない場合、ユーザーを audio グループに追加してください。ただしグループに追加すると問題が発生します。

Vim で端末の出力が消去されない

Vim を開いたときに端末の出力が消えない場合があります。ファイルの編集は可能ですがテキストが変更するまで表示されません。回避策として、TERM=vt220 環境変数を設定してみてください。もしくは、viNeovim などの vi ライクなテキストエディタを使ってください。

ノート TERMvt220 に設定した場合、カラーのサポートが利用できません。

自動ログイン

これを /etc/kmscon/kmscon.conf に追加することで、パスワードを要求せずにユーザーを自動的にログインさせることができます。

 # Modify this command to do what you need
 
 # Example: Login an user asking for user and password
 login=/bin/bash --login
 
 # Example: Login an user without asking for password
 login=/bin/bash -c su <your_username>

HiDPI のサポート

Ctrl++Ctrl+Shift+=Ctrl+- のショートカットを使用して、その場でフォントサイズを変更できます。また、/etc/kmscon/kmscon.conf で 'font-dpi' と 'font-size' を設定することもできます。たとえば、'font-dpi=288' 288 は 96 * 3、つまり 300% のスケーリングです。96 がデフォルトです。

KMS コンソールからウィンドウマネージャーを起動できない

コマンドラインから startxsway などを使用して Xorg や Wayland セッションを起動しようとすると失敗します。 この目的のために従来の非 KMS tty を使用するか、ログインマネージャーを利用してください。