X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fgrub2%2Fgrub2.c;h=34746164728f4e3edc166a7c39f1039e94227f15;hp=22d42dfc432a093d776a03b4109847413a66077b;hb=5b33aaaaad68b890aacc3ddc4e47812a58d8c1e6;hpb=d2a32f50660d32885ee20b6e3b5bbabfecd2b4e9 diff --git a/discover/grub2/grub2.c b/discover/grub2/grub2.c index 22d42df..3474616 100644 --- a/discover/grub2/grub2.c +++ b/discover/grub2/grub2.c @@ -1,5 +1,7 @@ #include +#include +#include #include #include @@ -9,8 +11,6 @@ #include #include "grub2.h" -#include "parser.h" -#include "lexer.h" static const char *const grub2_conf_files[] = { "/grub.cfg", @@ -86,24 +86,39 @@ bool resolve_grub2_resource(struct device_handler *handler, return true; } -static int grub2_parse(struct discover_context *dc, char *buf, int len) +static int grub2_parse(struct discover_context *dc) { + const char * const *filename; struct grub2_parser *parser; + int len, rc; + char *buf; + + /* Support block device boot only at present */ + if (dc->event) + return -1; + + for (filename = grub2_conf_files; *filename; filename++) { + rc = parser_request_file(dc, dc->device, *filename, &buf, &len); + if (rc) + continue; + + parser = grub2_parser_create(dc); + grub2_parser_parse(parser, *filename, buf, len); + device_handler_status_dev_info(dc->handler, dc->device, + _("Parsed GRUB configuration from %s"), + *filename); + talloc_free(buf); + talloc_free(parser); + break; + } - parser = grub2_parser_create(dc); - - grub2_parser_parse(parser, buf, len); - - talloc_free(parser); - return 1; + return 0; } static struct parser grub2_parser = { .name = "grub2", - .method = CONF_METHOD_LOCAL_FILE, .parse = grub2_parse, - .filenames = grub2_conf_files, .resolve_resource = resolve_grub2_resource, };