X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=lib%2Ftypes%2Ftypes.h;h=3a76cdaa751b6e0230e761c97df46942542efc0a;hp=bb4b23ca5f601d61e083041580de45a53880eb63;hb=b955fa07fc256b39caedb311f97fed404a63c8d5;hpb=7b793150f96a6fe6033ac1390a663b1b62be2df6 diff --git a/lib/types/types.h b/lib/types/types.h index bb4b23c..3a76cda 100644 --- a/lib/types/types.h +++ b/lib/types/types.h @@ -2,6 +2,7 @@ #define _TYPES_H #include +#include #include enum device_type { @@ -59,4 +60,64 @@ struct boot_status { int progress; }; +struct interface_info { + unsigned int hwaddr_size; + uint8_t *hwaddr; + char *name; + bool link; +}; + +struct blockdev_info { + char *name; + char *uuid; + char *mountpoint; +}; + +struct system_info { + char *type; + char *identifier; + struct interface_info **interfaces; + unsigned int n_interfaces; + struct blockdev_info **blockdevs; + unsigned int n_blockdevs; +}; + +#define HWADDR_SIZE 6 + +struct interface_config { + uint8_t hwaddr[HWADDR_SIZE]; + bool ignore; + enum { + CONFIG_METHOD_DHCP, + CONFIG_METHOD_STATIC, + } method; + union { + struct { + } dhcp_config; + struct { + char *address; + char *gateway; + } static_config; + }; +}; + +struct network_config { + struct interface_config **interfaces; + unsigned int n_interfaces; + const char **dns_servers; + unsigned int n_dns_servers; +}; + +struct boot_priority { + enum device_type type; +}; + +struct config { + bool autoboot_enabled; + unsigned int autoboot_timeout_sec; + struct network_config network; + struct boot_priority *boot_priorities; + unsigned int n_boot_priorities; +}; + #endif /* _TYPES_H */