Firefox snap does not use wayland backend by default

Bug #1970884 reported by Alfredo Matas
46
This bug affects 9 people
Affects Status Importance Assigned to Milestone
Mozilla Firefox
Fix Released
Unknown
firefox (Ubuntu)
In Progress
High
Unassigned

Bug Description

Previous versions of Firefox worked with the wayland backend, with the latest version ( 99.0.1 ) wayland is not available and it has to use xwayland. This breaks the screen sharing and also the fonts are not as sharp as using the wayland backend.

Nightly version 101.0a1 without snap works fine.

```
Gtk-Message: 09:20:51.884: Failed to load module "canberra-gtk-module"
Gtk-Message: 09:20:51.885: Failed to load module "canberra-gtk-module"
[GFX1-]: glxtest: Could not connect to wayland socket
```

Tested on Ubuntu 21.10 and 22.04 with the latest updates.
---
ProblemType: Bug
ApportVersion: 2.20.11-0ubuntu82
Architecture: amd64
CasperMD5CheckResult: pass
CurrentDesktop: ubuntu:GNOME
DistroRelease: Ubuntu 22.04
InstallationDate: Installed on 2021-06-21 (315 days ago)
InstallationMedia: Ubuntu 21.04 "Hirsute Hippo" - Release amd64 (20210420)
ProcVersionSignature: Ubuntu 5.15.0-27.28-generic 5.15.30
Snap: firefox 99.0.1-1 (latest/stable/ubuntu-22.04)
Snap.Changes: no changes found
Tags: jammy wayland-session
Uname: Linux 5.15.0-27-generic x86_64
UpgradeStatus: Upgraded to jammy on 2022-04-28 (4 days ago)
UserGroups: docker sudo
_MarkForUpload: True

Revision history for this message
In , Aosmond (aosmond) wrote :

The latest Fedora and Ubuntu releases, and presumably any derivatives thereof, ship Firefox on Wayland by default. They don't use the compatibility layer XWayland, but rather actual Wayland using our pref MOZ_ENABLE_WAYLAND to force it on.

Right now we are unable to test this configuration in CI because our version of Ubuntu is too old to work well as Wayland development is quite active.

We don't need our existing tests on Linux to be fully ported, but it would be good to have the option to run some tests using Wayland on a newer Ubuntu, such as 21.04. This would allow us to start greening the tree for Wayland, and push it out officially from our side.

Revision history for this message
In , Stransky (stransky) wrote :

The recent Wayland test suite (Bug 1578640) based on Ubuntu 18.04 is working relatively well.

The only issue there is missing focus support. The failures you see there are caused broken focus where we wait for focus (that produces timeouts) or we expect a window has focus (that produces reftest failures).

These failures are pretty random as it depends how the focus is handled by compositor - we use a workaround where we hide/show a window and hope it gets the focus after show.

Only reliable way how to fix that is XDG activation protocol implementation (https://wayland.app/protocols/xdg-activation-v1).
This is not finished yet (https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1845). Robert, do you know when this may be available in Mutter? For instance I don't see it in mutter-40.3-1.fc34.x86_64 package.

So our goal is to have compositor with XDG activation protocol available to test Wayland reliably.

Revision history for this message
In , Robert Mader (robert.posteo) wrote :

Copying my answer from the issue here:

> Current status is that we'll ship it in 41 - we may backport it to 40, but Ubuntu 21.04 still uses 3.38. So I currently don't see to get it into the FF CI apart from
> - waiting for 21.10
> - using another distro
> - asking Ubuntu devs to backport it to Gnome 3.36 so we can use Ubuntu 20.04 (I don't think they'll backport to Ubuntu 21.04, but that would also be an option)

That being said, I think in the Mutter version in Ubuntu 18.04 are quite a few Wayland related bugs - not to mention all those fixes for compositor integration. So I guess we'd want at least Ubuntu 20.04 so we don't run into already fixed issues.

Revision history for this message
In , Aosmond (aosmond) wrote :

I think we want 21.04 given that is the release users are getting Wayland today. Test what is already shipping :). They don't get it in 20.04 by default.

Revision history for this message
In , Jmaher (jmaher) wrote :

:stranksy - do you know of prior art/docs on getting wayland running on docker? Currently we run tests on docker with xvfb - my understanding is wayland on xvfb == xwayland; that is not wayland proper. Any advice you have on this would be helpful.

Revision history for this message
In , Robert Mader (robert.posteo) wrote :

