mozilla-bmo1744896.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Sat, 08 Jan 2022 10:41:19 +0100
branchfirefox95
changeset 1169 7481543bab31
permissions -rw-r--r--
Firefox 95.0.2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1169
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     1
diff -up firefox-95.0.2/widget/gtk/nsWindow.cpp.1744896 firefox-95.0.2/widget/gtk/nsWindow.cpp
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     2
--- firefox-95.0.2/widget/gtk/nsWindow.cpp.1744896	2021-12-23 11:54:31.522539340 +0100
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     3
+++ firefox-95.0.2/widget/gtk/nsWindow.cpp	2021-12-23 11:55:56.070270174 +0100
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     4
@@ -5765,6 +5765,17 @@ nsresult nsWindow::Create(nsIWidget* aPa
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     5
       }
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     6
     }
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     7
 #endif
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     8
+#ifdef MOZ_WAYLAND
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     9
+  // Initialize the window specific VsyncSource early in order to avoid races
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    10
+  // with BrowserParent::UpdateVsyncParentVsyncSource().
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    11
+  // Only use for toplevel windows for now, see bug 1619246.
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    12
+  if (GdkIsWaylandDisplay() &&
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    13
+      StaticPrefs::widget_wayland_vsync_enabled_AtStartup() &&
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    14
+      mWindowType == eWindowType_toplevel) {
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    15
+    mWaylandVsyncSource = new WaylandVsyncSource();
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    16
+    MOZ_RELEASE_ASSERT(mWaylandVsyncSource);
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    17
+  }
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    18
+#endif
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    19
 
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    20
     // We create input contexts for all containers, except for
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    21
     // toplevel popup windows
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    22
@@ -6077,19 +6088,12 @@ void nsWindow::ResumeCompositorFromCompo
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    23
 
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    24
 void nsWindow::WaylandStartVsync() {
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    25
 #ifdef MOZ_WAYLAND
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    26
-  // only use for toplevel windows for now - see bug 1619246
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    27
-  if (!GdkIsWaylandDisplay() ||
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    28
-      !StaticPrefs::widget_wayland_vsync_enabled_AtStartup() ||
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    29
-      mWindowType != eWindowType_toplevel) {
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    30
+  if (!mWaylandVsyncSource) {
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    31
     return;
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    32
   }
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    33
 
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    34
   LOG("nsWindow::WaylandStartVsync() [%p]\n", (void*)this);
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    35
 
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    36
-  if (!mWaylandVsyncSource) {
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    37
-    mWaylandVsyncSource = new WaylandVsyncSource();
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    38
-  }
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    39
-
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    40
   WaylandVsyncSource::WaylandDisplay& display =
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    41
       static_cast<WaylandVsyncSource::WaylandDisplay&>(
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    42
           mWaylandVsyncSource->GetGlobalDisplay());
7481543bab31 Firefox 95.0.2
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    43