teknoraver / rpms / systemd

Forked from rpms/systemd 2 months ago
Clone

Blame SOURCES/0345-bus_open-leak-sd_event_source-when-udevadm-trigger.patch

52b84b
From 448b34284c09469eaa2168291ccb34afc3e4cc1d Mon Sep 17 00:00:00 2001
52b84b
From: ven <2988994+hexiaowen@users.noreply.github.com>
52b84b
Date: Wed, 22 May 2019 14:24:28 +0800
52b84b
Subject: [PATCH] =?UTF-8?q?bus=5Fopen=20leak=20sd=5Fevent=5Fsource=20when?=
52b84b
 =?UTF-8?q?=20udevadm=20trigger=E3=80=82?=
52b84b
MIME-Version: 1.0
52b84b
Content-Type: text/plain; charset=UTF-8
52b84b
Content-Transfer-Encoding: 8bit
52b84b
52b84b
On my host, when executing the udevadm trigger, I only receive the change event, which causes memleak
52b84b
52b84b
(cherry picked from commit b2774a3ae692113e1f47a336a6c09bac9cfb49ad)
52b84b
52b84b
Resolves: #1798504
52b84b
---
52b84b
 src/login/logind-button.c | 1 +
52b84b
 1 file changed, 1 insertion(+)
52b84b
52b84b
diff --git a/src/login/logind-button.c b/src/login/logind-button.c
52b84b
index 0defa6b9ba..9944eb2316 100644
52b84b
--- a/src/login/logind-button.c
52b84b
+++ b/src/login/logind-button.c
52b84b
@@ -341,6 +341,7 @@ int button_open(Button *b) {
52b84b
 
52b84b
         (void) button_set_mask(b);
52b84b
 
52b84b
+        b->io_event_source = sd_event_source_unref(b->io_event_source);
52b84b
         r = sd_event_add_io(b->manager->event, &b->io_event_source, b->fd, EPOLLIN, button_dispatch, b);
52b84b
         if (r < 0) {
52b84b
                 log_error_errno(r, "Failed to add button event: %m");