ubuntu-multiseat team mailing list archive
-
ubuntu-multiseat team
-
Mailing list archive
-
Message #00097
[Blueprint multiseat] Basic Multiseat Support
Blueprint changed by Richard Hansen:
Whiteboard changed:
* Introduction
The protocol for interacting with logind in a multiseat environment is
described at [1]. I define "basic multiseat support" to be everything
documented there except steps 1 and 2 of "complete porting". Those two
steps are required for automatic multiseat support (dynamically spawning
and terminating greeters as seats come and go), which is out of scope
for this blueprint (see bug #1190581).
Also see "Multiseat on Linux" [2].
[1] http://www.freedesktop.org/wiki/Software/systemd/writing-display-managers/
[2] http://www.freedesktop.org/wiki/Software/systemd/multiseat/
** Terminology
- display server: an instance of X, Mir, a Wayland compositor, etc.
For other terms, see [3].
[3]
http://www.freedesktop.org/wiki/Software/systemd/multiseat/#definitionofterms
** Requirements
- follow steps 1-4 of "minimal porting" and steps 3-4 of "complete
porting"
- support X, Mir, Wayland compositors, etc.
** Mir and Wayland
I am not very familiar with alternative display servers such as Mir and
Wayland, but I believe their designs are similar enough to X with regard
to multiseat that all of the concepts in this blueprint also apply.
Thus, I will try to use the term "display server" instead of "X" when
the core idea is broadly applicable.
* Background: Multiseat and Virtual Terminals
** Associating with a VT
A display server can associate itself with a VT. For example, by
default X will discover an unused VT at startup and switch to it. When
it exits, it switches back.
When the display server is associated with a VT, it will allow the user
to switch to another VT at any time (e.g., by pressing a Ctrl-Alt-F? key
sequence). When the user switches away, the display server releases
control over the input and video devices so that they can be used by
another virtual terminal. When the user switches back, the display
server re-acquires control over the devices.
Note that a different display server could be running concurrently on
another virtual terminal. When the user switches to the other display
server, the virtual terminal system acts as a mediator, coordinating the
handoff of control over the input and video devices. This is how fast
user switching is currently implemented.
** Running independent of a VT
A display server can also be invoked in such a way that it does not
associate itself with a VT. It simply acquires control over some or all
input and video devices. Because the display server is not associated
with a virtual terminal, fast user switching is not supported -- there
is nothing mediating the release and acquisition of control over the
devices.
When a display server is not associated with a VT, it must not:
- probe to see what the current VT is
- attempt to switch VTs
- let a VT see the seat's input (keyboard, mouse) events
Note that any devices not controlled by the display server would still
be available for use by the Linux virtual terminal system.
** VT limitations
The Linux virtual terminal system only supports a single seat. This
makes configuring a multiseat X/Mir/whatever system difficult because
only one VT can be active at any given time. If one seat's display
server is running on vt7 and another seat's display server is running on
vt8, then only one of these two seats can be used at a time. To use the
other seat, a VT switch must be initiated.
To make all seats usable at the same time, there are a few options:
- Associate all display servers with the same VT. If any user at
any seat switches VTs, all seats will switch to the new VT. This
makes VT switching (and thus fast user switching) impractical.
- Don't associate any display server with a VT. Fast user switching
is impossible in this case. Text-based console logins are only
possible if an input and display device are reserved for this
purpose.
- Associate only one of the display servers with a VT. The other
display servers can't do VT switching, but the display server
associated with a VT can. VT switching on that one seat won't
affect the other seats. This is the approach favored and assumed
by systemd, and will be the approach taken by LightDM.
If/when kmscon [4] happens, the Linux kernel virtual terminal
limitations will go away. kmscon will support multiple seats, which
will make it possible to support fast user switching on each seat. (The
system administrator will have to be careful to configure kmscon and the
display manager to agree on the definition of the seat in terms of
hardware devices.)
[4] http://www.freedesktop.org/wiki/Software/kmscon/
* X specifics
** Associating with a VT
To run X associated with a VT, no special arguments or configuration
settings are needed. Some useful arguments are:
- 'vtXX' where XX is a virtual terminal number. This is used to
force X to use a particular VT, rather than try to discover an
unused VT. This argument is useful in combination with Plymouth,
where smooth handoff of the video device is desired.
- '-novtswitch' prevents X from doing any VT switching on startup
and shutdown. LightDM passes this option to X because it does its
own VT switching (to facilitate smooth handoff from Plymouth to
X).
** Without a VT
To run X without an associated VT:
- the '-sharevts' argument is used
- the '-novtswitch' is used (this might not be required)
- the following configuration snippet is used to prevent X from
attempting any VT switches:
Section "ServerFlags"
Option "DontVTSwitch" "True"
EndSection
- the following configuration snippet is used to prevent input
events from going to a virtual terminal (see the evdev(4) man
page):
Section "InputClass"
Identifier "prevent input events from going to the console"
Option "GrabDevice" "True"
EndSection
The above may not be sufficient; a code audit should be done to ensure
that the above settings are enough to guarantee that X does not do
anything related to virtual terminals.
** Device selection
When given the '-seat' argument, X will only use devices that have been
"tagged" (via udev rules) with the given name. All other devices are
off limits. This provides a convenient way to tell X which subset of
input and display devices it is permitted to use. See [5] for more
information.
[5]
http://www.freedesktop.org/wiki/Software/systemd/multiseat/#udevrules
* logind specifics
- seat0 is the name of the "primary" seat. It always exists. Any
seat-specific hardware device not specifically designated to
another seat belongs to seat0.
- As documented at [5], each seat must have a device tagged (via
udev) "master-of-seat". Without a device with this tag, logind
assumes the seat is not ready yet. When a master-of-seat device
appears, logind declares the seat available, signaling the display
manager that the seat is ready for a display server. This tag
should be applied only to the seat's video device so that the
video device is guaranteed to be ready when the display manager
launches the display server.
+
+ * Work Item descriptions
+
+ ** New setting: xdg-seat=<name>
+
+ The xdg-seat=<name> seat setting tells LightDM the name of the seat.
+ The name defaults to "seat0".
+
+ This name is used:
+ - in the XDG_SEAT variable (for PAM)
+ - in the -seat argument to X (if the seat is an X seat and not Mir
+ or something else)
+ - to determine how to handle VTs
+
+ If the name is unset, set to the empty string, or set to seat0, then:
+ - LightDM switches to an automatically chosen VT
+ - 'vtXX' is passed to X (if the seat is an X seat) where XX is the
+ number of the chosen VT
+ - '-seat seat0' is passed to X (if the seat is an X seat)
+
+ If the name is set to something other than seat0, then:
+ - LightDM does NOT do any VT switching
+ - 'vtXX' is NOT passed to X (if the seat is an X seat)
+ - '-seat <name>' is passed to X (if the seat is an X seat)
+ - LightDM creates a temporary xorg config file with the following
+ contents:
+
+ Section "ServerFlags"
+ Option "DontVTSwitch" "True"
+ EndSection
+ Section "InputClass"
+ Identifier "prevent input events from going to the console"
+ Option "GrabDevice" "True"
+ EndSection
+
+ - '-config /path/to/above/config/file -sharevts' is passed to X (if
+ the seat is an X seat)
+
+ If lightdm.conf defines two or more seats with the same name, an error
+ message is logged and the second and subsequent seats with that name are
+ ignored.
+
+ ** New setting: use-vt=auto|true|false|<integer>
+
+ (this is not strictly required, but would be a nice feature in case
+ anyone needs to control VT associations)
+
+ The use-vt=* seat setting tells LightDM which VT to associate with the
+ display server (if any).
+
+ - use-vt=true: Switch to an automatically chosen VT, pass vtXX to X,
+ and do not pass -sharevts to X.
+ - use-vt=false: Do not switch VTs, do not pass vtXX to X, do pass
+ -sharevts to X, and generate a X config with "DontVTSwitch" and
+ "GrabDevice" enabled.
+ - use-vt=auto (default): If the name of the seat is seat0, this is
+ the same as use-vt=true. Otherwise (not seat0), this is the same
+ as use-vt=false.
+ - use-vt=<integer>: Same as use-vt=true, but use the specified VT.
+
+ ** Write test cases
+
+ ** Set can_switch appropriately
+
+ - call set_seat_can_switch() with the value of the
+ org.freedesktop.login1.Seat.CanMultiSession dbus property
+ - bug that needs to be figured out: If can_switch is true on a
+ seat, then when you log out LightDM won't respawn a greeter on
+ that seat.
--
Basic Multiseat Support
https://blueprints.launchpad.net/lightdm/+spec/multiseat