diff options
| author | Michael Olbrich <m.olbrich@pengutronix.de> | 2016-10-04 16:13:27 +0200 | 
|---|---|---|
| committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2016-10-04 16:13:27 +0200 | 
| commit | c080fbce9ca4ac21d8dbb1c2d0e8c9205edfdbfb (patch) | |
| tree | d03278ea286ef7fff14602b86241a1ceb2d1e742 /src | |
| parent | 1f4f4cf76c7482a3d64086f0c0d1e2e649183a29 (diff) | |
automount: make sure the expire event is restarted after a daemon-reload (#4265)
If the corresponding mount unit is deserialized after the automount unit
then the expire event is set up in automount_trigger_notify(). However, if
the mount unit is deserialized first then the automount unit is still in
state AUTOMOUNT_DEAD and automount_trigger_notify() aborts without setting
up the expire event.
Explicitly call automount_start_expire() during coldplug to make sure that
the expire event is set up as necessary.
Fixes #4249.
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/automount.c | 5 | 
1 files changed, 5 insertions, 0 deletions
| diff --git a/src/core/automount.c b/src/core/automount.c index 00295cf769..bdc0e06965 100644 --- a/src/core/automount.c +++ b/src/core/automount.c @@ -271,6 +271,11 @@ static int automount_coldplug(Unit *u) {                                  return r;                          (void) sd_event_source_set_description(a->pipe_event_source, "automount-io"); +                        if (a->deserialized_state == AUTOMOUNT_RUNNING) { +                                r = automount_start_expire(a); +                                if (r < 0) +                                        log_unit_warning_errno(UNIT(a), r, "Failed to start expiration timer, ignoring: %m"); +                        }                  }                  automount_set_state(a, a->deserialized_state); | 
