|
|
594167 |
From 9c166afe17888b08d1e269cfd83a31838d601534 Mon Sep 17 00:00:00 2001
|
|
|
594167 |
From: Evgeny Vereshchagin <evvers@ya.ru>
|
|
|
594167 |
Date: Wed, 4 May 2022 11:35:19 +0000
|
|
|
594167 |
Subject: [PATCH] timedatectl: fix a memory leak
|
|
|
594167 |
|
|
|
594167 |
```
|
|
|
594167 |
timedatectl list-timezones --no-pager
|
|
|
594167 |
...
|
|
|
594167 |
==164329==ERROR: LeakSanitizer: detected memory leaks
|
|
|
594167 |
|
|
|
594167 |
Direct leak of 8192 byte(s) in 1 object(s) allocated from:
|
|
|
594167 |
#0 0x7fe8a74b6f8c in reallocarray (/lib64/libasan.so.6+0xaef8c)
|
|
|
594167 |
#1 0x7fe8a63485dc in strv_push ../src/basic/strv.c:419
|
|
|
594167 |
#2 0x7fe8a6349419 in strv_consume ../src/basic/strv.c:490
|
|
|
594167 |
#3 0x7fe8a634958d in strv_extend ../src/basic/strv.c:542
|
|
|
594167 |
#4 0x7fe8a643d787 in bus_message_read_strv_extend ../src/libsystemd/sd-bus/bus-message.c:5606
|
|
|
594167 |
#5 0x7fe8a643db9d in sd_bus_message_read_strv ../src/libsystemd/sd-bus/bus-message.c:5628
|
|
|
594167 |
#6 0x4085fb in list_timezones ../src/timedate/timedatectl.c:314
|
|
|
594167 |
#7 0x7fe8a61ef3e1 in dispatch_verb ../src/shared/verbs.c:103
|
|
|
594167 |
#8 0x410f91 in timedatectl_main ../src/timedate/timedatectl.c:1025
|
|
|
594167 |
#9 0x41111c in run ../src/timedate/timedatectl.c:1043
|
|
|
594167 |
#10 0x411242 in main ../src/timedate/timedatectl.c:1046
|
|
|
594167 |
#11 0x7fe8a489df1f in __libc_start_call_main (/lib64/libc.so.6+0x40f1f)
|
|
|
594167 |
```
|
|
|
594167 |
|
|
|
594167 |
(cherry picked from commit a2e37d52312806b1847800df2358e61276cda052)
|
|
|
594167 |
Related: #2087652
|
|
|
594167 |
---
|
|
|
594167 |
src/timedate/timedatectl.c | 2 +-
|
|
|
594167 |
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
|
594167 |
|
|
|
594167 |
diff --git a/src/timedate/timedatectl.c b/src/timedate/timedatectl.c
|
|
|
594167 |
index 75ca6195da..31909064cf 100644
|
|
|
594167 |
--- a/src/timedate/timedatectl.c
|
|
|
594167 |
+++ b/src/timedate/timedatectl.c
|
|
|
594167 |
@@ -304,7 +304,7 @@ static int list_timezones(int argc, char **argv, void *userdata) {
|
|
|
594167 |
sd_bus *bus = userdata;
|
|
|
594167 |
_cleanup_(sd_bus_message_unrefp) sd_bus_message *reply = NULL;
|
|
|
594167 |
int r;
|
|
|
594167 |
- char** zones;
|
|
|
594167 |
+ _cleanup_strv_free_ char **zones = NULL;
|
|
|
594167 |
|
|
|
594167 |
r = bus_call_method(bus, bus_timedate, "ListTimezones", &error, &reply, NULL);
|
|
|
594167 |
if (r < 0)
|