m (→Scope) |
(→Scope) |
||
(32 intermediate revisions by 6 users not shown) | |||
Line 8: | Line 8: | ||
== Owner == | == Owner == | ||
* Name: [[User: | * Name: [[User:mclasen| Matthias Clasen]] [[User:rstrode| Ray Strode]] [[User:jadahl| Jonas Ådahl]] [[User:ofourdan| Olivier Fourdan]] [[User:mchalupa| Marek Chalupa]] | ||
* Email: mclasen@redhat.com | * Email: mclasen@redhat.com rstrode@redhat.com ofourdan@redhat.com jadahl@redhat.com mchalupa@redhat.com | ||
* Release notes owner: <!--- To be assigned by docs team [[User:FASAccountName| Release notes owner name]] <email address> --> | * Release notes owner: <!--- To be assigned by docs team [[User:FASAccountName| Release notes owner name]] <email address> --> | ||
<!--- UNCOMMENT only for Changes with assigned Shepherd (by FESCo) | <!--- UNCOMMENT only for Changes with assigned Shepherd (by FESCo) | ||
Line 18: | Line 18: | ||
== Current status == | == Current status == | ||
* Targeted release: [[Releases/ | * Targeted release: [[Releases/25 | Fedora 25 ]] | ||
* Last updated: | * Last updated: 2016-08-23 | ||
<!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | <!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | ||
Bugzilla states meaning as usual: | Bugzilla states meaning as usual: | ||
NEW -> change proposal is submitted and announced | NEW -> change proposal is submitted and announced | ||
Line 28: | Line 28: | ||
CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development | CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development | ||
--> | --> | ||
* Tracker bug: | * Tracker bug: 1277927 | ||
== Detailed Description == | == Detailed Description == | ||
We will change | We will change GDM to use wayland by default for GNOME. The code will automatically fall back to Xorg in cases where wayland is unavailable (like nvidia). Users will be able to disable wayland by setting WaylandEnable=false in /etc/gdm/custom.conf but there will no longer be two separate menu items for GNOME on Wayland and GNOME on X11. | ||
== Benefit to Fedora == | == Benefit to Fedora == | ||
Using Wayland instead of X gives a much better basis for isolating applications from each other and the system. | Using Wayland instead of X gives a much better basis for isolating applications from each other and the system. | ||
<!-- What is the benefit to the platform? If this is a major capability update, what has changed? If this is a new functionality, what capabilities does it bring? Why will Fedora become a better distribution or project because of this proposal?--> | <!-- What is the benefit to the platform? If this is a major capability update, what has changed? If this is a new functionality, what capabilities does it bring? Why will Fedora become a better distribution or project because of this proposal?--> | ||
== Scope == | == Scope == | ||
* Proposal owners: | * Proposal owners: | ||
** merge the gnome-wayland.desktop and gnome.desktop into one file that is distributed into both /usr/share/wayland-sessions and /usr/share/xsessions. since they have same filename, the wayland one will "win". - DONE | |||
** Make gdm hide Wayland sessions from the session chooser if we know they will not work (because the login screen had to fall back to X) - DONE | |||
** Close remaining feature parity gaps between the Wayland and the X11 session: | |||
*** See the [[Wayland_features|Wayland features]] page for a complete list of features. | |||
*** game support - Wayland and mutter are DONE, missing support in Xwayland and SDL | |||
*** details panel in control center needs to show hardware graphics device | |||
*** input methods - DONE | |||
*** on-screen keyboard - DONE | |||
*** hi-dpi support - DONE | |||
*** tablet support - GTK+ side DONE, control-center side still in progress | |||
*** startup notification - DONE | |||
*** touch proxy for xwayland - DONE | |||
*** accessibility features - Screen reader and visual bell are DONE | |||
* Other developers: GTK+ applications that use X11-specific APIs need to be patched to explicitly use the GDK X backend | *** output rotation / randr like features - DONE | ||
*** triple-monitor setups (like [[https://bugzilla.gnome.org/show_bug.cgi?id=750610 this]]) | |||
*** primary selection - DONE ([https://wiki.gnome.org/Initiatives/Wayland/PrimarySelection discussion]) | |||
*** dnd actions and cancellation - DONE | |||
* Other developers: | |||
** GTK+ applications that use X11-specific APIs need to be patched to explicitly use the GDK X backend | |||
** Popup and dialog placement issues in applications | |||
* Release engineering: No release engineering changes needed | * Release engineering: No release engineering changes needed | ||
Line 64: | Line 68: | ||
== Upgrade/compatibility impact == | == Upgrade/compatibility impact == | ||
Systems using certain graphics hw or graphics drivers (matrox, qxl) may have problems running the Wayland session. In these (rare) cases, users may have to configure gdm to | Systems using certain graphics hw or graphics drivers (matrox, qxl) may have problems running the Wayland session. In these (rare) cases, users may have to configure gdm to use X11 (although automatic fallback should work most of the time). If we don't manage to close all the feature parity gaps entirely, then users relying on those features may have to choose the X11-based session. | ||
use X11 (although automatic fallback should work most of the time). If we don't manage to close all the feature parity gaps entirely, then users relying on those features | |||
may have to choose the X11-based session. | |||
== How To Test == | == How To Test == | ||
Boot a fresh | # Boot a fresh F25 workstation install. | ||
# | # Verify that the login screen is running under Wayland (you can do so by looking for a process called gdm-wayland-session in ps -ef output) | ||
# | # Verify that the session chooser offers 'GNOME', 'GNOME on X11' and 'GNOME Classic', and that 'GNOME' is selected by default. | ||
# | # Log into all three of these sessions and verify that 'GNOME' gives you Wayland (you can verify this by bringing up the GTK+ inspector in a gtk3 application and checking what backend is used), while the other two end up with X11. | ||
# Change the gdm configuration by adding WaylandEnable=false and reboot | # Change the gdm configuration by adding WaylandEnable=false and reboot | ||
Line 81: | Line 83: | ||
# Log into the Wayland-based session again | # Log into the Wayland-based session again | ||
# Use the desktop normally, and verify that there are no obvious instabilities, or Wayland-specific bugs or performance problems | # Use the desktop normally, and verify that there are no obvious instabilities, or Wayland-specific bugs or performance problems | ||
== User Experience == | == User Experience == | ||
The user experience of the Wayland session is identical to that of the X session. | The user experience of the Wayland session is identical to that of the X session. | ||
== Dependencies == | == Dependencies == | ||
The tasks lists in the Scope section are spread across a number of upstream modules and packages: gtk3, gnome-shell, mutter, libinput, Xorg, gdm. | The tasks lists in the Scope section are spread across a number of upstream modules and packages: gtk3, gnome-shell, mutter, libinput, Xorg, gdm. | ||
== Contingency Plan == | == Contingency Plan == | ||
* Contingency mechanism: | * Contingency mechanism: Rename /usr/share/wayland-sessions/gnome.desktop to /usr/share/wayland-sessions/gnome-wayland.desktop so it doesn't preempt the X11 session file anymore, thereby keeping the X-based session as the default and adding wayland back to the list. | ||
* Contingency deadline: beta | * Contingency deadline: beta | ||
* Blocks release? no | * Blocks release? no | ||
Line 104: | Line 106: | ||
<!-- When your change proposal page is completed and ready for review and announcement --> | <!-- When your change proposal page is completed and ready for review and announcement --> | ||
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler --> | <!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler --> | ||
<!-- The Wrangler announces the Change to the devel-announce list and changes the category to Category:ChangeAnnounced (no action required) --> | <!-- The Wrangler announces the Change to the devel-announce list and changes the category to Category:ChangeAnnounced (no action required) --> | ||
<!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete--> | <!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete--> | ||
[[Category:SystemWideChange] | [[Category:SystemWideChange]] |
Latest revision as of 14:43, 24 August 2016
Wayland By Default
Summary
Change the default session selection in gdm to prefer the Wayland-based GNOME session over the X11-based one.
Owner
- Name: Matthias Clasen Ray Strode Jonas Ådahl Olivier Fourdan Marek Chalupa
- Email: mclasen@redhat.com rstrode@redhat.com ofourdan@redhat.com jadahl@redhat.com mchalupa@redhat.com
- Release notes owner:
- Product: Workstation
- Responsible WG: Workstation
Current status
- Targeted release: Fedora 25
- Last updated: 2016-08-23
- Tracker bug: 1277927
Detailed Description
We will change GDM to use wayland by default for GNOME. The code will automatically fall back to Xorg in cases where wayland is unavailable (like nvidia). Users will be able to disable wayland by setting WaylandEnable=false in /etc/gdm/custom.conf but there will no longer be two separate menu items for GNOME on Wayland and GNOME on X11.
Benefit to Fedora
Using Wayland instead of X gives a much better basis for isolating applications from each other and the system.
Scope
- Proposal owners:
- merge the gnome-wayland.desktop and gnome.desktop into one file that is distributed into both /usr/share/wayland-sessions and /usr/share/xsessions. since they have same filename, the wayland one will "win". - DONE
- Make gdm hide Wayland sessions from the session chooser if we know they will not work (because the login screen had to fall back to X) - DONE
- Close remaining feature parity gaps between the Wayland and the X11 session:
- See the Wayland features page for a complete list of features.
- game support - Wayland and mutter are DONE, missing support in Xwayland and SDL
- details panel in control center needs to show hardware graphics device
- input methods - DONE
- on-screen keyboard - DONE
- hi-dpi support - DONE
- tablet support - GTK+ side DONE, control-center side still in progress
- startup notification - DONE
- touch proxy for xwayland - DONE
- accessibility features - Screen reader and visual bell are DONE
- output rotation / randr like features - DONE
- triple-monitor setups (like [this])
- primary selection - DONE (discussion)
- dnd actions and cancellation - DONE
- Other developers:
- GTK+ applications that use X11-specific APIs need to be patched to explicitly use the GDK X backend
- Popup and dialog placement issues in applications
- Release engineering: No release engineering changes needed
- Policies and guidelines: No policy or guideline changes needed
Upgrade/compatibility impact
Systems using certain graphics hw or graphics drivers (matrox, qxl) may have problems running the Wayland session. In these (rare) cases, users may have to configure gdm to use X11 (although automatic fallback should work most of the time). If we don't manage to close all the feature parity gaps entirely, then users relying on those features may have to choose the X11-based session.
How To Test
- Boot a fresh F25 workstation install.
- Verify that the login screen is running under Wayland (you can do so by looking for a process called gdm-wayland-session in ps -ef output)
- Verify that the session chooser offers 'GNOME', 'GNOME on X11' and 'GNOME Classic', and that 'GNOME' is selected by default.
- Log into all three of these sessions and verify that 'GNOME' gives you Wayland (you can verify this by bringing up the GTK+ inspector in a gtk3 application and checking what backend is used), while the other two end up with X11.
- Change the gdm configuration by adding WaylandEnable=false and reboot
- Verify that the login screen comes up under X
- Verify that only X-based sessions are offered in the session chooser
- Log into the Wayland-based session again
- Use the desktop normally, and verify that there are no obvious instabilities, or Wayland-specific bugs or performance problems
User Experience
The user experience of the Wayland session is identical to that of the X session.
Dependencies
The tasks lists in the Scope section are spread across a number of upstream modules and packages: gtk3, gnome-shell, mutter, libinput, Xorg, gdm.
Contingency Plan
- Contingency mechanism: Rename /usr/share/wayland-sessions/gnome.desktop to /usr/share/wayland-sessions/gnome-wayland.desktop so it doesn't preempt the X11 session file anymore, thereby keeping the X-based session as the default and adding wayland back to the list.
- Contingency deadline: beta
- Blocks release? no
- Blocks product? no
Documentation
TBD
Release Notes
TBD