[prev in list] [next in list] [prev in thread] [next in thread]
List: linux-bluetooth
Subject: [BlueZ v2 10/20] main: Fix memory leaks
From: Bastien Nocera <hadess () hadess ! net>
Date: 2024-05-10 12:10:20
Message-ID: 20240510121355.3241456-11-hadess () hadess ! net
[Download RAW message or body]
Error: RESOURCE_LEAK (CWE-772): [#def51] [important]
bluez-5.75/src/main.c:451:2: alloc_arg: "parse_config_string" allocates memory that \
is stored into "str". bluez-5.75/src/main.c:454:2: identity_transfer: Passing "str" \
as argument 1 to function "strtol", which sets "endptr" to that argument. \
bluez-5.75/src/main.c:456:3: noescape: Assuming resource "str" is not freed or \
pointed-to as ellipsis argument to "btd_error". bluez-5.75/src/main.c:457:3: \
leaked_storage: Variable "endptr" going out of scope leaks the storage it points to. \
bluez-5.75/src/main.c:457:3: leaked_storage: Variable "str" going out of scope leaks \
the storage it points to. 455| if (!endptr || *endptr != '\0') {
456| error("%s.%s = %s is not integer", group, key, str);
457|-> return false;
458| }
459|
Error: RESOURCE_LEAK (CWE-772): [#def52] [important]
bluez-5.75/src/main.c:451:2: alloc_arg: "parse_config_string" allocates memory that \
is stored into "str". bluez-5.75/src/main.c:454:2: identity_transfer: Passing "str" \
as argument 1 to function "strtol", which sets "endptr" to that argument. \
bluez-5.75/src/main.c:463:3: leaked_storage: Variable "endptr" going out of scope \
leaks the storage it points to. bluez-5.75/src/main.c:463:3: leaked_storage: Variable \
"str" going out of scope leaks the storage it points to. 461| warn("%s.%s = %zu is \
out of range (< %zu)", group, key, tmp, 462| min);
463|-> return false;
464| }
465|
Error: RESOURCE_LEAK (CWE-772): [#def53] [important]
bluez-5.75/src/main.c:451:2: alloc_arg: "parse_config_string" allocates memory that \
is stored into "str". bluez-5.75/src/main.c:454:2: identity_transfer: Passing "str" \
as argument 1 to function "strtol", which sets "endptr" to that argument. \
bluez-5.75/src/main.c:475:2: leaked_storage: Variable "endptr" going out of scope \
leaks the storage it points to. bluez-5.75/src/main.c:475:2: leaked_storage: Variable \
"str" going out of scope leaks the storage it points to. 473| *val = tmp;
474|
475|-> return true;
476| }
477|
---
src/main.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/src/main.c b/src/main.c
index 23af6781d931..ac840d684f6d 100644
--- a/src/main.c
+++ b/src/main.c
@@ -454,21 +454,25 @@ static bool parse_config_int(GKeyFile *config, const char \
*group, tmp = strtol(str, &endptr, 0);
if (!endptr || *endptr != '\0') {
error("%s.%s = %s is not integer", group, key, str);
+ g_free(str);
return false;
}
if (tmp < min) {
+ g_free(str);
warn("%s.%s = %zu is out of range (< %zu)", group, key, tmp,
min);
return false;
}
if (tmp > max) {
+ g_free(str);
warn("%s.%s = %zu is out of range (> %zu)", group, key, tmp,
max);
return false;
}
+ g_free(str);
if (val)
*val = tmp;
--
2.44.0
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic