From Fedora Project Wiki
(replace gedit with gnome-text-editor, per https://pagure.io/fedora-workstation/issue/248)
 
(70 intermediate revisions by 4 users not shown)
Line 1: Line 1:
== Fedora Workstation Technical Specification==
== Fedora Workstation Technical Specification ==
 
'''The following technical specification document is a historical foundational document of Fedora Workstation. It is no longer an effective governing document. It is historically important and continues to inform the mission of the WG, but some parts are obsolete. This document will no longer updated.'''
 
This document aims to describe the technical characteristics Fedora Workstation product in detail. This includes provided services and APIs, installed software, etc. Some of the desired characteristics may not be entirely achievable in the first version of the Workstation product, and will be approximated.
 
The content of the spec unavoidably overlaps with the work of the Base Working Group, and needs to be aligned with their deliverables.


== Core Services and Features ==
== Core Services and Features ==
This section should describe the core services of the platform and their intended use. The items here should refer back to the PRD for a functional justification.
This section should describe the core services of the platform and their intended use. The items here should refer back to the PRD for a functional justification.
=== File system ===
The default file system type for workstation installs should be btrfs. Until btrfs is considered ready for this role, we will stay with the current  setup of the desktop spin.


=== Service management ===
=== Service management ===


Systemd provides ways to control and monitor the activity and status of system services, resources they require, etc. System services are expected to provide systemd units.
Systemd provides ways to control and monitor the activity and status of system services, resources they require, etc. System services are expected to provide systemd units. See the systemd [http://0pointer.de/public/systemd-man/systemd.unit.html documentation].


=== Logging ===
=== Logging ===
Line 12: Line 23:
The systemd journal will be used as the local storage backend for system logs. For 'managed' scenarios (e.g the 'developer in a large organization' use case of the PRD), it will be possible to collect the logs in a centralized location, off the local machine.
The systemd journal will be used as the local storage backend for system logs. For 'managed' scenarios (e.g the 'developer in a large organization' use case of the PRD), it will be possible to collect the logs in a centralized location, off the local machine.


Applications and services can either use the syslog API or the journal APIs for their logging.
Applications and services can either use the syslog API or the journal APIs for their logging. See the journal API [http://0pointer.de/public/systemd-man/sd-journal.html documentation].


=== Networking ===
=== Networking ===


Network devices and connections will be controlled by NetworkManager. This includes support for VPN, which is relevant for 'corporate' scenarios. Applications are advised to use higher-level APIs (such as GNetworkMonitor in GIO) to monitor online status.
Network devices and connections will be controlled by NetworkManager. This includes support for VPN, which is relevant for 'corporate' scenarios. Applications are advised to use higher-level APIs (such as [https://developer.gnome.org/gio/stable/GNetworkMonitor.html GNetworkMonitor] in GIO) to monitor online status.
 
=== Firewall ===
 
A firewall in its default configuration may not interfere with the normal operation of programs installed by default.
 
We should detect when the system is on a public or untrusted network and prevent the user from unwanted sharing of e.g. music or other media in
this situation. A firewall (and network zones as currently implemented by firewalld) may or may not be part of a solution to this.
 
=== SELinux ===
 
SELinux will be enabled in enforcing mode, using the targeted policy.
 
=== Problem reporting ===
 
Problems and error conditions (e.g. kernel oopses, Selinux AVCs, application crashes, OOM, disk errors) should all be reported in the systemd
journal.
 
Sending this information to a central place (like abrt does for crashes today) should be possible, but not mandatory. Depending on the use case, it may be turned off, enabled manually on a case-by-case basis, or entirely automatic without user intervention.


=== Session tracking ===
=== Session tracking ===


Logind will be used as the session tracking facility.  
Logind will be used as the session tracking facility.
 
Applications that need to interact with sessions can use the logind [http://www.freedesktop.org/software/systemd/man/sd_session_is_active.html library API], the [http://www.freedesktop.org/wiki/Software/systemd/logind/ D-Bus API], or a higher-level API


=== Account handling ===
=== Account handling ===
Line 32: Line 63:
=== Software updates ===
=== Software updates ===


dnf will be used to obtain and install software updates for packaged applications and the OS itself. The recommendation for applications is to use the PackageKit APIs to interact with the underlying packaging system.
gnome-software will use PackageKit with the hawkey backend to obtain and install software updates for packaged applications and the OS itself. The recommendation for applications is to use the PackageKit APIs to interact with the underlying packaging system.


=== Miscellaneous system information ===
=== Miscellaneous system information ===


System locale, timezone, hostname, etc. will be managed through the services provided by systemd for this purpose.
System locale, timezone, hostname, etc. will be managed through the services provided by systemd for this purpose.
See developer documentation for
[http://www.freedesktop.org/wiki/Software/systemd/localed/ localed],
[http://www.freedesktop.org/wiki/Software/systemd/timedated/ timedated] and
[http://www.freedesktop.org/wiki/Software/systemd/hostnamed/ hostnamed]
=== Virtualization ===
libvirt-daemon will be used to manage virtualization capabilities.


=== Display manager ===
=== Display manager ===
Line 49: Line 88:


The accessibility support in the workstation includes a screen reader, a high-contrast theme and a zoom capability, amongst others. The screen reading is provided through orca, which runs as a session service and requires the at-spi infrastructure. Applications are expected to provide suitable information to the screen reader via the toolkit's accessibility support. Applications are also expected to work acceptably in the high-contrast theme. The zoom is implemented in the desktop shell and does not need any application support.
The accessibility support in the workstation includes a screen reader, a high-contrast theme and a zoom capability, amongst others. The screen reading is provided through orca, which runs as a session service and requires the at-spi infrastructure. Applications are expected to provide suitable information to the screen reader via the toolkit's accessibility support. Applications are also expected to work acceptably in the high-contrast theme. The zoom is implemented in the desktop shell and does not need any application support.
=== Input Methods ===
The input method framework on the workstation is provided by ibus. Input methods and keyboard layouts can be configured in the control-center, and selected in shell keyboard menu. The supported application toolkits all support ibus.
=== Graphics ===
The workstation session will switch to using a Wayland compositor as soon as feasible. Until then, it will be based on X11.
Even after the switch, an X server will be included, so applications can either connect to Wayland natively, or run as an X client.
It shall be possible to calibrate the screen for accurate color reproduction.


=== Media support ===
=== Media support ===


Sound hardware and audio streams will be managed by pulseaudio. Applications are recommended to use the gstreamer framework for media playback.
Sound hardware and audio streams will be managed by pulseaudio. Applications are recommended to use the
[http://gstreamer.freedesktop.org/documentation/ gstreamer] framework for media playback.


=== Appearance ===
=== Appearance ===
Line 59: Line 110:
well with this theme, as well as with the high-contrast theme that is used for accessibility. The theme will include a dark variant that applications
well with this theme, as well as with the high-contrast theme that is used for accessibility. The theme will include a dark variant that applications
can opt into using (this is most suitable for certain content-focused applications). The theme also includes an icon theme that provides named icons according to the icon-naming spec, plus symbolic variants.
can opt into using (this is most suitable for certain content-focused applications). The theme also includes an icon theme that provides named icons according to the icon-naming spec, plus symbolic variants.
We will be using the Adwaita theme, with a yet-to-be-written qt variant.


=== Application Integration ===
=== Application Integration ===


Installed applications are expected to install a desktop file in /usr/share/applications and an application icon in the hicolor icon theme.
Installed applications are expected to install a desktop file in /usr/share/applications and an application icon in the hicolor icon theme.
Packaged applications are also expected to provide [http://people.freedesktop.org/~hughsient/appdata/ appdata] for use in the application installer.
=== System Installer ===
The desired installation experience for the workstation product is to limit the pre-installation user interaction to the minimum. The storage configuration UI should be focused on the classes of hardware that are expected in workstation-class machines. Package selection is not necessary: the installer will install the workstation product as defined. Tweaks, customizations and software additions should be performed after the installation.
One aspect of storage configuration that will be needed is support for dual-boot setups (preserving preexisting Windows or OS X installations), since e.g. students may be required to run software on those platforms for their coursework.
gnome-initial-setup already provides support for post-install user creation, language selection, timezone configuration, etc. If necessary, it should be extended to cover all required setup tasks.
=== Printing ===
cups will be available to support local and network printers.


=== Other ===
=== Other ===


TBD: graphics, firewall, geolocation, virtualization, containers, applications
TBD: containers, supported languages
 
== Core Applications ==
 
Core applications are part of the Workstation product and can not be removed.
 
Applications can depend on any services that are listed above, and can assume that all of the packages listed below are present on the system.
They can not require other applications to be installed.
 
=== Application installer ===
 
gnome-software will serve as graphical application installer, offering to install and remove applications, system extensions and add-ons (such as fonts, or codecs) and other optional software. To be presented in the application installer, applications need to provide appdata.
 
=== Web Browser ===
 
firefox will be used as the web browser.
 
=== Terminal emulator ===


== Core Package list ==
gnome-terminal will be installed as a terminal emulator. More powerful options, such as terminator, can be investigated.
List the core packages of the product. This list includes all packages that will be shipping on the core media. This is the mandatory minimal list of packages that needs to be installed on a system at all times for it to qualify as a Fedora workstation install. This package list will be the priority focus for QA and bug fixing.


=== Package list ===
=== Text Editor ===


systemd, gdm, gnome-shell, gtk3, orca, control-center, qt plus their dependencies
gnome-text-editor will be installed as a simple text editor.


Here is the full list of packages that are installed as dependencies of systemd, gdm, gnome-shell, gtk3, orca, control-center:
=== File Manager ===


<pre>
nautilus will be installed as a file manager.
at-spi2-atk
setup
libgusb
telepathy-filesystem
libcanberra-gtk3
heisenbug-backgrounds-gnome
gnome-keyring
linux-firmware
libnm-gtk
nss-softokn-freebl
gnome-themes-standard
ncurses-libs
pyatspi
pcre
caribou
libxml2
gnome-session-xsession
libcom_err
realmd
shared-mime-info
libsoup
p11-kit
geoclue
libICE
upower
libgcrypt
xorg-x11-server-utils
freetype
kernel
libuuid
libvisual
libevdev
libgdata
popt
mutter-wayland
libsecret
gnome-settings-daemon
hunspell-en-US
libtalloc
libXau
brltty
libXfixes
festival-speechtools-libs
libXdamage
festival
libXinerama
python3-gobject
libplist
libwbclient
libtool-ltdl
libunistring
libtasn1
libwnck3
nss-softokn
libgomp
mozjs24
cups-pk-helper
orc
sox
harfbuzz
flite
harfbuzz-icu
libgnomekbd
ca-certificates
orca
libXxf86misc
startup-notification
acl
libdb-utils
desktop-file-utils
diffutils
mozjs17
avahi-libs
abattis-cantarell-fonts
libproxy
libverto
libsamplerate
libxshmfence
libthai
libXdmcp
openssl-libs
cracklib-dicts
libmount
shadow-utils
util-linux
libusbx
cups-libs
fedora-logos
curl
newt-python
openssl
fipscheck-lib
cryptsetup-libs
polkit
mesa-libEGL
pango
librsvg2
libgcc
dbus-x11
fontpackages-filesystem
gtk2
filesystem
accountsservice-libs
basesystem
colord-libs
libX11-common
gcr
heisenbug-backgrounds-base
clutter
libwacom-data
dconf
mobile-broadband-provider-info
gnome-keyring-pam
hwdata
gnome-bluetooth-libs
ncurses-base
gjs
glibc-common
adwaita-gtk2-theme
libstdc++
gnome-desktop3
bash
pygobject3
libsepol
caribou-gtk3-module
libselinux
python-caribou
dbus-libs
rtkit
nspr
gnome-session
info
libwacom
libffi
PackageKit-glib
glib2
trousers
atk
glib-networking
libwayland-client
libgweather
json-glib
geocode-glib
audit-libs
rest
libogg
libimobiledevice
libgpg-error
kpartx
libwayland-cursor
mcpp
libpng
xorg-x11-xinit
mesa-libwayland-egl
dracut
libxkbcommon
pulseaudio
libSM
gnome-bluetooth
sqlite
gstreamer1-plugins-base
libattr
gnome-online-accounts
libacl
evolution-data-server
chkconfig
mutter
sed
gdm-libs
libvorbis
libnotify
grep
gdm
hunspell
hunspell-en
bzip2-libs
libtevent
libxcb
python3
libXext
brlapi
libXrender
gupnp
libXi
clutter-gtk
libXcomposite
festvox-slt-arctic-hts
libXcursor
gupnp-av
libxkbfile
python3-cairo
telepathy-glib
python3-pyatspi
mesa-libglapi
pytalloc
libicu
samba-libs
libcap-ng
libsmbclient
libtdb
wavpack
libical
libXres
libXxf86vm
avahi-glib
lua
nm-connection-editor
libidn
dotconf
kmod-libs
rygel
redhat-menus
libgtop2
tcp_wrappers-libs
libao
graphite2
festival-freebsoft-utils
pixman
cheese-libs
newt
espeak
gnome-menus
python3-speechd
p11-kit-trust
control-center
nettle
xorg-x11-xkb-utils
libXevie
xcb-util
jasper-libs
enchant
libmetalink
libxslt
cyrus-sasl-lib
libtheora
libgee
cpio
make
findutils
xml-common
libxklavier
psmisc
lyx-fonts
ncurses
libmodman
libpciaccess
json-c
gdbm
libsndfile
qrencode-libs
speex
jbigkit-libs
gdk-pixbuf2
sbc
cdparanoia-libs
ustr
krb5-libs
nss-tools
cracklib
openldap
libpwquality
libuser
coreutils
pam
libutempter
nss-sysinit
pulseaudio-libs
alsa-lib
gnome-icon-theme
pulseaudio-libs-glib2
python
libssh2
liboauth
rpm-libs
color-filesystem
pygobject3-base
libXft
authconfig
procps-ng
fipscheck
device-mapper-libs
systemd
libgudev1
polkit-pkla-compat
mesa-libgbm
libcanberra
cairo
cairo-gobject
NetworkManager-glib
liblouis-python3
at-spi2-core
control-center-filesystem
accountsservice
tzdata
gtk3
adwaita-cursor-theme
bluez
mozilla-filesystem
adwaita-gtk3-theme
emacs-filesystem
colord
glibc
pycairo
xz-libs
caribou-gtk2-module
zlib
GConf2
nss-util
ibus-libs
pkgconfig
gnutls
gobject-introspection
geoclue2
libwayland-server
usbmuxd
libdb
libmcpp
gsettings-desktop-schemas
hardlink
expat
pulseaudio-module-bluetooth
readline
webkitgtk3
libcap
zenity
dbus-glib
gnome-shell
gstreamer1
pulseaudio-gdm-hooks
libjpeg-turbo
python3-libs
libX11
gssdp
libXrandr
festival-lib
libXtst
python3-brlapi
libXt
libldb
gmp
samba-common
lcms2
glx-utils
libXmu
vino
libcroco
gupnp-dlna
kmod
colord-gtk
elfutils-libelf
clutter-gst2
slang
speech-dispatcher
xorg-x11-xauth
liblouis
telepathy-logger
libXv
hunspell-en-GB
desktop-backgrounds-gnome
flac-libs
ModemManager-glib
gawk
iso-codes
xz
webrtc-audio-processing
libasyncns
gsm
keyutils-libs
libtiff
libwebp
libsemanage
gzip
systemd-libs
nss
libblkid
fontconfig
hicolor-icon-theme
python-libs
libcurl
rpm
gnome-icon-theme-symbolic
sound-theme-freedesktop
device-mapper
dbus
libdrm
mesa-libGL
cogl
</pre>


TODOS
=== Virtualization frontend ===
* do we need to pin down versions ?
* add vpn packages
* figure out what qt packages need to added
* add mandatory applications


=== Policies for software add-ons ===
gnome-boxes will be available for the creation and use of vms, as well as for connecting to remote systems, e.g. ovirt.
 
== Policies for software add-ons ==


General rules and policies for how extra software is installed and what requirements are put on that software.
General rules and policies for how extra software is installed and what requirements are put on that software.
Line 481: Line 174:
* Optional software should integrate properly into the defined extension points of the OS:
* Optional software should integrate properly into the defined extension points of the OS:
** Applications should provide desktop files and icons
** Applications should provide desktop files and icons
** Applications should provide appdata (link?) for the software installer
** System services should provide systemd units
** System services should provide systemd units
** Desktop environments should provide a desktop file in /usr/share/xsessions
** Desktop environments should provide a desktop file in /usr/share/xsessions


* It must be possible to remove optional software from the system again
* It must be possible to remove optional software from the system again
== Installation methods and media ==
We will produce a live .iso image. The primary target for this image will be USB sticks, but the ability to burn the image to a DVD should be preserved (since we are still getting regular requests for such media). There is no pressing reason to restrict the image to the current 1GB size target. Persistence is not an important feature of the live media, whose primary focus should be to install the system.
gnome-disks can create USB sticks on Fedora, and liveusb-creator is the tool we have to let people create USB sticks on Windows or Linux. Both of these tools may need to be extended with support for EFI (whatever that means in detail).
== Hardware requirements ==
We expect to support 64bit machines with suitable graphics and display resolutions. High-resolution displays, touchscreens and wacom tablets are
interesting hardware for some workstation use cases and should be supported in the future.
These hardware requirements are not meant to prevent the workstation product from running on other systems, but rather to determine the range of hardware that we will focus on with QA, and when it comes to determining release blockers.


== Engineering Roadmap ==
== Engineering Roadmap ==


Not sure if we want this section here or if we should just make this a pure description document and put the implementation roadmap in a separate document.
Not sure if we want this section here or if we should just make this a pure description document and put the implementation roadmap in a separate document.

Latest revision as of 22:23, 18 January 2022

Fedora Workstation Technical Specification

The following technical specification document is a historical foundational document of Fedora Workstation. It is no longer an effective governing document. It is historically important and continues to inform the mission of the WG, but some parts are obsolete. This document will no longer updated.

This document aims to describe the technical characteristics Fedora Workstation product in detail. This includes provided services and APIs, installed software, etc. Some of the desired characteristics may not be entirely achievable in the first version of the Workstation product, and will be approximated.

The content of the spec unavoidably overlaps with the work of the Base Working Group, and needs to be aligned with their deliverables.

Core Services and Features

This section should describe the core services of the platform and their intended use. The items here should refer back to the PRD for a functional justification.

File system

The default file system type for workstation installs should be btrfs. Until btrfs is considered ready for this role, we will stay with the current setup of the desktop spin.

Service management

Systemd provides ways to control and monitor the activity and status of system services, resources they require, etc. System services are expected to provide systemd units. See the systemd documentation.

Logging

The systemd journal will be used as the local storage backend for system logs. For 'managed' scenarios (e.g the 'developer in a large organization' use case of the PRD), it will be possible to collect the logs in a centralized location, off the local machine.

Applications and services can either use the syslog API or the journal APIs for their logging. See the journal API documentation.

Networking

Network devices and connections will be controlled by NetworkManager. This includes support for VPN, which is relevant for 'corporate' scenarios. Applications are advised to use higher-level APIs (such as GNetworkMonitor in GIO) to monitor online status.

Firewall

A firewall in its default configuration may not interfere with the normal operation of programs installed by default.

We should detect when the system is on a public or untrusted network and prevent the user from unwanted sharing of e.g. music or other media in this situation. A firewall (and network zones as currently implemented by firewalld) may or may not be part of a solution to this.

SELinux

SELinux will be enabled in enforcing mode, using the targeted policy.

Problem reporting

Problems and error conditions (e.g. kernel oopses, Selinux AVCs, application crashes, OOM, disk errors) should all be reported in the systemd journal.

Sending this information to a central place (like abrt does for crashes today) should be possible, but not mandatory. Depending on the use case, it may be turned off, enabled manually on a case-by-case basis, or entirely automatic without user intervention.

Session tracking

Logind will be used as the session tracking facility.

Applications that need to interact with sessions can use the logind library API, the D-Bus API, or a higher-level API

Account handling

SSSD is providing the backing storage for identity management. For 'managed' scenarios (e.g. the 'developer in a large organization' use case of the PRD), it will be possible to configure it to rely on a directory service for this information. The accountsservice is providing a D-Bus interface for user account information; this may be integrated into SSSD at some point.

Depending on their needs, application and services can either use the POSIX APIs (getpwent(), etc) or the accountsservice D-Bus interface to obtain user information.

Software updates

gnome-software will use PackageKit with the hawkey backend to obtain and install software updates for packaged applications and the OS itself. The recommendation for applications is to use the PackageKit APIs to interact with the underlying packaging system.

Miscellaneous system information

System locale, timezone, hostname, etc. will be managed through the services provided by systemd for this purpose. See developer documentation for localed, timedated and hostnamed

Virtualization

libvirt-daemon will be used to manage virtualization capabilities.

Display manager

gdm will be used as the display manager. It is responsible for showing a login screen on each seat. It will be able to launch both X-based sessions and Wayland sessions.

Desktop environments are expected to make themselves known as an available session option on the login screen by dropping a .desktop file into /usr/share/xsessions (or its wayland equivalent).

Other facilities provided by the display manager include screen unlock authentication and user switching.

Accessibility

The accessibility support in the workstation includes a screen reader, a high-contrast theme and a zoom capability, amongst others. The screen reading is provided through orca, which runs as a session service and requires the at-spi infrastructure. Applications are expected to provide suitable information to the screen reader via the toolkit's accessibility support. Applications are also expected to work acceptably in the high-contrast theme. The zoom is implemented in the desktop shell and does not need any application support.

Input Methods

The input method framework on the workstation is provided by ibus. Input methods and keyboard layouts can be configured in the control-center, and selected in shell keyboard menu. The supported application toolkits all support ibus.

Graphics

The workstation session will switch to using a Wayland compositor as soon as feasible. Until then, it will be based on X11. Even after the switch, an X server will be included, so applications can either connect to Wayland natively, or run as an X client.

It shall be possible to calibrate the screen for accurate color reproduction.

Media support

Sound hardware and audio streams will be managed by pulseaudio. Applications are recommended to use the gstreamer framework for media playback.

Appearance

The workstation will ship with a single theme, which will have support for the included toolkits: gtk3, qt and gtk2. Applications are expected to work well with this theme, as well as with the high-contrast theme that is used for accessibility. The theme will include a dark variant that applications can opt into using (this is most suitable for certain content-focused applications). The theme also includes an icon theme that provides named icons according to the icon-naming spec, plus symbolic variants.

We will be using the Adwaita theme, with a yet-to-be-written qt variant.

Application Integration

Installed applications are expected to install a desktop file in /usr/share/applications and an application icon in the hicolor icon theme.

Packaged applications are also expected to provide appdata for use in the application installer.

System Installer

The desired installation experience for the workstation product is to limit the pre-installation user interaction to the minimum. The storage configuration UI should be focused on the classes of hardware that are expected in workstation-class machines. Package selection is not necessary: the installer will install the workstation product as defined. Tweaks, customizations and software additions should be performed after the installation.

One aspect of storage configuration that will be needed is support for dual-boot setups (preserving preexisting Windows or OS X installations), since e.g. students may be required to run software on those platforms for their coursework.

gnome-initial-setup already provides support for post-install user creation, language selection, timezone configuration, etc. If necessary, it should be extended to cover all required setup tasks.

Printing

cups will be available to support local and network printers.

Other

TBD: containers, supported languages

Core Applications

Core applications are part of the Workstation product and can not be removed.

Applications can depend on any services that are listed above, and can assume that all of the packages listed below are present on the system. They can not require other applications to be installed.

Application installer

gnome-software will serve as graphical application installer, offering to install and remove applications, system extensions and add-ons (such as fonts, or codecs) and other optional software. To be presented in the application installer, applications need to provide appdata.

Web Browser

firefox will be used as the web browser.

Terminal emulator

gnome-terminal will be installed as a terminal emulator. More powerful options, such as terminator, can be investigated.

Text Editor

gnome-text-editor will be installed as a simple text editor.

File Manager

nautilus will be installed as a file manager.

Virtualization frontend

gnome-boxes will be available for the creation and use of vms, as well as for connecting to remote systems, e.g. ovirt.

Policies for software add-ons

General rules and policies for how extra software is installed and what requirements are put on that software.

  • Optional software must not interfere with the regular functionality of mandatory components. E.g. installing optional audio software must not prevent other applications from using pulseaudio and gstreamer for media playback.
  • Optional software should integrate properly into the defined extension points of the OS:
    • Applications should provide desktop files and icons
    • Applications should provide appdata (link?) for the software installer
    • System services should provide systemd units
    • Desktop environments should provide a desktop file in /usr/share/xsessions
  • It must be possible to remove optional software from the system again

Installation methods and media

We will produce a live .iso image. The primary target for this image will be USB sticks, but the ability to burn the image to a DVD should be preserved (since we are still getting regular requests for such media). There is no pressing reason to restrict the image to the current 1GB size target. Persistence is not an important feature of the live media, whose primary focus should be to install the system.

gnome-disks can create USB sticks on Fedora, and liveusb-creator is the tool we have to let people create USB sticks on Windows or Linux. Both of these tools may need to be extended with support for EFI (whatever that means in detail).

Hardware requirements

We expect to support 64bit machines with suitable graphics and display resolutions. High-resolution displays, touchscreens and wacom tablets are interesting hardware for some workstation use cases and should be supported in the future.

These hardware requirements are not meant to prevent the workstation product from running on other systems, but rather to determine the range of hardware that we will focus on with QA, and when it comes to determining release blockers.

Engineering Roadmap

Not sure if we want this section here or if we should just make this a pure description document and put the implementation roadmap in a separate document.