mirror of
https://github.com/LibreELEC/LibreELEC.tv.git
synced 2025-08-02 07:27:49 +00:00
Merge pull request #2373 from codesnake/system2-236_kernel_variables
systemd: Fix a failure in systemd-sysctl during a startup of systemd-236
This commit is contained in:
commit
f115a202f1
@ -0,0 +1,58 @@
|
|||||||
|
From c2ae95a71d8ceb5e7d7b766569044439ef0bad6b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Mike Gilbert <floppym@gentoo.org>
|
||||||
|
Date: Wed, 27 Dec 2017 16:59:04 -0500
|
||||||
|
Subject: [PATCH] sysctl: use raw file descriptor in sysctl_write
|
||||||
|
|
||||||
|
The kernel returns specific error codes which may be lost if we use the
|
||||||
|
libc buffered io functions.
|
||||||
|
|
||||||
|
Fixes: https://github.com/systemd/systemd/issues/7744
|
||||||
|
---
|
||||||
|
src/shared/sysctl-util.c | 17 ++++++++++++++++-
|
||||||
|
1 file changed, 16 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/shared/sysctl-util.c b/src/shared/sysctl-util.c
|
||||||
|
index 189580e3ed..0bc81aaa56 100644
|
||||||
|
--- a/src/shared/sysctl-util.c
|
||||||
|
+++ b/src/shared/sysctl-util.c
|
||||||
|
@@ -18,9 +18,13 @@
|
||||||
|
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
***/
|
||||||
|
|
||||||
|
+#include <errno.h>
|
||||||
|
+#include <fcntl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
|
||||||
|
+#include "fd-util.h"
|
||||||
|
#include "fileio.h"
|
||||||
|
#include "log.h"
|
||||||
|
#include "macro.h"
|
||||||
|
@@ -53,6 +57,7 @@ char *sysctl_normalize(char *s) {
|
||||||
|
|
||||||
|
int sysctl_write(const char *property, const char *value) {
|
||||||
|
char *p;
|
||||||
|
+ _cleanup_close_ int fd = -1;
|
||||||
|
|
||||||
|
assert(property);
|
||||||
|
assert(value);
|
||||||
|
@@ -60,7 +65,17 @@ int sysctl_write(const char *property, const char *value) {
|
||||||
|
log_debug("Setting '%s' to '%s'", property, value);
|
||||||
|
|
||||||
|
p = strjoina("/proc/sys/", property);
|
||||||
|
- return write_string_file(p, value, WRITE_STRING_FILE_DISABLE_BUFFER);
|
||||||
|
+ fd = open(p, O_WRONLY|O_CLOEXEC);
|
||||||
|
+ if (fd < 0)
|
||||||
|
+ return -errno;
|
||||||
|
+
|
||||||
|
+ if (!endswith(value, "\n"))
|
||||||
|
+ value = strjoina(value, "\n");
|
||||||
|
+
|
||||||
|
+ if (write(fd, value, strlen(value)) < 0)
|
||||||
|
+ return -errno;
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int sysctl_read(const char *property, char **content) {
|
Loading…
x
Reference in New Issue
Block a user