Set up LD_PRELOAD for the Payloads module
This commit is contained in:
parent
1be5c0e4d3
commit
90e5000e7e
85
anaconda-Set-up-LD_PRELOAD-for-the-Payloads-module.patch
Normal file
85
anaconda-Set-up-LD_PRELOAD-for-the-Payloads-module.patch
Normal file
@ -0,0 +1,85 @@
|
||||
From e39ab9aee03aebda41e4c247e5f3e58f62abb54b Mon Sep 17 00:00:00 2001
|
||||
From: Vendula Poncova <vponcova@redhat.com>
|
||||
Date: Tue, 2 Jun 2020 17:20:19 +0200
|
||||
Subject: [PATCH] Extend the start-module script
|
||||
|
||||
Allow to specify environment variables with the --env options. The environment
|
||||
will be set up before the module is started.
|
||||
|
||||
Examples:
|
||||
|
||||
./start-module pyanaconda.modules.boss
|
||||
./start-module --env LD_PRELOAD=libgomp.so.1 pyanaconda.modules.payloads
|
||||
|
||||
Related: rhbz#1722181
|
||||
|
||||
The environment variable LD_PRELOAD needs to be set up during the start of
|
||||
the Payloads module, but it needs to be dropped after that.
|
||||
|
||||
After the modularization, only the Payloads module should require LD_PRELOAD.
|
||||
|
||||
Related: rhbz#1722181
|
||||
---
|
||||
...g.fedoraproject.Anaconda.Modules.Payload.service | 2 +-
|
||||
pyanaconda/modules/payload/__main__.py | 4 ++++
|
||||
scripts/start-module | 21 +++++++++++++++++++++
|
||||
3 files changed, 26 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/data/dbus/org.fedoraproject.Anaconda.Modules.Payload.service b/data/dbus/org.fedoraproject.Anaconda.Modules.Payload.service
|
||||
index f6a50c2..a33f87a 100644
|
||||
--- a/data/dbus/org.fedoraproject.Anaconda.Modules.Payload.service
|
||||
+++ b/data/dbus/org.fedoraproject.Anaconda.Modules.Payload.service
|
||||
@@ -1,4 +1,4 @@
|
||||
[D-BUS Service]
|
||||
Name=org.fedoraproject.Anaconda.Modules.Payload
|
||||
-Exec=/usr/libexec/anaconda/start-module pyanaconda.modules.payload
|
||||
+Exec=/usr/libexec/anaconda/start-module --env LD_PRELOAD=libgomp.so.1 pyanaconda.modules.payload
|
||||
User=root
|
||||
diff --git a/pyanaconda/modules/payload/__main__.py b/pyanaconda/modules/payload/__main__.py
|
||||
index 2d53f94..863b151 100644
|
||||
--- a/pyanaconda/modules/payload/__main__.py
|
||||
+++ b/pyanaconda/modules/payload/__main__.py
|
||||
@@ -1,6 +1,10 @@
|
||||
from pyanaconda.modules.common import init
|
||||
init()
|
||||
|
||||
+import os
|
||||
+if "LD_PRELOAD" in os.environ:
|
||||
+ del os.environ["LD_PRELOAD"]
|
||||
+
|
||||
from pyanaconda.modules.payload.payload import PayloadModule
|
||||
payload_module = PayloadModule()
|
||||
payload_module.run()
|
||||
diff --git a/scripts/start-module b/scripts/start-module
|
||||
index 4bc5b0f..6e8da2a 100755
|
||||
--- a/scripts/start-module
|
||||
+++ b/scripts/start-module
|
||||
@@ -1,4 +1,25 @@
|
||||
#!/bin/bash
|
||||
+# Start the Anaconda's Python module $1.
|
||||
+# Examples:
|
||||
+# ./start-module pyanaconda.modules.boss
|
||||
+# ./start-module --env LD_PRELOAD=libgomp.so.1 pyanaconda.modules.payloads
|
||||
+#
|
||||
+
|
||||
+# Process the arguments.
|
||||
+while true
|
||||
+do
|
||||
+ case $1 in
|
||||
+ # Set up the environment.
|
||||
+ --env)
|
||||
+ export $2
|
||||
+ shift 2
|
||||
+ ;;
|
||||
+ # Nothing else to do.
|
||||
+ *)
|
||||
+ break
|
||||
+ ;;
|
||||
+ esac
|
||||
+done
|
||||
|
||||
# add updates & product image directories to PYTHONPATH if
|
||||
# it looks like we are in the installation environment
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
@ -3,7 +3,7 @@
|
||||
|
||||
Name: anaconda
|
||||
Version: 29.24.7
|
||||
Release: 30
|
||||
Release: 31
|
||||
Summary: Graphical system installer
|
||||
License: GPLv2+ and MIT
|
||||
URL: https://fedoraproject.org/wiki/Anaconda
|
||||
@ -50,6 +50,7 @@ Patch9032: anaconda-modify-default-timezone-and-zh_CN_po.patch
|
||||
Patch9033: bugfix-modify-network-hostname-dot-illegal.patch
|
||||
Patch9034: backport-Remove-initThreading-method-from-pyanaconda-threading.patch
|
||||
Patch9035: huawei-add-boot-options-for-dummy.patch
|
||||
Patch9036: anaconda-Set-up-LD_PRELOAD-for-the-Payloads-module.patch
|
||||
|
||||
BuildRequires: audit-libs-devel libtool gettext-devel >= 0.19.8 gtk3-devel >= 3.22.17
|
||||
BuildRequires: gtk-doc gtk3-devel-docs >= 3.22.17 glib2-doc gobject-introspection-devel
|
||||
@ -222,6 +223,12 @@ update-desktop-database &> /dev/null || :
|
||||
%{_datadir}/gtk-doc
|
||||
|
||||
%changelog
|
||||
* Fri Aug 21 2020 zhangqiumiao <zhangqiumiao1@huawei.com> - 29.24.7-31
|
||||
- Type:bugfix
|
||||
- Id:NA
|
||||
- SUG:NA
|
||||
- DESC:Set up LD_PRELOAD for the Payloads module
|
||||
|
||||
* Tue Aug 18 2020 chenyaqiang <chenyaqiang@huawei.com> - 29.24.7-30
|
||||
- rebuild for package build
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user