Давайте разберемся...
X Window System — оконная система, обеспечивающая стандартные инструменты и протоколы для построения графического интерфейса пользователя. Используется в UNIX-подобных ОС.
X Window System обеспечивает базовые функции графической среды: отрисовку и перемещение окон на экране, взаимодействие с мышью и клавиатурой. X Window System не определяет деталей интерфейса пользователя — этим занимаются менеджеры окон, которых разработано множество. По этой причине внешний вид программ в среде X Window System может очень сильно различаться в зависимости от возможностей и настроек конкретного оконного менеджера.
В X Window System предусмотрена сетевая прозрачность: графические приложения могут выполняться на другой машине в сети, а их интерфейс при этом будет передаваться по сети и отображаться на локальной машине пользователя (в случае если это разрешено в настройках). В контексте X Window System термины «клиент» и «сервер» имеют непривычное для многих пользователей значение: «сервер» означает локальный дисплей пользователя (дисплейный сервер), а «клиент» — программу, которая этот дисплей использует (она может выполняться на удалённом компьютере).
Wayland — графический сервер для Linux и других UNIX-подобных операционных систем. Разработка Wayland была начата Кристианом Хогсбергом (англ. Kristian Høgsberg), членом «Центра открытых технологий Intel» (англ. Intel's Open Source Technology Center) и сотрудником Red Hat. Wayland является свободным ПО и распространяется под лицензией MIT.
Архитектура Wayland
Хороший способ понять wayland архитектуру и как это отлично X, состоит в том, чтобы следовать за случаем от входного устройства к сути, где изменение, которое это затрагивает, появляется на экране.Это - то, где мы теперь с X:
- Ядро получает случай от входного устройства и посылает это в X через входного водителя evdev. Ядро делает всю тяжелую работу здесь, ведя устройство, и переводя различные протоколы специфического события устройства к linux evdev вводят стандарт случая.
- X серверов определяют, какое окно случай затрагивает и посылает им клиентам, которые выбрали для рассматриваемого случая на том окне. X серверов фактически не знают, как сделать это правильно, так как местоположение окна на экране управляется наборщиком и может быть преобразовано многими способами, которыми X серверов не понимают (сокращенный, вращаемый, колебание, и т.д).
- Клиент смотрит на случай и решает, что сделать. Часто UI должен будет измениться в ответ на случай - возможно, флажком щелкнули, или указатель вошел в кнопку, которая должна быть выдвинута на первый план. Таким образом клиент отсылает запрос предоставления назад к X серверам.
- Когда X серверов получают запрос предоставления, они посылают это водителю, чтобы позволить этому программировать аппаратные средства, чтобы сделать предоставление. X серверов также вычисляют область ограничения предоставления, и посылают это наборщику как случай повреждения.
- Случай повреждения говорит наборщику, что кое-что измененное в окне и что у этого есть к пересоединению часть экрана, где то окно видимо. Наборщик ответственен за предоставление всего содержания экрана, основанного на его scenegraph и содержании этих X окон. Все же, это должно пройти X серверов, чтобы отдать этому.
- X серверов получают запросы предоставления от наборщика и или копируют наборщика, назад буферизуют на передний буфер, или делает pageflip. В общем случае X серверов должны сделать этот шаг, таким образом это может составлять наложившиеся окна, которые могут потребовать обрыва и определить, может ли это пролистать щелчок. Однако, для наборщика, который всегда является fullscreen, это - другой ненужный выключатель контекста.
В wayland наборщик - сервер показа. Мы передаем контроль КМ/СЕК и evdev наборщику. wayland протокол позволяет наборщику посылать входные события непосредственно клиентам и позволяет клиенту посылать случай повреждения непосредственно наборщику:
- Ядро получает случай и посылает это наборщику. Это подобно X случаям, которые являются большими, так как мы добираемся, чтобы снова использовать всех входных водителей в ядре.
- Наборщик просматривает его scenegraph, чтобы определить, какое окно должно получить случай. scenegraph соответствует тому, что находится на экране, и наборщик понимает преобразования, что это, возможно, относилось к элементам в scenegraph. Таким образом, наборщик может выбрать правильное окно и преобразовать координаты экрана к окну местные координаты, применяя обратные преобразования. Типы преобразования, которое может быть применено к окну, только restriced к тому, что может сделать наборщик, пока оно может вычислить обратное преобразование для входных событий.
- Как в X случаях, когда клиент получает случай, это обновляет UI в ответе. Но в wayland случае, предоставление случается в клиенте, и клиент только посылает запрос наборщику указать область, которая была обновлена.
- Наборщик собирает запросы повреждения от его клиентов и затем пересоединений экран. Наборщик может тогда непосредственно выпустить ioctl, чтобы наметить pageflip с КМ/СЕК.
Предоставление Wayland
Одни из деталей, которые я не учел в вышеупомянутом кратком обзоре, - то, как клиенты фактически отдают под wayland. Удаляя X серверов из картины мы также удалили механизм, которым X клиентов типично отдают. Но есть другой механизм, который мы уже используем с DRI2 под X: прямое предоставление. С прямым предоставлением клиент и сервер разделяют видео буфер памяти. Клиент связывается с библиотекой предоставления, такой как OpenGL, который знает, как программировать аппаратные средства и отдает непосредственно в буфер. Наборщик в свою очередь может взять буфер и использовать его как структуру когда он соединения рабочий стол. После начальной установки клиент только должен сказать наборщику, которые буферизуют, чтобы использовать и когда и где она отдала новое содержание в это.Это оставляет заявление с двумя способами обновить его содержание окна:
- Отдайте новое содержание в новый буфер и скажите наборщику использовать это вместо старого буфера. Заявление может ассигновать новый буфер каждый раз, когда оно должно обновить содержание окна, или оно может держать два (или больше) буфера вокруг и цикл между ними. Буферное управление находится полностью под прикладным контролем.
- Отдайте новое содержание в буфер, которому оно ранее сказало наборщику использовать. В то время как возможно только отдать непосредственно в буфер, которым разделяют с наборщиком, это могло бы мчаться с наборщиком. То, что может случиться, - то, что перекрашивание содержания окна могло быть прервано наборщиком, перекрашивающим рабочий стол. Если заявление будет прервано только после прояснения окна, но прежде, чем отдать содержание, то наборщик будет структура от чистого буфера. Результат состоит в том, что прикладное окно будет мерцать между декоративным окном или полуотдавало содержание. Традиционный способ избежать этого состоит в том, чтобы отдать новое содержание в обратный буфер и затем скопировать оттуда в поверхность наборщика. Обратный буфер может быть ассигнован на лету и только достаточно большой, чтобы держать новое содержание, или заявление может иметь в наличии буфер. Снова, это находится под прикладным контролем.
Настолько грубый перевод оригинального текста, что глазам больно читать.
ОтветитьУдалить