]> git.itanic.dy.fi Git - linux-stable/commitdiff
kconfig: default to zero if int/hex symbol lacks default property
authorMasahiro Yamada <masahiroy@kernel.org>
Sat, 25 Nov 2023 16:35:59 +0000 (01:35 +0900)
committerMasahiro Yamada <masahiroy@kernel.org>
Sun, 3 Dec 2023 10:01:25 +0000 (19:01 +0900)
When a default property is missing in an int or hex symbol, it defaults
to an empty string, which is not a valid symbol value.

It results in an incorrect .config, and can also lead to an infinite
loop in scripting.

Use "0" for int and "0x0" for hex as a default value.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Reviewed-by: Yoann Congal <yoann.congal@smile.fr>
scripts/kconfig/symbol.c

index f7075d148ac79e3b4120bb383a5e3d22d55fe2bc..a5a4f9153eb7377aaa1970faa148ad6503ffc6bf 100644 (file)
@@ -338,7 +338,11 @@ void sym_calc_value(struct symbol *sym)
 
        switch (sym->type) {
        case S_INT:
+               newval.val = "0";
+               break;
        case S_HEX:
+               newval.val = "0x0";
+               break;
        case S_STRING:
                newval.val = "";
                break;
@@ -746,14 +750,17 @@ const char *sym_get_string_default(struct symbol *sym)
                case yes: return "y";
                }
        case S_INT:
+               if (!str[0])
+                       str = "0";
+               break;
        case S_HEX:
-               return str;
-       case S_STRING:
-               return str;
-       case S_UNKNOWN:
+               if (!str[0])
+                       str = "0x0";
+               break;
+       default:
                break;
        }
-       return "";
+       return str;
 }
 
 const char *sym_get_string_value(struct symbol *sym)