mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-11 05:17:44 +03:00
core: don't accidentally unref a varlink connection twice
Let's make sure that our close handler unrefs a connection again that we
are already unreffing a few stack frames up by invalidating the pointer
first, and dropping the ref counter only after that.
Replaces: 39ad3f1c09
Fixes: #18025
This commit is contained in:
parent
cc6b0a18ff
commit
d65e974e67
@ -475,8 +475,11 @@ int manager_varlink_init(Manager *m) {
|
||||
void manager_varlink_done(Manager *m) {
|
||||
assert(m);
|
||||
|
||||
/* Send the final message if we still have a subscribe request open. */
|
||||
m->managed_oom_varlink_request = varlink_close_unref(m->managed_oom_varlink_request);
|
||||
/* Explicitly close the varlink connection to oomd. Note we first take the varlink connection out of
|
||||
* the manager, and only then disconnect it — in two steps – so that we don't end up accidentally
|
||||
* unreffing it twice. After all, closing the connection might cause the disconnect handler we
|
||||
* installed (vl_disconnect() above) to be called, where we will unref it too. */
|
||||
varlink_close_unref(TAKE_PTR(m->managed_oom_varlink_request));
|
||||
|
||||
m->varlink_server = varlink_server_unref(m->varlink_server);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user