]> git.ozlabs.org Git - petitboot/blobdiff - discover/device-handler.h
discover: pxe: Avoid dereferencing null pointer
[petitboot] / discover / device-handler.h
index 693f5e45a229e66a71cd069049e10486c536cdd7..771cd066a37697e5c99a73054b2a043341832820 100644 (file)
@@ -1,27 +1,21 @@
 #ifndef _DEVICE_HANDLER_H
 #define _DEVICE_HANDLER_H
 
-#include <list/list.h>
+#include <stdbool.h>
 
-#define DEFAULT_BOOT_TIMEOUT_SEC       10
+#include <list/list.h>
+#include <types/types.h>
 
 struct device_handler;
 struct discover_device;
 struct discover_server;
 struct boot_option;
 struct boot_command;
+struct process_info;
 struct event;
 struct device;
 struct waitset;
-
-enum conf_method {
-       CONF_METHOD_LOCAL_FILE, /* discover by looking at local files on this
-                                  block device */
-
-       CONF_METHOD_DHCP,       /* configuration from a DHCP response */
-
-       CONF_METHOD_UNKNOWN = -1,
-};
+struct config;
 
 struct discover_device {
        struct device           *device;
@@ -29,13 +23,21 @@ struct discover_device {
        char                    **links;
        int                     n_links;
 
-       char                    *uuid;
-       char                    *label;
+       const char              *uuid;
+       const char              *label;
 
        char                    *mount_path;
-       char                    *device_path;
+       char                    *root_path;
+       const char              *device_path;
+       struct ramdisk_device   *ramdisk;
+       bool                    mounted;
+       bool                    mounted_rw;
+       bool                    unmount;
+
+       bool                    notified;
 
        struct list             boot_options;
+       struct list             params;
 };
 
 struct discover_boot_option {
@@ -43,21 +45,32 @@ struct discover_boot_option {
        struct discover_device  *device;
        struct boot_option      *option;
        struct list_item        list;
+       const char              *proxy;
 
        struct resource         *boot_image;
        struct resource         *initrd;
        struct resource         *dtb;
+       struct resource         *args_sig_file;
        struct resource         *icon;
 };
 
 
 struct discover_context {
+       struct device_handler   *handler;
        struct parser           *parser;
        struct event            *event;
        struct discover_device  *device;
        struct list             boot_options;
        struct pb_url           *conf_url;
-       enum conf_method        method;
+       void                    *test_data;
+};
+
+struct ramdisk_device {
+       const char      *path;
+       char            *snapshot;
+       char            *origin;
+       char            *base;
+       uint64_t        sectors;
 };
 
 struct device_handler *device_handler_init(struct discover_server *server,
@@ -68,29 +81,91 @@ void device_handler_destroy(struct device_handler *devices);
 int device_handler_get_device_count(const struct device_handler *handler);
 const struct discover_device *device_handler_get_device(
        const struct device_handler *handler, unsigned int index);
+int device_handler_get_plugin_count(const struct device_handler *handler);
+const struct plugin_option *device_handler_get_plugin(
+       const struct device_handler *handler, unsigned int index);
+struct network *device_handler_get_network(
+               const struct device_handler *handler);
+
+struct discover_device *discover_device_create(struct device_handler *handler,
+               const char *uuid, const char *id);
+void device_handler_add_device(struct device_handler *handler,
+               struct discover_device *device);
+void device_handler_add_ramdisk(struct device_handler *handler,
+               const char *path);
+struct ramdisk_device *device_handler_get_ramdisk(
+               struct device_handler *handler);
+void device_handler_release_ramdisk(struct discover_device *device);
+int device_handler_discover(struct device_handler *handler,
+               struct discover_device *dev);
+int device_handler_dhcp(struct device_handler *handler,
+               struct discover_device *dev, struct event *event);
+void device_handler_remove(struct device_handler *handler,
+               struct discover_device *device);
+
+void device_handler_status(struct device_handler *handler,
+               struct status *status);
+void device_handler_status_info(struct device_handler *handler,
+               const char *fmt, ...);
+void device_handler_status_err(struct device_handler *handler,
+               const char *fmt, ...);
+void device_handler_status_dev_info(struct device_handler *handler,
+               struct discover_device *dev, const char *fmt, ...);
+void device_handler_status_dev_err(struct device_handler *handler,
+               struct discover_device *dev, const char *fmt, ...);
+void device_handler_status_download(struct device_handler *handler,
+               const struct process_info *procinfo,
+               unsigned int percentage, unsigned int size, char suffix);
+void device_handler_status_download_remove(struct device_handler *handler,
+               struct process_info *procinfo);
+
+struct discover_context *device_handler_discover_context_create(
+               struct device_handler *handler,
+               struct discover_device *device);
+void device_handler_discover_context_commit(struct device_handler *handler,
+               struct discover_context *ctx);
 
-struct device *discover_context_device(struct discover_context *ctx);
 struct discover_boot_option *discover_boot_option_create(
                struct discover_context *ctx,
                struct discover_device *dev);
 void discover_context_add_boot_option(struct discover_context *ctx,
                struct discover_boot_option *opt);
+void device_handler_add_plugin_option(struct device_handler *handler,
+               struct plugin_option *opt);
 
-int device_handler_event(struct device_handler *handler, struct event *event);
+int device_handler_user_event(struct device_handler *handler,
+                               struct event *event);
 
 struct discover_device *device_lookup_by_name(struct device_handler *handler,
                const char *name);
-struct discover_device *device_lookup_by_path(struct device_handler *handler,
-               const char *path);
 struct discover_device *device_lookup_by_uuid(struct device_handler *handler,
                const char *uuid);
 struct discover_device *device_lookup_by_label(struct device_handler *handler,
                const char *label);
 struct discover_device *device_lookup_by_id(struct device_handler *handler,
                const char *id);
+struct discover_device *device_lookup_by_serial(
+               struct device_handler *device_handler,
+               const char *serial);
+
+void discover_device_set_param(struct discover_device *device,
+               const char *name, const char *value);
+const char *discover_device_get_param(struct discover_device *device,
+               const char *name);
 
 void device_handler_boot(struct device_handler *handler,
                struct boot_command *cmd);
 void device_handler_cancel_default(struct device_handler *handler);
+void device_handler_update_config(struct device_handler *handler,
+               struct config *config);
+void device_handler_process_url(struct device_handler *handler,
+               const char *url, const char *mac, const char *ip);
+void device_handler_install_plugin(struct device_handler *handler,
+               const char *plugin_file);
+void device_handler_reinit(struct device_handler *handler);
+
+int device_request_write(struct discover_device *dev, bool *release);
+void device_release_write(struct discover_device *dev, bool release);
+void device_sync_snapshots(struct device_handler *handler, const char *device);
 
 #endif /* _DEVICE_HANDLER_H */