For the record from matrix:
> robert.mader
> jmaher: for the record, "wayland on xvfb == xwayland" sounds wrong to me. Xwayland runs on top of Wayland, so Xwayland would imply "x11 on wayland on xvfb". So if a nested Wayland session runs on top of xvfb, that's entirely valid.
"Wayland on native backend" would certainly be better than "Wayland on X11 backend", but for docker tests the later should be fine for now.
> jmaher
> robert.mader: ok, then maybe this isn't such a hard problem to solve- I was reading up on it and kept running into more resources about pure Wayland without xvfb; I will keep looking into this a bit more
> robert.mader
> jmaher: Gnome-Shell/Mutter only supports native headless Wayland mode since very recently (since Gnome 40), see https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1698. Ubuntu 21.04 still ships 3.38 (because of big UI changes, also mind the versioning switch). So IIUC this will only work from Ubuntu 21.10 on :/
> jmaher
> ok, that seems very new- probably not what we want right now

Revision history for this message
In , Jmaher (jmaher) wrote :

for unrelated reasons (OOM, should be fixed with upgraded MESA) we would like to run the marionette tests on this new 21.04 image as well

Revision history for this message
In , Stransky (stransky) wrote :

(In reply to Joel Maher ( :jmaher ) (UTC -0800) from comment #4)
> :stranksy - do you know of prior art/docs on getting wayland running on docker? Currently we run tests on docker with xvfb - my understanding is wayland on xvfb == xwayland; that is not wayland proper. Any advice you have on this would be helpful.

The testing wayland scripts are already there - see Bug 1578640

The important part is here:
https://searchfox.org/mozilla-central/rev/28c8f793f9f8c80de24a179b4472098692a7e9a4/taskcluster/scripts/tester/test-linux.sh#210

This launch Wayland compositor (Mutter in this case) which provides Wayland display.

xvfb is used as underlying X11 server as AFAIK Mutter fails to run without X11. If any new version does not need X11 to run, you can just run mutter without it.

Generally when you set WAYLAND_DISPLAY env variable and MOZ_ENABLE_WAYLAND=1 env variable Firefox will run under Wayland and it does not matter if there's X11, Xwayland or any other X server running.

Revision history for this message
In , Robert Mader (robert.posteo) wrote :

Given that 21.04 is going EOL next week and 22.04 (LTS) is already in alpha, I'm taking the freedom to update the request.

Revision history for this message
In , Stransky (stransky) wrote :

Ubuntu 22.04 is live now and it's even running Firefox on Wayland by default. We need to do the testing ASAP.

Revision history for this message
In , Jmaher (jmaher) wrote :

we just did a manual QA pass on this, ASAP == DONE :)

Revision history for this message
In , Emilio (emiliocobos) wrote :

But we still don't have CI for this right? That seems unfortunate :(

Revision history for this message
In , Jmaher (jmaher) wrote :

These comments are not productive, lets work to keep our bugzilla comments about issues and solving problems, not opinions.

Revision history for this message
In , Emilio (emiliocobos) wrote :

I was just trying to confirm that CI for this is not set up yet, sorry if it came across the wrong way... If there's anything I can help with to get it set up let me know, I'd be happy to help.

Revision history for this message
In , Jmaher (jmaher) wrote :

yeah, CI is not setup, and probably won't be until the summer. We don't have headcount and our contractor is blocked on access (which goes to headcount in other teams). There is a long list of things, our priorities are migrating from AWS to GCP and replacing old performance hardware (old phones and laptops). We are using manual QA to give us sanity checks in the meantime.

The biggest problem we have is that our current images run in docker images and the last 3 times we have spent 3+ months just getting a desktop windowing environment to work properly from within docker. I have proposed switching to a VM where this is a task that can complete in a day or two for a simple experiment, but for automation requires some retooling and provisioning changes (then we are back migrating cloud providers).

This is a higher priority than windows 11. OSX upgrades, or android emulator upgrades.

Revision history for this message
In , Emilio (emiliocobos) wrote :

Thanks for the update Joel (and for all the work you and your team do)

Revision history for this message
In , Jmaher (jmaher) wrote :

*** Bug 1752113 has been marked as a duplicate of this bug. ***

Revision history for this message
In , Olivier Tilloy (osomon) wrote :

