X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=lib%2Ftypes%2Ftypes.h;h=9ab2a43497602d22507e65602132930a20d52f0f;hp=e22dbc307d478389047ad32de52076c57ad955b7;hb=ff7293bba1fd4cdf54bb90bd1b7a38dd393fee69;hpb=366ff957d2900eae6d26ad2f002b735302e7eb41 diff --git a/lib/types/types.h b/lib/types/types.h index e22dbc3..9ab2a43 100644 --- a/lib/types/types.h +++ b/lib/types/types.h @@ -8,11 +8,23 @@ enum device_type { DEVICE_TYPE_NETWORK, DEVICE_TYPE_DISK, + DEVICE_TYPE_USB, DEVICE_TYPE_OPTICAL, DEVICE_TYPE_ANY, DEVICE_TYPE_UNKNOWN, }; +enum ipmi_bootdev { + IPMI_BOOTDEV_NONE = 0x00, + IPMI_BOOTDEV_NETWORK = 0x01, + IPMI_BOOTDEV_DISK = 0x2, + IPMI_BOOTDEV_SAFE = 0x3, + IPMI_BOOTDEV_CDROM = 0x5, + IPMI_BOOTDEV_SETUP = 0x6, + IPMI_BOOTDEV_INVALID = 0xff, +}; + +const char *ipmi_bootdev_display_name(enum ipmi_bootdev bootdev); const char *device_type_display_name(enum device_type type); const char *device_type_name(enum device_type type); enum device_type find_device_type(const char *str); @@ -40,11 +52,32 @@ struct boot_option { char *initrd_file; char *dtb_file; char *boot_args; + char *args_sig_file; bool is_default; struct list_item list; void *ui_info; + + enum { + DISCOVER_BOOT_OPTION, + DISCOVER_PLUGIN_OPTION, + } type; +}; + +struct plugin_option { + char *id; + char *name; + char *vendor; + char *vendor_id; + char *version; + char *date; + char *plugin_file; + + unsigned int n_executables; + char **executables; + + void *ui_info; }; struct boot_command { @@ -53,16 +86,22 @@ struct boot_command { char *initrd_file; char *dtb_file; char *boot_args; + char *args_sig_file; + char *console; }; -struct boot_status { - enum { - BOOT_STATUS_INFO, - BOOT_STATUS_ERROR, +struct status { + enum status_type { + STATUS_INFO, + STATUS_ERROR, } type; char *message; - char *detail; - int progress; + bool backlog; +}; + +struct statuslog_entry { + struct status *status; + struct list_item list; }; struct interface_info { @@ -70,6 +109,7 @@ struct interface_info { uint8_t *hwaddr; char *name; bool link; + char *address; }; struct blockdev_info { @@ -81,6 +121,15 @@ struct blockdev_info { struct system_info { char *type; char *identifier; + char **platform_primary; + char **platform_other; + unsigned int n_primary; + unsigned int n_other; + char **bmc_current; + char **bmc_golden; + unsigned int n_bmc_current; + unsigned int n_bmc_golden; + uint8_t *bmc_mac; struct interface_info **interfaces; unsigned int n_interfaces; struct blockdev_info **blockdevs; @@ -102,8 +151,10 @@ struct interface_config { struct { char *address; char *gateway; + char *url; } static_config; }; + bool override; }; struct network_config { @@ -113,15 +164,6 @@ struct network_config { unsigned int n_dns_servers; }; -struct boot_priority { - /* Boot options with higher priority values will take precedence over - * lower values. Negative priorities signify "don't boot this by - * default". - */ - int priority; - enum device_type type; -}; - struct autoboot_option { enum { BOOT_DEVICE_TYPE, @@ -138,19 +180,29 @@ struct config { unsigned int autoboot_timeout_sec; struct network_config network; - struct boot_priority *boot_priorities; - unsigned int n_boot_priorities; - - char *boot_device; + struct autoboot_option *autoboot_opts; + unsigned int n_autoboot_opts; unsigned int ipmi_bootdev; bool ipmi_bootdev_persistent; + char *http_proxy; + char *https_proxy; + + bool allow_writes; + + char *boot_console; + bool manual_console; char *lang; /* not user-settable */ + unsigned int n_consoles; + char **consoles; + bool disable_snapshots; bool safe_mode; bool debug; }; +bool config_autoboot_active(const struct config *config); + #endif /* _TYPES_H */