summaryrefslogtreecommitdiffstats
path: root/discover/grub2-parser.c
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2013-03-18 14:23:23 +0800
committerJeremy Kerr <jk@ozlabs.org>2013-04-29 14:41:04 +1000
commit45e92aa32a80fdbbf5ad3ad64e34b1ac872018ef (patch)
tree2753fb3912c07d23f3e2f622c05043f55c8f24c9 /discover/grub2-parser.c
parent5444648fe1ff9b79f3db5ee6feadd51341f59d71 (diff)
downloadtalos-petitboot-45e92aa32a80fdbbf5ad3ad64e34b1ac872018ef.tar.gz
talos-petitboot-45e92aa32a80fdbbf5ad3ad64e34b1ac872018ef.zip
parsers: dynamically register parsers
Currently, we require all parsers to be defined in an array in parsers.c. This change removes this requirement, by introducting a register_parser() macro, which adds a constructor to register the parser with the core parser infrastructure. Because each parser no longer resolves an undefined symbol, we need to use a `ld -r` object for libparser, instead of using libtool, which creates a .a (and hence has no parsers included). Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'discover/grub2-parser.c')
-rw-r--r--discover/grub2-parser.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/discover/grub2-parser.c b/discover/grub2-parser.c
index eaf3cd3..4a1acf5 100644
--- a/discover/grub2-parser.c
+++ b/discover/grub2-parser.c
@@ -191,8 +191,10 @@ static int grub2_parse(struct discover_context *dc, char *buf, int len)
return 1;
}
-struct parser __grub2_parser = {
+static struct parser grub2_parser = {
.name = "grub2",
.parse = grub2_parse,
.filenames = grub2_conf_files,
};
+
+register_parser(grub2_parser);
OpenPOWER on IntegriCloud