X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=discover%2Fgrub2%2Fscript.c;h=e29d43702b1e0099435ab76b2f3966ad559cee90;hb=fc95dc4ecc55c3dd4e429c6b5530ae2672d7ca1f;hp=d0b824aebcb9965e63d2ec0d0cb631da0a2dfc5d;hpb=ffc167572a9d56c52908aebefe62ba3e3e2a9cf8;p=petitboot diff --git a/discover/grub2/script.c b/discover/grub2/script.c index d0b824a..e29d437 100644 --- a/discover/grub2/script.c +++ b/discover/grub2/script.c @@ -23,8 +23,8 @@ container_of(stmt, struct grub2_statement_conditional, st) struct env_entry { - const char *name; - const char *value; + char *name; + char *value; struct list_item list; }; @@ -35,6 +35,8 @@ struct grub2_symtab_entry { struct list_item list; }; +static const char *default_prefix = "/boot/grub"; + static struct grub2_symtab_entry *script_lookup_function( struct grub2_script *script, const char *name) { @@ -73,11 +75,13 @@ void script_env_set(struct grub2_script *script, if (!entry) { entry = talloc(script, struct env_entry); - entry->name = name; + entry->name = talloc_strdup(entry, name); list_add(&script->environment, &entry->list); + } else { + talloc_free(entry->value); } - entry->value = value; + entry->value = talloc_strdup(entry, value); } static bool expand_var(struct grub2_script *script, struct grub2_word *word) @@ -316,7 +320,7 @@ int statement_if_execute(struct grub2_script *script, struct grub2_statement_if *st = to_stmt_if(statement); struct grub2_statement *conditional; bool executed; - int rc; + int rc = 0; list_for_each_entry(&st->conditionals->list, conditional, list) { rc = statement_conditional_execute(script, @@ -401,7 +405,7 @@ static void init_env(struct grub2_script *script) env = talloc(script, struct env_entry); env->name = talloc_strdup(env, "prefix"); - env->value = talloc_strdup(env, "/"); + env->value = talloc_strdup(env, default_prefix); list_add(&script->environment, &env->list); }