I now ran everything with D-BUS monitoring and GDBUS debugging in shim.

When selecting "Shutdown" from the indicator, on the session bus there's
nothing surprising:

method call sender=:1.18 -> dest=:1.34 serial=53 
path=/org/gnome/SessionManager/EndSessionDialog; interface=org
.gnome.SessionManager.EndSessionDialog; member=Open
method call sender=:1.34 -> dest=:1.13 serial=538 
path=/org/gnome/SessionManager; interface=org.gnome.SessionManager; 
member=Shutdown

gnome-session then calls to systemd for the actual shutdown on the
system bus:

signal sender=:1.2 -> dest=(null destination) serial=156 
path=/org/freedesktop/login1; interface=org.freedeskto
p.login1.Manager; member=PrepareForShutdown
   boolean true

method call sender=:1.2 -> dest=org.freedesktop.systemd1 serial=165 
path=/org/freedesktop/systemd1; interface=org.freedesktop.systemd1.Manager; 
member=StartUnit
   string "poweroff.target"
   string "replace-irreversibly"

Notably this is the only method call to systemd-shim in the whole
process (I don't see a suspend.target call!), and there are no calls to
UPower or logind.

However, there is no corresponding entry in systemd-shim's debug output.
Instead, I only see:

18:06:24 O:     interface -> 'org.freedesktop.systemd1.Manager'
18:06:24 O:     member -> 'StartUnit'
18:06:24 O:     destination -> 'org.freedesktop.systemd1'
18:06:24 O:     sender -> ':1.2'
18:06:24 O:     signature -> signature 'ss'
18:06:24 O:   Body: ('suspend.target', 'replace-irreversibly')

so something (presumably logind) indeed calls systemd-shim's suspend
target when I close the lid. Conversely, I don't see *that* call in the
system D-BUS monitor.

However, monitoring D-BUS during shutdown is a rather wonky business in
the first place, as during shutdown the system D-BUS itself is being
killed. So I figure it wasn't actually running any more, or being shut
down when I closed the lid, and I missed logind's suspend call to
systemd-shim.

The main oddity which points out why this happens is that systemd-shim
does *not* stay running as one would expect:

18:28:17 I: Started /usr/lib/x86_64-linux-gnu/systemd-shim
18:28:17 E: 
18:28:17 E: ** (process:3919): WARNING **: going into in_shutdown mode now
[...]   # ^ I manually added that warning for debugging the in_shutdown flag
18:28:18 O: GDBus-debug:Call:
18:28:18 O:  >>>> ASYNC org.freedesktop.DBus.RequestName()
[...]   # this does not get very far:
18:28:18 O: GDBus-debug:Transport:
18:28:18 O:   <<<< READ 16 bytes of message with serial 3 and
18:28:18 O:        size 189 to offset 0 from a GSocketInputStream
Terminated


and immediately afterwards:
18:28:19 I: Started /usr/lib/x86_64-linux-gnu/systemd-shim
[...]  # so at that point we definitively lost the call to poweroff.target and 
the in_shutdown flag.
18:28:19 O: GDBus-debug:Message:
[...]
18:28:19 O:   Body: ('suspend.target', 'replace-irreversibly')
   # this would then actually be executed as it's a fresh instance.

So as far as I can see, we need to keep systemd-shim alive even if the
system D-BUS is being shut down. It still seems to be alive enough to
spawn new requests, but it already *seems* to kill existing instances;
at least that's how I interpret the "Terminated". It now needs to be
confirmed what exactly terminates the shim.

** Attachment added: "D-BUS system monitor log"
   
https://bugs.launchpad.net/ubuntu/trusty/+source/systemd-shim/+bug/1211514/+attachment/3906610/+files/dbus-monitor-system.log

-- 
You received this bug notification because you are a member of Ubuntu
Bugs, which is subscribed to Ubuntu.
https://bugs.launchpad.net/bugs/1211514

Title:
  Shutdowns fail to finish if laptop lid is closed before completely
  shutdown

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/systemd-shim/+bug/1211514/+subscriptions

-- 
ubuntu-bugs mailing list
ubuntu-bugs@lists.ubuntu.com
https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs

Reply via email to