X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fpxe-parser.c;h=470dd83f08ad71590339156ac1bc10c853152532;hp=d2ebaab0e8a0f07f2f1aeef8bd262762301980b8;hb=6d06f0dbe1195cd8be7d3c54d02012ff16466d0c;hpb=47d0601affe80d7f98a2053749f5e1d479f902f4 diff --git a/discover/pxe-parser.c b/discover/pxe-parser.c index d2ebaab..470dd83 100644 --- a/discover/pxe-parser.c +++ b/discover/pxe-parser.c @@ -41,6 +41,7 @@ static void pxe_finish(struct conf_context *conf) if (info->proxy) info->opt->proxy = talloc_strdup(info->opt, info->proxy); discover_context_add_boot_option(conf->dc, info->opt); + info->opt = NULL; } } @@ -273,12 +274,14 @@ static void pxe_conf_parse_cb(struct load_url_result *result, void *data) if (!data) return; + if (!result) + goto out_clean; handler = talloc_parent(conf); - if (result && result->status == LOAD_OK) + if (result->status == LOAD_OK) rc = read_file(conf, result->local, &buf, &len); - if (!result || result->status != LOAD_OK || rc) { + if (result->status != LOAD_OK || rc) { /* This load failed so try the next available filename */ info = conf->parser_info; if (!info->pxe_conf_files) {