import CS gjs-1.68.6-4.el9

This commit is contained in:
eabdullin 2023-09-21 18:36:52 +00:00
parent 0700f57211
commit fea79781f2
2 changed files with 74 additions and 1 deletions

View File

@ -0,0 +1,67 @@
From 4cbaa23f1f4a3510176a1f38489834203f71b2b6 Mon Sep 17 00:00:00 2001
From: Sebastian Keller <skeller@gnome.org>
Date: Thu, 16 Mar 2023 22:35:49 +0100
Subject: [PATCH] function: Always initialize callback return value
When callback_closure() exits early, for example due to being called
during GC, the return value would not be initialized. This value is
often non-zero. If the callback is a source func of an idle or a timeout
this would then get interpreted as G_SOURCE_CONTINUE and the same would
repeat in the next iteration. If this happens fast enough, this results
in the entire process being seemingly frozen while spamming the log with
error messages.
To fix this always initialize the return value to 0 or a comparable
neutral value.
Related: https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/1868
---
gi/function.cpp | 18 +++++++++---------
1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/gi/function.cpp b/gi/function.cpp
index 7c0064c8..5d69ed8a 100644
--- a/gi/function.cpp
+++ b/gi/function.cpp
@@ -308,6 +308,15 @@ void GjsCallbackTrampoline::callback_closure(GIArgument** args, void* result) {
JSContext *context;
GITypeInfo ret_type;
+ g_callable_info_load_return_type(m_info, &ret_type);
+
+ // Fill in the result with some hopefully neutral value
+ if (g_type_info_get_tag(&ret_type) != GI_TYPE_TAG_VOID) {
+ GIArgument argument = {};
+ gjs_gi_argument_init_default(&ret_type, &argument);
+ set_return_ffi_arg_from_giargument(&ret_type, result, &argument);
+ }
+
if (G_UNLIKELY(!gjs_closure_is_valid(m_js_function))) {
warn_about_illegal_js_callback(
"during shutdown",
@@ -382,7 +391,6 @@ void GjsCallbackTrampoline::callback_closure(GIArgument** args, void* result) {
JS::RootedValue rval(context);
- g_callable_info_load_return_type(m_info, &ret_type);
GIArgument* error_argument = nullptr;
if (g_callable_info_can_throw_gerror(m_info))
@@ -406,14 +414,6 @@ void GjsCallbackTrampoline::callback_closure(GIArgument** args, void* result) {
m_info.ns(), m_info.name());
}
- // Fill in the result with some hopefully neutral value
- if (g_type_info_get_tag(&ret_type) != GI_TYPE_TAG_VOID) {
- GIArgument argument = {};
- g_callable_info_load_return_type(m_info, &ret_type);
- gjs_gi_argument_init_default(&ret_type, &argument);
- set_return_ffi_arg_from_giargument(&ret_type, result, &argument);
- }
-
// If the callback has a GError** argument and invoking the closure
// returned an error, try to make a GError from it
if (error_argument && rval.isObject()) {
--
2.35.1

View File

@ -20,7 +20,7 @@
Name: gjs Name: gjs
Version: 1.68.6 Version: 1.68.6
Release: 3%{?dist} Release: 4%{?dist}
Summary: Javascript Bindings for GNOME Summary: Javascript Bindings for GNOME
# The following files contain code from Mozilla which # The following files contain code from Mozilla which
@ -72,6 +72,7 @@ Patch32: 0003-D94538-autoconf2.diff
%endif %endif
Patch40: 0001-gobject-Guard-against-null-JS-wrapper-in-set-get-pro.patch Patch40: 0001-gobject-Guard-against-null-JS-wrapper-in-set-get-pro.patch
Patch41: 0001-function-Always-initialize-callback-return-value.patch
BuildRequires: cairo-gobject-devel BuildRequires: cairo-gobject-devel
BuildRequires: dbus-daemon BuildRequires: dbus-daemon
@ -188,6 +189,7 @@ popd
%endif %endif
%patch40 -p1 %patch40 -p1
%patch41 -p1
%build %build
%if 0%{?bundled_mozjs} %if 0%{?bundled_mozjs}
@ -300,6 +302,10 @@ popd
%{_datadir}/installed-tests/ %{_datadir}/installed-tests/
%changelog %changelog
* Tue May 16 2023 Florian Müllner <fmuellner@redhat.com> - 1.68.6-4
- Always initialize callback return value
Resolves: #2196877
* Wed Feb 15 2023 Florian Müllner <fmuellner@redhat.com> - 1.68.6-2 * Wed Feb 15 2023 Florian Müllner <fmuellner@redhat.com> - 1.68.6-2
- Guard against invalid gobject property access - Guard against invalid gobject property access
Resolves: #2170044 Resolves: #2170044