Backport a fix for tracker erroring out with "Failed to set scheduler settings"
https://gitlab.gnome.org/GNOME/tracker-miners/merge_requests/148
This commit is contained in:
parent
e53e323864
commit
1274d99b1c
195
148.patch
Normal file
195
148.patch
Normal file
@ -0,0 +1,195 @@
|
|||||||
|
From 3757daba251bd5bd1bb20b89c6269d63ff95038d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Carlos Garnacho <carlosg@gnome.org>
|
||||||
|
Date: Wed, 19 Feb 2020 18:27:11 +0100
|
||||||
|
Subject: [PATCH 1/3] tracker-extract: Set cpu/io/nice settings before glib/gio
|
||||||
|
usage
|
||||||
|
|
||||||
|
This was happening late enough during main() that there were already
|
||||||
|
non-exclusive threadpools/threads created with regular scheduler
|
||||||
|
settings. Those settings would be cached in recent glib, creating
|
||||||
|
disparities that it will g_error() out on later. Those created threads
|
||||||
|
might however be reused later on by different code (eg. metadata
|
||||||
|
extraction, directly or indirectly), with the regular scheduling
|
||||||
|
priorities set.
|
||||||
|
|
||||||
|
Given that even accessing GSettings will result in threads being
|
||||||
|
spawned underneath, there's no better choice than doing this always.
|
||||||
|
This means the 'sched-idle' setting is ineffective. But this default
|
||||||
|
should avoid fingers from pointing at us.
|
||||||
|
|
||||||
|
Closes: https://gitlab.gnome.org/GNOME/tracker/issues/180
|
||||||
|
---
|
||||||
|
src/tracker-extract/tracker-main.c | 20 ++++++++------------
|
||||||
|
1 file changed, 8 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/tracker-extract/tracker-main.c b/src/tracker-extract/tracker-main.c
|
||||||
|
index f6db1e0f2..0a9a42ebd 100644
|
||||||
|
--- a/src/tracker-extract/tracker-main.c
|
||||||
|
+++ b/src/tracker-extract/tracker-main.c
|
||||||
|
@@ -109,14 +109,10 @@ static GOptionEntry entries[] = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static void
|
||||||
|
-initialize_priority_and_scheduling (TrackerSchedIdle sched_idle,
|
||||||
|
- gboolean first_time_index)
|
||||||
|
+initialize_priority_and_scheduling (void)
|
||||||
|
{
|
||||||
|
/* Set CPU priority */
|
||||||
|
- if (sched_idle == TRACKER_SCHED_IDLE_ALWAYS ||
|
||||||
|
- (sched_idle == TRACKER_SCHED_IDLE_FIRST_INDEX && first_time_index)) {
|
||||||
|
- tracker_sched_idle ();
|
||||||
|
- }
|
||||||
|
+ tracker_sched_idle ();
|
||||||
|
|
||||||
|
/* Set disk IO priority and scheduling */
|
||||||
|
tracker_ioprio_init ();
|
||||||
|
@@ -230,6 +226,9 @@ run_standalone (TrackerConfig *config)
|
||||||
|
output_format_name = "turtle";
|
||||||
|
}
|
||||||
|
|
||||||
|
+ /* This makes sure we don't steal all the system's resources */
|
||||||
|
+ initialize_priority_and_scheduling ();
|
||||||
|
+
|
||||||
|
/* Look up the output format by name */
|
||||||
|
enum_class = g_type_class_ref (TRACKER_TYPE_SERIALIZATION_FORMAT);
|
||||||
|
enum_value = g_enum_get_value_by_nick (enum_class, output_format_name);
|
||||||
|
@@ -242,9 +241,6 @@ run_standalone (TrackerConfig *config)
|
||||||
|
|
||||||
|
tracker_locale_sanity_check ();
|
||||||
|
|
||||||
|
- /* This makes sure we don't steal all the system's resources */
|
||||||
|
- initialize_priority_and_scheduling (tracker_config_get_sched_idle (config), TRUE);
|
||||||
|
-
|
||||||
|
file = g_file_new_for_commandline_arg (filename);
|
||||||
|
uri = g_file_get_uri (file);
|
||||||
|
|
||||||
|
@@ -371,6 +367,9 @@ main (int argc, char *argv[])
|
||||||
|
return EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ /* This makes sure we don't steal all the system's resources */
|
||||||
|
+ initialize_priority_and_scheduling ();
|
||||||
|
+
|
||||||
|
connection = g_bus_get_sync (TRACKER_IPC_BUS, NULL, &error);
|
||||||
|
if (error) {
|
||||||
|
g_critical ("Could not create DBus connection: %s\n",
|
||||||
|
@@ -402,9 +401,6 @@ main (int argc, char *argv[])
|
||||||
|
/* Initialize subsystems */
|
||||||
|
initialize_directories ();
|
||||||
|
|
||||||
|
- /* This makes sure we don't steal all the system's resources */
|
||||||
|
- initialize_priority_and_scheduling (tracker_config_get_sched_idle (config), TRUE);
|
||||||
|
-
|
||||||
|
extract = tracker_extract_new (TRUE, force_module);
|
||||||
|
|
||||||
|
if (!extract) {
|
||||||
|
--
|
||||||
|
2.24.1
|
||||||
|
|
||||||
|
|
||||||
|
From 75493f12a06a2150d9c8d66d2ec6fe25e14428cd Mon Sep 17 00:00:00 2001
|
||||||
|
From: Carlos Garnacho <carlosg@gnome.org>
|
||||||
|
Date: Wed, 19 Feb 2020 18:27:21 +0100
|
||||||
|
Subject: [PATCH 2/3] tracker-miner-fs: Set cpu/io/nice settings before
|
||||||
|
glib/gio usage
|
||||||
|
|
||||||
|
This was happening late enough during main() that there were already
|
||||||
|
non-exclusive threadpools/threads created with regular scheduler
|
||||||
|
settings. Those settings would be cached in recent glib, creating
|
||||||
|
disparities that it will g_error() out on later. Those created threads
|
||||||
|
might however be reused later on by different code (eg. metadata
|
||||||
|
extraction, directly or indirectly), with the regular scheduling
|
||||||
|
priorities set.
|
||||||
|
|
||||||
|
Given that even accessing GSettings will result in threads being
|
||||||
|
spawned underneath, there's no better choice than doing this always.
|
||||||
|
This means the 'sched-idle' setting is ineffective. But this default
|
||||||
|
should avoid fingers from pointing at us.
|
||||||
|
|
||||||
|
Closes: https://gitlab.gnome.org/GNOME/tracker/issues/180
|
||||||
|
---
|
||||||
|
src/miners/fs/tracker-main.c | 15 +++++----------
|
||||||
|
1 file changed, 5 insertions(+), 10 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/miners/fs/tracker-main.c b/src/miners/fs/tracker-main.c
|
||||||
|
index 03e8e6496..7ae85e254 100644
|
||||||
|
--- a/src/miners/fs/tracker-main.c
|
||||||
|
+++ b/src/miners/fs/tracker-main.c
|
||||||
|
@@ -271,14 +271,10 @@ initialize_signal_handler (void)
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
-initialize_priority_and_scheduling (TrackerSchedIdle sched_idle,
|
||||||
|
- gboolean first_time_index)
|
||||||
|
+initialize_priority_and_scheduling (void)
|
||||||
|
{
|
||||||
|
/* Set CPU priority */
|
||||||
|
- if (sched_idle == TRACKER_SCHED_IDLE_ALWAYS ||
|
||||||
|
- (sched_idle == TRACKER_SCHED_IDLE_FIRST_INDEX && first_time_index)) {
|
||||||
|
- tracker_sched_idle ();
|
||||||
|
- }
|
||||||
|
+ tracker_sched_idle ();
|
||||||
|
|
||||||
|
/* Set disk IO priority and scheduling */
|
||||||
|
tracker_ioprio_init ();
|
||||||
|
@@ -823,6 +819,9 @@ main (gint argc, gchar *argv[])
|
||||||
|
return EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ /* This makes sure we don't steal all the system's resources */
|
||||||
|
+ initialize_priority_and_scheduling ();
|
||||||
|
+
|
||||||
|
connection = g_bus_get_sync (TRACKER_IPC_BUS, NULL, &error);
|
||||||
|
if (error) {
|
||||||
|
g_critical ("Could not create DBus connection: %s\n",
|
||||||
|
@@ -851,10 +850,6 @@ main (gint argc, gchar *argv[])
|
||||||
|
|
||||||
|
sanity_check_option_values (config);
|
||||||
|
|
||||||
|
- /* This makes sure we don't steal all the system's resources */
|
||||||
|
- initialize_priority_and_scheduling (tracker_config_get_sched_idle (config),
|
||||||
|
- tracker_miner_files_get_first_index_done () == FALSE);
|
||||||
|
-
|
||||||
|
main_loop = g_main_loop_new (NULL, FALSE);
|
||||||
|
|
||||||
|
if (domain_ontology_name) {
|
||||||
|
--
|
||||||
|
2.24.1
|
||||||
|
|
||||||
|
|
||||||
|
From 78c709c3946857e43796240d54a7558cbb6c2da1 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Carlos Garnacho <carlosg@gnome.org>
|
||||||
|
Date: Wed, 19 Feb 2020 18:27:35 +0100
|
||||||
|
Subject: [PATCH 3/3] libtracker-miners-common: Allow sched_setattr syscall
|
||||||
|
|
||||||
|
https://gitlab.gnome.org/GNOME/glib/issues/2039 has taught us two
|
||||||
|
things:
|
||||||
|
- Even if sched_setattr failures aren't handled as g_error() in
|
||||||
|
glib, there will be some kind of warning. It's not desirable to
|
||||||
|
extractor modules to indirectly trigger it.
|
||||||
|
- Since priorities cannot be risen back without special capabilities
|
||||||
|
(results in EPERM), it's not that bad to simply allow this syscall.
|
||||||
|
|
||||||
|
So simply allow the sched_setattr syscall in our seccomp filter.
|
||||||
|
|
||||||
|
Closes: https://gitlab.gnome.org/GNOME/tracker/issues/180
|
||||||
|
---
|
||||||
|
src/libtracker-miners-common/tracker-seccomp.c | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/libtracker-miners-common/tracker-seccomp.c b/src/libtracker-miners-common/tracker-seccomp.c
|
||||||
|
index 6e6218126..9d031c09e 100644
|
||||||
|
--- a/src/libtracker-miners-common/tracker-seccomp.c
|
||||||
|
+++ b/src/libtracker-miners-common/tracker-seccomp.c
|
||||||
|
@@ -114,7 +114,7 @@ tracker_seccomp_init (void)
|
||||||
|
ALLOW_RULE (rt_sigprocmask);
|
||||||
|
ALLOW_RULE (sched_yield);
|
||||||
|
ALLOW_RULE (sched_getaffinity);
|
||||||
|
- ERROR_RULE (sched_setattr, EPERM);
|
||||||
|
+ ALLOW_RULE (sched_setattr);
|
||||||
|
ALLOW_RULE (nanosleep);
|
||||||
|
ALLOW_RULE (waitid);
|
||||||
|
ALLOW_RULE (waitpid);
|
||||||
|
--
|
||||||
|
2.24.1
|
||||||
|
|
@ -18,13 +18,16 @@
|
|||||||
|
|
||||||
Name: tracker-miners
|
Name: tracker-miners
|
||||||
Version: 2.3.2
|
Version: 2.3.2
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
Summary: Tracker miners and metadata extractors
|
Summary: Tracker miners and metadata extractors
|
||||||
|
|
||||||
# libtracker-extract is LGPLv2+; the miners are a mix of GPLv2+ and LGPLv2+ code
|
# libtracker-extract is LGPLv2+; the miners are a mix of GPLv2+ and LGPLv2+ code
|
||||||
License: GPLv2+ and LGPLv2+
|
License: GPLv2+ and LGPLv2+
|
||||||
URL: https://wiki.gnome.org/Projects/Tracker
|
URL: https://wiki.gnome.org/Projects/Tracker
|
||||||
Source0: https://download.gnome.org/sources/%{name}/2.3/%{name}-%{version}.tar.xz
|
Source0: https://download.gnome.org/sources/%{name}/2.3/%{name}-%{version}.tar.xz
|
||||||
|
# Fix tracker erroring out with "Failed to set scheduler settings"
|
||||||
|
# https://gitlab.gnome.org/GNOME/tracker-miners/merge_requests/148
|
||||||
|
Patch0: 148.patch
|
||||||
|
|
||||||
BuildRequires: gcc
|
BuildRequires: gcc
|
||||||
BuildRequires: giflib-devel
|
BuildRequires: giflib-devel
|
||||||
@ -126,6 +129,9 @@ rm -rf %{buildroot}%{_datadir}/tracker-tests
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Feb 19 2020 Kalev Lember <klember@redhat.com> - 2.3.2-2
|
||||||
|
- Backport a fix for tracker erroring out with "Failed to set scheduler settings"
|
||||||
|
|
||||||
* Wed Feb 19 2020 Kalev Lember <klember@redhat.com> - 2.3.2-1
|
* Wed Feb 19 2020 Kalev Lember <klember@redhat.com> - 2.3.2-1
|
||||||
- Update to 2.3.2
|
- Update to 2.3.2
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user