summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2010-07-13 00:27:27 +0200
committerLennart Poettering <lennart@poettering.net>2010-07-13 00:27:27 +0200
commitba3e67a78564bf25c5af97ffe2e1a122b193a9cb (patch)
tree8d47f6a421da2660ac090dd526c387b5fc90e744 /src
parenta974d58e83e409a92ca916bb9bbce0e457ea896f (diff)
socket: when the socket is supposed to stop, don't accept any connections anymore
Diffstat (limited to 'src')
-rw-r--r--src/automount.c7
-rw-r--r--src/path.c4
-rw-r--r--src/socket.c7
-rw-r--r--src/timer.c4
4 files changed, 22 insertions, 0 deletions
diff --git a/src/automount.c b/src/automount.c
index 00f3736b2f..e685c96a76 100644
--- a/src/automount.c
+++ b/src/automount.c
@@ -568,6 +568,13 @@ static void automount_enter_runnning(Automount *a) {
dbus_error_init(&error);
+ /* We don't take mount requests anymore if we are supposed to
+ * shut down anyway */
+ if (a->meta.job && a->meta.job->type == JOB_STOP) {
+ automount_send_ready(a, -EHOSTDOWN);
+ return;
+ }
+
mkdir_p(a->where, a->directory_mode);
/* Before we do anything, let's see if somebody is playing games with us? */
diff --git a/src/path.c b/src/path.c
index 27c4544729..2ae6e569ce 100644
--- a/src/path.c
+++ b/src/path.c
@@ -304,6 +304,10 @@ static void path_enter_running(Path *p) {
assert(p);
dbus_error_init(&error);
+ /* Don't start job if we are supposed to go down */
+ if (p->meta.job && p->meta.job->type == JOB_STOP)
+ return;
+
if ((r = manager_add_job(p->meta.manager, JOB_START, p->unit, JOB_REPLACE, true, &error, NULL)) < 0)
goto fail;
diff --git a/src/socket.c b/src/socket.c
index 2d113aef30..f998cada26 100644
--- a/src/socket.c
+++ b/src/socket.c
@@ -1030,6 +1030,13 @@ static void socket_enter_running(Socket *s, int cfd) {
assert(s);
dbus_error_init(&error);
+ /* We don't take connections anymore if we are supposed to
+ * shut down anyway */
+ if (s->meta.job && s->meta.job->type == JOB_STOP) {
+ close_nointr_nofail(cfd);
+ return;
+ }
+
if (cfd < 0) {
if ((r = manager_add_job(s->meta.manager, JOB_START, UNIT(s->service), JOB_REPLACE, true, &error, NULL)) < 0)
goto fail;
diff --git a/src/timer.c b/src/timer.c
index 1c7010d120..0d4ed27bb4 100644
--- a/src/timer.c
+++ b/src/timer.c
@@ -268,6 +268,10 @@ static void timer_enter_running(Timer *t) {
assert(t);
dbus_error_init(&error);
+ /* Don't start job if we are supposed to go down */
+ if (t->meta.job && t->meta.job->type == JOB_STOP)
+ return;
+
if ((r = manager_add_job(t->meta.manager, JOB_START, t->unit, JOB_REPLACE, true, &error, NULL)) < 0)
goto fail;