kmscon

From Infogalactic: the planetary knowledge core
Jump to: navigation, search
kmscon
Developer(s) David Herrmann
Initial release March 27, 2012 (2012-03-27)[1]
Stable release 8 / October 29, 2013; 10 years ago (2013-10-29)
Preview release 8 / October 29, 2013; 10 years ago (2013-10-29)
Development status Active
Written in C
Operating system Linux
Type System console
License ISC license
Website www.freedesktop.org/wiki/Software/kmscon

Kmscon is a virtual console which runs in userspace and intends to replace the Linux console, a terminal built into the Linux kernel. Kmscon uses the KMS driver for its output, it is multi-seat capable, supports internationalized keyboard input and UTF-8 terminal output. The input support is implemented using X keyboard extension (XKB). Development of Kmscon stopped in March 2015. There is a new project called systemd-consoled.

Features

Kmscon supports printing the full set of Unicode glyphs and is not limited by console encoding as the Linux console.[2] While the only hard dependency is udev, kmscon can optionally be compiled to use Mesa for hardware acceleration of the console, and the pango library for improved font rendering.[3]

The adoption of XKB for input allows kmscon to accept the full range of available keyboard layouts for the X.Org Server and Wayland compositors for input and makes it possible to use the same layout both in graphical environment and in terminal.[4]

Multi-seat

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

The VT system in the Linux kernel dates to 1993 and does not implement out-of-the-box multi-seat support. It supports up to 63 VTs, but only one VT can be active at any given time. This necessitates additional steps to configure multi-seat support. kmscon/systemd-consoled will[clarification needed] enable multi-seat out-of-the-box.

If one seat's display server is running on VT 7 and another seat's display server is running on VT 8, 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: any user can switch VTs and in that case all users switch to the new VT. This makes VT switching (and thus fast user switching) impractical. X.Org Server command-line option -sharevts
  • 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. command-line option vt7 for user 1 and -novtswitch for all other users.

Development

In 2011, Jesse Barnes wrote in his blog about the possible userspace DRM-based implementation of the virtual terminal, that would dissolve the need for the Linux framebuffer and virtual terminal (VT) subsystems in the Linux kernel. Motivated by this blog post, David Herrmann implemented the basic functionality of virtual terminal.[2]

In October 2013, terminal emulator state machine (libtsm) library, a state machine for DEC VT100-VT520 compatible terminal emulators, was split out of kmscon and made available separately.[5] It was amended with wlterm, an example Wayland terminal emulator.[6]

See also

References

  1. Lua error in package.lua at line 80: module 'strict' not found.
  2. 2.0 2.1 Lua error in package.lua at line 80: module 'strict' not found.
  3. Lua error in package.lua at line 80: module 'strict' not found.
  4. Lua error in package.lua at line 80: module 'strict' not found.
  5. Lua error in package.lua at line 80: module 'strict' not found.
  6. Lua error in package.lua at line 80: module 'strict' not found.