diff options
author | Masahiro Yamada <masahiroy@kernel.org> | 2021-10-01 08:32:44 +0300 |
---|---|---|
committer | Masahiro Yamada <masahiroy@kernel.org> | 2021-10-01 11:28:17 +0300 |
commit | 229d0cfae5b21bfc42525cf43b0b4279243acc4e (patch) | |
tree | 46de5d2794e9f067e749db5d914beabbc4c02a10 /scripts/kconfig/conf.c | |
parent | 6988f70cf105e70b4ea424d320521a9ed452fe46 (diff) | |
download | linux-229d0cfae5b21bfc42525cf43b0b4279243acc4e.tar.xz |
kconfig: remove 'const' from the return type of sym_escape_string_value()
sym_escape_string_value() returns a malloc'ed memory, but as
(const char *). So, it must be casted to (void *) when it is free'd.
This is odd.
The return type of sym_escape_string_value() should be (char *).
I exploited that free(NULL) has no effect.
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Diffstat (limited to 'scripts/kconfig/conf.c')
-rw-r--r-- | scripts/kconfig/conf.c | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/scripts/kconfig/conf.c b/scripts/kconfig/conf.c index 5d84b44a2a2a..310fdd408793 100644 --- a/scripts/kconfig/conf.c +++ b/scripts/kconfig/conf.c @@ -647,17 +647,16 @@ static void check_conf(struct menu *menu) switch (input_mode) { case listnewconfig: if (sym->name) { - const char *str; + const char *val = sym_get_string_value(sym); + char *escaped = NULL; if (sym->type == S_STRING) { - str = sym_get_string_value(sym); - str = sym_escape_string_value(str); - printf("%s%s=%s\n", CONFIG_, sym->name, str); - free((void *)str); - } else { - str = sym_get_string_value(sym); - printf("%s%s=%s\n", CONFIG_, sym->name, str); + escaped = sym_escape_string_value(val); + val = escaped; } + + printf("%s%s=%s\n", CONFIG_, sym->name, val); + free(escaped); } break; case helpnewconfig: |