|
Harald Hoyer |
fe20ad |
From 49d2e4a62d9c94c4c4aeeb6c4da4b226f9a638a7 Mon Sep 17 00:00:00 2001
|
|
Harald Hoyer |
fe20ad |
From: Lennart Poettering <lennart@poettering.net>
|
|
Harald Hoyer |
fe20ad |
Date: Fri, 26 Jul 2013 17:32:19 +0200
|
|
Harald Hoyer |
fe20ad |
Subject: [PATCH] logind: update state file after generating the session fifo,
|
|
Harald Hoyer |
fe20ad |
not before
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
https://bugs.freedesktop.org/show_bug.cgi?id=67273
|
|
Harald Hoyer |
fe20ad |
---
|
|
Harald Hoyer |
fe20ad |
src/login/logind-dbus.c | 7 ++++++-
|
|
Harald Hoyer |
fe20ad |
src/login/logind-session-dbus.c | 4 ++++
|
|
Harald Hoyer |
fe20ad |
src/machine/machined-dbus.c | 3 ++-
|
|
Harald Hoyer |
fe20ad |
3 files changed, 12 insertions(+), 2 deletions(-)
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
diff --git a/src/login/logind-dbus.c b/src/login/logind-dbus.c
|
|
Harald Hoyer |
fe20ad |
index 39af637..b5e975a 100644
|
|
Harald Hoyer |
fe20ad |
--- a/src/login/logind-dbus.c
|
|
Harald Hoyer |
fe20ad |
+++ b/src/login/logind-dbus.c
|
|
Harald Hoyer |
fe20ad |
@@ -643,6 +643,10 @@ static int bus_manager_create_session(Manager *m, DBusMessage *message) {
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
session->create_message = dbus_message_ref(message);
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
+ /* Now, let's wait until the slice unit and stuff got
|
|
Harald Hoyer |
fe20ad |
+ * created. We send the reply back from
|
|
Harald Hoyer |
fe20ad |
+ * session_send_create_reply().*/
|
|
Harald Hoyer |
fe20ad |
+
|
|
Harald Hoyer |
fe20ad |
return 0;
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
fail:
|
|
Harald Hoyer |
fe20ad |
@@ -2356,7 +2360,6 @@ DBusHandlerResult bus_message_filter(
|
|
Harald Hoyer |
fe20ad |
if (streq_ptr(path, s->scope_job)) {
|
|
Harald Hoyer |
fe20ad |
free(s->scope_job);
|
|
Harald Hoyer |
fe20ad |
s->scope_job = NULL;
|
|
Harald Hoyer |
fe20ad |
- session_save(s);
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
if (s->started) {
|
|
Harald Hoyer |
fe20ad |
if (streq(result, "done"))
|
|
Harald Hoyer |
fe20ad |
@@ -2366,6 +2369,8 @@ DBusHandlerResult bus_message_filter(
|
|
Harald Hoyer |
fe20ad |
session_send_create_reply(s, &error);
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
+
|
|
Harald Hoyer |
fe20ad |
+ session_save(s);
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
session_add_to_gc_queue(s);
|
|
Harald Hoyer |
fe20ad |
diff --git a/src/login/logind-session-dbus.c b/src/login/logind-session-dbus.c
|
|
Harald Hoyer |
fe20ad |
index 62b9ffd..210f756 100644
|
|
Harald Hoyer |
fe20ad |
--- a/src/login/logind-session-dbus.c
|
|
Harald Hoyer |
fe20ad |
+++ b/src/login/logind-session-dbus.c
|
|
Harald Hoyer |
fe20ad |
@@ -535,6 +535,10 @@ int session_send_create_reply(Session *s, DBusError *error) {
|
|
Harald Hoyer |
fe20ad |
if (!s->create_message)
|
|
Harald Hoyer |
fe20ad |
return 0;
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
+ /* This is called after the session scope was successfully
|
|
Harald Hoyer |
fe20ad |
+ * created, and finishes where bus_manager_create_session()
|
|
Harald Hoyer |
fe20ad |
+ * left off. */
|
|
Harald Hoyer |
fe20ad |
+
|
|
Harald Hoyer |
fe20ad |
if (error) {
|
|
Harald Hoyer |
fe20ad |
DBusError buffer;
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
diff --git a/src/machine/machined-dbus.c b/src/machine/machined-dbus.c
|
|
Harald Hoyer |
fe20ad |
index 1e8bc60..6c4d50b 100644
|
|
Harald Hoyer |
fe20ad |
--- a/src/machine/machined-dbus.c
|
|
Harald Hoyer |
fe20ad |
+++ b/src/machine/machined-dbus.c
|
|
Harald Hoyer |
fe20ad |
@@ -543,7 +543,6 @@ DBusHandlerResult bus_message_filter(
|
|
Harald Hoyer |
fe20ad |
if (streq_ptr(path, mm->scope_job)) {
|
|
Harald Hoyer |
fe20ad |
free(mm->scope_job);
|
|
Harald Hoyer |
fe20ad |
mm->scope_job = NULL;
|
|
Harald Hoyer |
fe20ad |
- machine_save(mm);
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
if (mm->started) {
|
|
Harald Hoyer |
fe20ad |
if (streq(result, "done"))
|
|
Harald Hoyer |
fe20ad |
@@ -553,6 +552,8 @@ DBusHandlerResult bus_message_filter(
|
|
Harald Hoyer |
fe20ad |
machine_send_create_reply(mm, &error);
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
+
|
|
Harald Hoyer |
fe20ad |
+ machine_save(mm);
|
|
Harald Hoyer |
fe20ad |
}
|
|
Harald Hoyer |
fe20ad |
|
|
Harald Hoyer |
fe20ad |
machine_add_to_gc_queue(mm);
|