ディスプレイサーバ

ウィキペディアから無料の百科事典

ディスプレイサーバとは、ウィンドウシステムにおいて、ポインティングデバイスキーボードディスプレイハードウェア制御を行い、遠隔または同一のコンピュータ上で動作する他のプログラムに対し、ポインティングデバイス・キーボード・ディスプレイによる入出力の機能を提供するプログラムである。


機能の提供はディスプレイサーバプロトコルと呼ばれる通信プロトコルを通じて行われる。

ディスプレイサーバはグラフィカルユーザーインターフェースを構成する基本コンポネートで、ウィンドウマネージャを実装します。単純なウィンドウマネージャーはウィンドウの描画のみを行いますが、コンポジットウィンドウマネージャの場合より多くのことを行います。

利用可能なプロトコル[編集]

X11[編集]

X.Org サーバは、X11プロトコルを介してクライアントと通信します。

X.Org Serverは、通常、LinuxBSDなどのUnixベースのカーネル上で動作する。 X.Org Serverは、ユーザー入力クライアントからデータを受け取り、処理・合成し、LinuxではDRMgemKMSなどのカーネルコンポーネントに出力する。 カーネルコンポーネントは受け取ったデータをフレームバッファに書き込み、画面に表示する。 XはGLX依存している。

ディスプレイサーバの概念実装したものとして、 X Windowシステムがある。実際に使われているものとしては、X.Org サーバおよび XlibXCBなどがある。 X.Org サーバはディスプレイサーバだが、現在の実装では、MutterKwinといったコンポジットウィンドウマネージャに依存している。

有名なX11プロトコルを実装したディスプレイサーバの例としては、 X.Org サーバや XFree86XQuartzCygwin/Xなどがある。クライアント向けのライブラリとしてはXlibやXCBがある。

 xevと呼ばれるUnixコマンドは、ウィンドウを作成し、ウィンドウに発生したイベントの情報(リサイズやキーボードからの入力、マウスクリックなど)を送信するようディスプレイサーバに要求し、受け取った情報をコンソールに出力する。

Wayland[編集]

Waylandのプロトコル

Waylandのプロトコルを実装するディスプレイサーバは、Waylandコンポジットと呼ばれる。Waylandコンポジットは、クライアントに対する入出力を処理する。X11とは違い、コンポジットも担当する。Waylandを実装したものとしては、 Weston[1]MutterKwinEnlightenment[2]などがある。

Waylandコンポジットは、Waylandディスプレイサーバプロトコルを使用してクライアントと通信する。このプロトコルは、EGLレンダリングAPIのフレームバッファを利用し、クライアントが直接データーを出力できるように定義されている。また、ディスプレイサーバは、どのウィンドウが最上部に位置するか、つまりユーザーが何を見えるのかを判断し、ディスプレイに表示する。また、evdev英語版からクライアントへの情報の伝達にも責任を負う。

WaylandはFedoraなどいくつかのLinuxディストリビューションで採用されている[3]。また、Waylandはモバイルにも適しており、TizenSalifish OSといったスマートフォンやタブレット向けのプロジェクトでも採用されている。

Waylandの実装はMITライセンスで提供されているlibwayland-clientとlibwayland-serverを使うことで使用可能となる。

また、WaylandをChromeOSに実装するプロジェクトが進行中である[4]

Mir[編集]

Mirは、Ubuntuのディスプレイサーバに採用されることを目的にカノニカルによって開発されたが、2017年にUbuntuのディスプレイサーバはWaylandに変更された。Mirは、X11やWaylandに使われているものとは異なる、独自のMirディスプレイサーバプロトコルを使用するが、X11プロトコルもサポートする[5]

Mirの実装は、GPLv3でライセンスされたlibmir-serverとlibmir-clientのもとで利用することができる。

SurfaceFlinger[編集]

SurfaceFlingerは、Android用にGoogleによって開発されたディスプレイサーバである。

Androidのコンポーネントは、全て"surface"にレンダリングされる。"surface"は、アプリケーションによって生成され、SurfaceFlingerによって管理されるキューに入れられる。[6][7]

また、Android特有のものとして、デバイスのメモリの割当や仲裁、ファイル記述子の同期といったメモリ管理を行う"Gralloc"がある。Grallocは、GBMやNvidiaのEGLStreamsなどと競合する。Grallocのハードウェア抽象化レイヤ (HAL) は、"surface"の基礎となるバッファを割り当てるために使用される。

Androidでコンポジットを行うとき、SurfacesはSurfaceFlingerに送られ、OpenGL ESを使用して合成が行われる。

HWCはAndroid 3.0にて導入され、開発が続いている。HWCの主要な目的は、 ハードウェアを用いた合成時の効率を上げることである。HALの実装は各端末により異なり、通常はOEMが担当する。

Quartz[編集]

ApplemacOSの描画エンジン。Quartzは、ディスプレイサーバの機能とウィンドウシステム内のウィンドウマネージャの機能を実装している。

Desktop Window Manager (DWM)[編集]

Desktop Window Managerは、Windows Vista以降のMicrosoft Windowsに導入された。GUIの描画にハードウェアアクセラレーションを使用する。DWMは、"Windows Aero"の機能である透明化や、3Dのウィンドウ切り替えなどを行う。DWMはWindows Server 2008でも使用可能だが、"Desktop Experience"を有効にし、互換性のあるグラフィックドライバインストールする必要がある。

脚注[編集]

  1. ^ Wayland”. wayland.freedesktop.org. 2023年12月30日閲覧。
  2. ^ Wayland”. www.enlightenment.org. 2023年12月30日閲覧。
  3. ^ Why Wayland Anyway?”. Goings On. Matthias Clasen. 2016年6月17日閲覧。
  4. ^ Ozone Overview”. 2017年8月20日閲覧。
  5. ^ ThomasVo5 (2013年3月4日). “[Updated Mir – An outpost envisioned as a new home]”. tvoss@work. 2017年8月5日閲覧。
  6. ^ Android Developer: Surface”. 2020年3月8日閲覧。
  7. ^ Android Developer: SurfaceFlinger and Hardware Composer”. 2020年3月8日閲覧。

関連項目[編集]