]> git.ozlabs.org Git - petitboot/blobdiff - discover/device-handler.h
discover: implement a periodic requery for network devices
[petitboot] / discover / device-handler.h
index 874133db16032adc28f7af27872f9b576f19d12c..427a94a7a2e7abbaeeabe0ef9a832269643ccbfe 100644 (file)
@@ -11,6 +11,7 @@ struct discover_device;
 struct discover_server;
 struct boot_option;
 struct boot_command;
+struct process_info;
 struct event;
 struct device;
 struct waitset;
@@ -37,6 +38,8 @@ struct discover_device {
 
        struct list             boot_options;
        struct list             params;
+
+       struct waiter           *requery_waiter;
 };
 
 struct discover_boot_option {
@@ -44,6 +47,7 @@ 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;
@@ -79,6 +83,9 @@ 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);
 
@@ -97,6 +104,8 @@ 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_start_requery_timeout( struct device_handler *handler,
+               struct discover_device *dev, int timeout);
 
 void device_handler_status(struct device_handler *handler,
                struct status *status);
@@ -108,6 +117,11 @@ 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,
@@ -120,6 +134,8 @@ struct discover_boot_option *discover_boot_option_create(
                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_user_event(struct device_handler *handler,
                                struct event *event);
@@ -148,6 +164,8 @@ 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);