(In reply to Martin Stránský [:stransky] (ni? me) from comment #9)
> Ubuntu 22.04 is live now and it's even running Firefox on Wayland by default. We need to do the testing ASAP.

A minor clarification: Ubuntu 22.04 hasn't been released yet, it will go live on 2022-04-21. Also note that users of Ubuntu 20.04 won't be offered to upgrade until 22.04.1 is released, on 2022-08-04. See [the release schedule](https://discourse.ubuntu.com/t/jammy-jellyfish-release-schedule/23906) for details.

Revision history for this message
In , Olivier Tilloy (osomon) wrote :

And to further mitigate potential issues with Firefox on Wayland not being ready for prime time, we can easily disable it (by setting `DISABLE_WAYLAND: 1` in the launch environment) until it is deemed ready.

Revision history for this message
In , Olivier Tilloy (osomon) wrote :
Revision history for this message
In , Olivier Tilloy (osomon) wrote :

I've had the firefox snap crash 3 times today, while running it from the candidate channel (100.0-1) in a wayland session (Ubuntu 22.04). These crashes didn't trigger the crash reporter.
The last time (just now) I happened to be running it from a terminal, and I got this:

    (firefox:80147): Gdk-WARNING **: 21:44:48.720: The program 'firefox' received an X Window System error.
    This probably reflects a bug in the program.
    The error was 'BadValue'.
      (Details: serial 980422 error_code 2 request_code 53 (core protocol) minor_code 0)
      (Note to programmers: normally, X errors are reported asynchronously;
       that is, you will receive the error a while after causing it.
       To debug your program, run it with the GDK_SYNCHRONIZE environment
       variable to change this behavior. You can then get a meaningful
       backtrace from your debugger if you break on the gdk_x_error() function.)

I wonder whether that might speak in favour of reverting to native wayland (which I've been running for months without seeing any such crash)?

Revision history for this message
In , Pascalc (pascalc) wrote :

(In reply to Olivier Tilloy from comment #20)
> I've had the firefox snap crash 3 times today, while running it from the candidate channel (100.0-1) in a wayland session (Ubuntu 22.04). These crashes didn't trigger the crash reporter.
> The last time (just now) I happened to be running it from a terminal, and I got this:
>
> (firefox:80147): Gdk-WARNING **: 21:44:48.720: The program 'firefox' received an X Window System error.
> This probably reflects a bug in the program.
> The error was 'BadValue'.
> (Details: serial 980422 error_code 2 request_code 53 (core protocol) minor_code 0)
> (Note to programmers: normally, X errors are reported asynchronously;
> that is, you will receive the error a while after causing it.
> To debug your program, run it with the GDK_SYNCHRONIZE environment
> variable to change this behavior. You can then get a meaningful
> backtrace from your debugger if you break on the gdk_x_error() function.)
>
> I wonder whether that might speak in favour of reverting to native wayland (which I've been running for months without seeing any such crash)?

Did you file a bug?

Revision history for this message
In , Olivier Tilloy (osomon) wrote :

(In reply to Pascal Chevrel:pascalc from comment #21)
> Did you file a bug?

Now I have: bug 1766849

Alfredo Matas (amatas)
description: updated
Revision history for this message
Erich Eickmeyer (eeickmeyer) wrote :

Thank you for taking the time to report this bug and helping to make Ubuntu better. Please execute the following command only once, as it will automatically gather debugging information, in a terminal:

apport-collect 1970884

When reporting bugs in the future please use apport by using 'ubuntu-bug' and the name of the package affected. You can learn more about this functionality at https://wiki.ubuntu.com/ReportingBugs.

Changed in firefox (Ubuntu):
status: New → Incomplete
Revision history for this message
Alfredo Matas (amatas) wrote : Dependencies.txt

apport information

tags: added: apport-collected jammy wayland-session
description: updated
Revision history for this message
Alfredo Matas (amatas) wrote : ProcCpuinfoMinimal.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : ProcEnviron.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : Snap.Connections.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : Snap.Info.core20.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : Snap.Info.firefox.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : Snap.Info.gnome-3-38-2004.txt

apport information

Revision history for this message
Alfredo Matas (amatas) wrote : Snap.Info.gtk-common-themes.txt

apport information

Revision history for this message
Sebastien Bacher (seb128) wrote : Re: Firefox does not support wayland backend

Thanks, Mozilla asked to revert the option until they can do more testing, we are working on building back with it but meanwhile you can use the beta channel snap which is still built with wayland

Changed in firefox (Ubuntu):
status: Incomplete → In Progress
importance: Undecided → High
Revision history for this message
Olivier Tilloy (osomon) wrote :

Also note that with version 100.0 (currently in the candidate channel, to be released to the stable channel later today), you can force the use of native Wayland by running the firefox snap with MOZ_ENABLE_WAYLAND=1.

Changed in firefox (Ubuntu):
assignee: nobody → Olivier Tilloy (osomon)
summary: - Firefox does not support wayland backend
+ Firefox snap does not use wayland backend by default
tags: added: snap
Revision history for this message
In , Olivier Tilloy (osomon) wrote :

Another data point: several users have reported that a cold startup of the firefox snap (just after booting the machine) on Ubuntu 22.04 in a Wayland session is significantly faster when using the beta channel than with the candidate channel. The only meaningful difference between the two is that the snap in the candidate channel forces the use of XWayland, whereas beta makes use of native Wayland support.

Revision history for this message
Alfredo Matas (amatas) wrote :

I can confirm that using the version 100 (available in the candidate channel of snap at the time of writing this comment) the wayland backend works again.

Looking forward to have this version in the stable channel of snap :)

Revision history for this message
In , Tim Richardson (tim-richardson) wrote :

in lieu of CI infrastructure, can you accept as an alternative some kind of community feedback? Because Firefox under wayland has been great on Fedora for > 12 months, and the beta channel seems to work, and using xwayland is exposing people to https://gitlab.gnome.org/GNOME/gtk/-/issues/4136 (a gtk4 bug that is triggered by xwayland). While it's not a mozilla problem and I can't speak for the Ubuntu release team, it's a bit ironic that despite efforts to avoid gtk4 bugs in Ubuntu 22.04, the Firefox snap has shipped one anyway.

Revision history for this message
In , Hskupin (hskupin) wrote :

When we upgrade our CI from 18.04 to 22.04 it would be great if we could take care of properly setting up the font cache to not trigger a generation for the very first start of Firefox. For all of our CI jobs it adds another 15s and also some test jobs fail under such a condition because the startup of Firefox takes longer than usual. I'll add bug 1670290 as dependency. Thanks.

Revision history for this message
Martin Vysny (vyzivus) wrote :

In my case, using xwayland breaks the mouse hover: https://bugzilla.mozilla.org/show_bug.cgi?id=1774531 . I'll enforce MOZ_ENABLE_WAYLAND=1 on my system.

Revision history for this message
In , Mozilla-kaply (mozilla-kaply) wrote :

Where do we stand on this? I thought we were targeting October originally.

Revision history for this message
In , Mcastelluccio (mcastelluccio) wrote :

David is working on standing up a VM, but run into some issues lately.

Olivier Tilloy (osomon)
Changed in firefox (Ubuntu):
assignee: Olivier Tilloy (osomon) → nobody
Revision history for this message
In , Stransky (stransky) wrote :

Folks, how do we look here? Ubuntu 18.04 (recently used for testing) is EOL and latest nightly can't be build there due to old python 3.6. So all test fixes/tweaks has to be done on try directly which wastes Mozilla resources (right now on Bug 1787182 for instance).

Revision history for this message
In , Gpascutto (gpascutto) wrote :

Michelle, can you provide an update here or link the bugs where that work is happening?

Revision history for this message
In , Mh+mozilla (mh+mozilla) wrote :

Maybe bug 1801347?

(In reply to Martin Stránský [:stransky] (ni? me) from comment #28)
> Folks, how do we look here? Ubuntu 18.04 (recently used for testing) is EOL and latest nightly can't be build there due to old python 3.6. So all test fixes/tweaks has to be done on try directly which wastes Mozilla resources (right now on Bug 1787182 for instance).

FWIW, 18.04 has python 3.7: https://packages.ubuntu.com/bionic/python3.7

Revision history for this message
In , Stransky (stransky) wrote :

(In reply to Mike Hommey [:glandium] from comment #30)
> Maybe bug 1801347?

Wayland is just a part of it.

AFAIK we need new testing environment to test what we already ship on X11 - EGL, dmabuf/WebGL, disabled system titlebar etc. All "new" features are off and we don't test them due to old setup in Mozilla automation.

Revision history for this message
In , Mgoossens (mgoossens) wrote :

https://mozilla-hub.atlassian.net/browse/RELOPS-376
https://mozilla-hub.atlassian.net/browse/RELOPS-132 (perhaps?)

Now to give a little context, I was assigned to this. Then someone left, and I do all their Mac tasks now so I haven't looked at it (I think this is also why the priority was dropped.)
Julia is on PTO for a few days, so I can't ask her right now what the plan is.
I'll ping-pong the NI over to the main Linux magician at our team.

Revision history for this message
In , Aerickson-y (aerickson-y) wrote :

This is on our radar. We're discussing in Slack #wayland-support.

Revision history for this message
Birgit Edel (biredel) wrote :

When updating this, review MOZ_PGO and xvfb mentions in the build scripts to verify build defaults and runtime defaults match.

Changed in firefox:
status: Unknown → Confirmed
Revision history for this message
In , Robert Mader (robert.posteo) wrote :

IIUC there are now several runners using Ubuntu 22.04, notably for bug 1813588, so I guess this can be closed and most dependent bugs can depend on that bug instead?

Revision history for this message
In , Julien Cristau (jcristau-mozilla) wrote :

Comment 34 makes sense to me. Andrew, OK to close?

Revision history for this message
In , Aerickson-y (aerickson-y) wrote :

<edited> wrong andrew :)

Revision history for this message
In , Ahal (ahal) wrote :

Wfm!

Changed in firefox:
status: Confirmed → Fix Released
To post a comment you must log in.
This report contains Public information  
Everyone can see this information.

Other bug subscribers

Remote bug watches

Bug watches keep track of this bug in other bug trackers.