From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on sa.local.altlinux.org X-Spam-Level: X-Spam-Status: No, score=-3.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,RP_MATCHES_RCVD,UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.1 DKIM-Filter: OpenDKIM Filter v2.11.0 zen.imath.kiev.ua 1B19C808CF28 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=imath.kiev.ua; s=hydra; t=1638013563; bh=4YqeM+L/uBocJsK7rlJ9s65Yo9n61+zMaBsVDWR+aSQ=; h=Date:From:To:Subject:From; b=pbhtEf/WsjCKdQ9x9cFNDvONev9IrZVRwifCGGLVJX3PbyDkmxe0j8eebD01K6Y6N xrClTBXBlt2tOliSFBxeKtegZZBZrQ6ztYHxX7BAFCbrPstQEOlOuyeDlYrhkDddJF Sa6gU+b1n1EgDN19NTXdzoeEDi3BXXwAKXZeUwNs= Date: Sat, 27 Nov 2021 00:31:01 +0200 From: Igor Vlasenko To: devel@lists.altlinux.org Message-ID: <20211126223101.GA21526@dad.imath.kiev.ua> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit User-Agent: Mutt/1.9.1 (2017-09-22) Subject: [devel] =?utf-8?b?RE0gUG9saWN5IDIuMSDQntCx0YHRg9C20LTQtdC90Lg=?= =?utf-8?b?0LU6INGB0LXRgdGB0LjQuCB3YXlsYW5kINC4INC+0LHQstGP0LfQutCwINC6?= =?utf-8?b?INC90LjQvA==?= X-BeenThere: devel@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: ALT Linux Team development discussions List-Id: ALT Linux Team development discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 27 Nov 2021 11:46:06 -0000 Archived-At: List-Archive: List-Post: Уважаемые коллеги! Хочу форкнуть из обсуждения Display_Manager_Policy 2.0 [ https://www.altlinux.org/Display_Manager_Policy ] обсуждение темы "поддержка Wayland в Display_Manager" по итогам которой, возможно, будет сформулировано Display_Manager_Policy 2.1. Затравку для обсуждения этой темы я выложил здесь. https://www.altlinux.org/Display_Manager_Policy#Wayland Проблема. Не наработана системная обвязка для сессий Wayland. Текст внизу предварительный и нуждается в обсуждении и уточнении. Отличия классической сессии X от сессии Wayland. Сводная таблица отличий. {| class="standard" ! ! сессия X ! сессия Wayland |- | сервер | требуется уже запущенный X сервер. | не требуется. Приложение запускает его самостоятельно |- | ограничения | X приложение. | нет. Что угодно. wayland compositor, fb app, console app,
X app (должна сама запускать себе X) |- | запуск | нет требований. Сойдет fork+exec в текущем VT | аналог openvt -s -- |- | обертка D-BUS | dbus-launch --exit-with-x11 | dbus-run-session |} Следствие. сессии Wayland в принципе не могут использовать старую схему с запуском /etc/X11/Xsession как посредника. Хотя бы потому, что /etc/X11/Xsession должен быть запущен в сеансе X-cервера, вызывает утилиты X и без X-cервера вылетит с ошибкой. Также почти все, что делает /etc/X11/Xsession, бессмысленно вне X. Исключение - /etc/X11/profile.d но там у нас по сути нет ничего конкретно для X. Можно ввести какой-нибудь /etc/user-session/profile.d и перенести бывшее в /etc/X11/profile.d туда (ssh-agent.sh xdg-user-dirs.sh ...) В итоге гипотетический помощник ALT для сессии Wayland должен вызвать условный /etc/user-session/profile.d и проконтролировать наличие пользовательской сессии D-BUS, обернув при необходимости вызов сессии Wayland в dbus-run-session. Это может быть не только скрипт, но и, к примеру, специально написанный для ALT pam модуль. Также добавил по заказу Сергея Турчина (zerg@) в wm-select (dev version) поддержку отображения wayland-sessions (но пока без полноценного запуска). ./wm-select --no-x --wayland --xdg --print ============================================================ Выношу в отдельную поддискуссию в связи с важностью wayland и чтобы не смешивать с обсуждением проекта политики 2.0 (отказ от wmsession.d через миграцию xinitrc на новый runwm (пока упакован в wm-select, как runwm.test.) Cм. https://bugzilla.altlinux.org/show_bug.cgi?id=41367 #289869 TESTED #1 [test-only] sisyphus wm-select.git=0.9.8-alt2 xinitrc.git=2.4.47-alt3 $ runwm.test --help runwm is compiled to use /etc/X11/wmsession.d by default. Usage: runwm [args(ignored)] runwm --print [args(ignored)] runwm --list runwm --help Extra options: --help this help -v,--verbose verbose -q,--quiet quiet --print do nothing; just print command to execute --alt,--altlinux | --deb,--debian use /etc/X11/wmsession.d --xdg,--freedesktop use /usr/share/xsessions -- I V