Merge pull request #8626 from floppym/initctl

sysvinit-2.89 compatibility fixes
This commit is contained in:
Lennart Poettering 2018-03-31 12:56:58 +02:00 committed by GitHub
commit 34bfb98ace
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 6 deletions

View File

@ -8213,6 +8213,7 @@ static int talk_initctl(void) {
_cleanup_close_ int fd = -1;
char rl;
int r;
const char *p;
rl = action_to_runlevel();
if (!rl)
@ -8220,17 +8221,21 @@ static int talk_initctl(void) {
request.runlevel = rl;
fd = open(INIT_FIFO, O_WRONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY);
FOREACH_STRING(p, "/run/initctl", "/dev/initctl") {
fd = open(p, O_WRONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY);
if (fd >= 0 || errno != ENOENT)
break;
}
if (fd < 0) {
if (errno == ENOENT)
return 0;
return log_error_errno(errno, "Failed to open "INIT_FIFO": %m");
return log_error_errno(errno, "Failed to open initctl fifo: %m");
}
r = loop_write(fd, &request, sizeof(request), false);
if (r < 0)
return log_error_errno(r, "Failed to write to "INIT_FIFO": %m");
return log_error_errno(r, "Failed to write to %s: %m", p);
return 1;
#else

View File

@ -8,7 +8,7 @@
# (at your option) any later version.
[Unit]
Description=/dev/initctl Compatibility Daemon
Description=initctl Compatibility Daemon
Documentation=man:systemd-initctl.service(8)
DefaultDependencies=no

View File

@ -8,12 +8,12 @@
# (at your option) any later version.
[Unit]
Description=/dev/initctl Compatibility Named Pipe
Description=initctl Compatibility Named Pipe
Documentation=man:systemd-initctl.service(8)
DefaultDependencies=no
Before=sockets.target
[Socket]
ListenFIFO=/run/systemd/initctl/fifo
ListenFIFO=/run/initctl
Symlinks=/dev/initctl
SocketMode=0600