From: Jeremy Kerr Date: Thu, 19 Sep 2013 14:18:04 +0000 (+0800) Subject: discover: Implement device priorities X-Git-Tag: v1.0.0~487 X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=commitdiff_plain;h=c12cebabba5c4647f558ef40f8cbc8c6a204593e discover: Implement device priorities Signed-off-by: Jeremy Kerr --- diff --git a/discover/device-handler.c b/discover/device-handler.c index cdfee48..f9d2dbf 100644 --- a/discover/device-handler.c +++ b/discover/device-handler.c @@ -334,17 +334,50 @@ static int default_timeout(void *arg) return 0; } -static void set_default(struct device_handler *handler, +static bool priority_match(struct boot_priority *prio, struct discover_boot_option *opt) { - if (handler->default_boot_option) - return; + return prio->type == opt->device->device->type; +} + +static int default_option_priority(struct discover_boot_option *opt) +{ + const struct config *config; + struct boot_priority *prio; + int i; + + config = config_get(); + + for (i = 0; i < config->n_boot_priorities; i++) { + prio = &config->boot_priorities[i]; + if (priority_match(prio, opt)) + break; + } + + return i; +} +static void set_default(struct device_handler *handler, + struct discover_boot_option *opt) +{ if (!handler->autoboot_enabled) return; - handler->default_boot_option = opt; + /* Resolve any conflicts: if we have a new default option, it only + * replaces the current if it has a higher priority. */ + if (handler->default_boot_option) { + int new_prio, cur_prio; + + new_prio = default_option_priority(opt); + cur_prio = default_option_priority( + handler->default_boot_option); + + if (new_prio >= cur_prio) + return; + } + handler->sec_to_boot = config_get()->autoboot_timeout_sec; + handler->default_boot_option = opt; pb_log("Boot option %s set as default, timeout %u sec.\n", opt->option->id, handler->sec_to_boot); diff --git a/lib/pb-config/pb-config.c b/lib/pb-config/pb-config.c index aad3b9e..b6f26c7 100644 --- a/lib/pb-config/pb-config.c +++ b/lib/pb-config/pb-config.c @@ -1,5 +1,6 @@ #include +#include #include #include "pb-config.h" @@ -18,6 +19,13 @@ static void config_set_defaults(struct config *config) config->network.n_interfaces = 0; config->network.dns_servers = NULL; config->network.n_dns_servers = 0; + + config->n_boot_priorities = 2; + config->boot_priorities = talloc_array(config, struct boot_priority, + config->n_boot_priorities); + config->boot_priorities[0].type = DEVICE_TYPE_NETWORK; + config->boot_priorities[1].type = DEVICE_TYPE_DISK; + } static void dump_config(struct config *config) diff --git a/lib/pb-config/pb-config.h b/lib/pb-config/pb-config.h index c74fa1b..523cada 100644 --- a/lib/pb-config/pb-config.h +++ b/lib/pb-config/pb-config.h @@ -4,6 +4,8 @@ #include #include +#include + #define HWADDR_SIZE 6 struct interface_config { @@ -30,10 +32,16 @@ struct network_config { int n_dns_servers; }; +struct boot_priority { + enum device_type type; +}; + struct config { bool autoboot_enabled; int autoboot_timeout_sec; struct network_config network; + struct boot_priority *boot_priorities; + int n_boot_priorities; };