]> git.ozlabs.org Git - petitboot/blobdiff - discover/device-handler.h
discover/resource: create_url_resource should take ownership of url
[petitboot] / discover / device-handler.h
index 60a33b7bfc9107c5fba31177d794f13a5eb6313b..854be48dab48176e925e985eb56cf0a936fe48c6 100644 (file)
@@ -1,9 +1,9 @@
 #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>
 
 struct device_handler;
 struct discover_device;
@@ -23,19 +23,23 @@ enum conf_method {
        CONF_METHOD_UNKNOWN = -1,
 };
 
+
 struct discover_device {
        struct device           *device;
 
        char                    **links;
        int                     n_links;
 
-       char                    *uuid;
-       char                    *label;
+       const char              *uuid;
+       const char              *label;
+
+       const char              *mount_path;
+       const char              *device_path;
 
-       char                    *mount_path;
-       char                    *device_path;
+       bool                    notified;
 
        struct list             boot_options;
+       struct list             params;
 };
 
 struct discover_boot_option {
@@ -46,6 +50,7 @@ struct discover_boot_option {
 
        struct resource         *boot_image;
        struct resource         *initrd;
+       struct resource         *dtb;
        struct resource         *icon;
 };
 
@@ -68,25 +73,49 @@ 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);
 
-struct device *discover_context_device(struct discover_context *ctx);
+struct discover_device *discover_device_create(struct device_handler *handler,
+               const char *id);
+void device_handler_add_device(struct device_handler *handler,
+               struct discover_device *device);
+int device_handler_discover(struct device_handler *handler,
+               struct discover_device *dev, enum conf_method method);
+int device_handler_conf(struct device_handler *handler,
+               struct discover_device *dev, struct pb_url *url,
+               enum conf_method method);
+void device_handler_remove(struct device_handler *handler,
+               struct discover_device *device);
+
+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 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);
 
-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);