Fix minor typo in discover-client file descriptor check
[petitboot] / discover / udev.c
index 9c1b399cd7857a9d59c6bb1b4884a26bbd315c8a..1a527895878d4de36f17406c3fe7ad44c1ceb07d 100644 (file)
 #include <sys/un.h>
 
 #include <talloc/talloc.h>
 #include <sys/un.h>
 
 #include <talloc/talloc.h>
+#include <waiter/waiter.h>
+#include <log/log.h>
 
 
+#include "event.h"
 #include "udev.h"
 #include "udev.h"
-#include "log.h"
-#include "waiter.h"
 #include "pb-discover.h"
 #include "pb-discover.h"
+#include "device-handler.h"
 
 #define PBOOT_DEVICE_SOCKET "/tmp/petitboot.udev"
 
 #define max(a, b) ((a) > (b) ? (a) : (b))
 
 struct udev {
 
 #define PBOOT_DEVICE_SOCKET "/tmp/petitboot.udev"
 
 #define max(a, b) ((a) > (b) ? (a) : (b))
 
 struct udev {
+       struct device_handler *handler;
        int socket;
 };
 
        int socket;
 };
 
-static void parse_event_params(struct udev_event *event, char *buf, int len)
-{
-       int param_len, name_len, value_len;
-       struct param *param;
-       char *sep;
-
-       for (; len > 0; len -= param_len + 1, buf += param_len + 1) {
-
-               /* find the length of the whole parameter */
-               param_len = strnlen(buf, len);
-               if (!param_len) {
-                       /* multiple NULs? skip over */
-                       param_len = 1;
-                       continue;
-               }
-
-               /* find the separator */
-               sep = memchr(buf, '=', param_len);
-               if (!sep)
-                       continue;
-
-               name_len = sep - buf;
-               value_len = param_len - name_len - 1;
-
-               /* update the params array */
-               event->params = talloc_realloc(event, event->params,
-                                       struct param, ++event->n_params);
-               param = &event->params[event->n_params - 1];
-
-               param->name = talloc_strndup(event, buf, name_len);
-               param->value = talloc_strndup(event, sep + 1, value_len);
-       }
-}
-
-static const char *event_param(struct udev_event *event, const char *name)
-{
-       int i;
-
-       for (i = 0; i < event->n_params; i++)
-               if (!strcasecmp(event->params[i].name, name))
-                       return event->params[i].value;
-
-       return NULL;
-}
-
-static void print_event(struct udev_event *event)
+static void udev_print_event(struct event *event)
 {
        const char *action, *params[] = {
                "DEVNAME", "ID_TYPE", "ID_BUS", "ID_FS_UUID", "ID_FS_LABEL",
 {
        const char *action, *params[] = {
                "DEVNAME", "ID_TYPE", "ID_BUS", "ID_FS_UUID", "ID_FS_LABEL",
@@ -77,61 +35,32 @@ static void print_event(struct udev_event *event)
        };
        int i;
 
        };
        int i;
 
-       action = event->action == UDEV_ACTION_ADD ? "add" : "remove";
+       action = event->action == EVENT_ACTION_ADD ? "add" : "remove";
 
        pb_log("udev %s event:\n", action);
 
        pb_log("udev %s event:\n", action);
-       printf("\tdevice: %s\n", event->device);
+       pb_log("\tdevice: %s\n", event->device);
 
        for (i = 0; params[i]; i++)
 
        for (i = 0; params[i]; i++)
-               printf("\t%-12s => %s\n",
-                               params[i], event_param(event, params[i]));
+               pb_log("\t%-12s => %s\n",
+                               params[i], event_get_param(event, params[i]));
 
 }
 
 
 }
 
-static void handle_udev_message(struct udev *udev, char *buf, int len)
+static void udev_handle_message(struct udev *udev, char *buf, int len)
 {
 {
-       char *sep, *device;
-       enum udev_action action;
-       struct udev_event *event;
-       int device_len;
-
-       /* we should see an <action>@<device>\0 at the head of the buffer */
-       sep = strchr(buf, '@');
-       if (!sep)
-               return;
-
-       /* terminate the action string */
-       *sep = '\0';
-       len -= sep - buf + 1;
+       int result;
+       struct event *event;
 
 
-       if (!strcmp(buf, "add")) {
-               action = UDEV_ACTION_ADD;
+       event = talloc(udev, struct event);
+       event->type = EVENT_TYPE_UDEV;
 
 
-       } else if (!strcmp(buf, "remove")) {
-               action = UDEV_ACTION_REMOVE;
+       result = event_parse_ad_message(event, buf, len);
 
 
-       } else {
+       if (result)
                return;
                return;
-       }
-
-       /* initialise the device string */
-       device = sep + 1;
-       device_len = strnlen(device, len);
-       if (!device_len)
-               return;
-
-       /* now we have an action and a device, we can construct an event */
-       event = talloc(udev, struct udev_event);
-       event->action = action;
-       event->device = talloc_strndup(event, device, device_len);
-       event->n_params = 0;
-       event->params = NULL;
-
-       len -= device_len + 1;
-       parse_event_params(event, device + device_len + 1, len);
-
-       print_event(event);
 
 
+       udev_print_event(event);
+       device_handler_event(udev->handler, event);
        talloc_free(event);
 
        return;
        talloc_free(event);
 
        return;
@@ -153,7 +82,7 @@ static int udev_process(void *arg)
        if (len == 0)
                return 0;
 
        if (len == 0)
                return 0;
 
-       handle_udev_message(udev, buf, len);
+       udev_handle_message(udev, buf, len);
 
        return 0;
 }
 
        return 0;
 }
@@ -168,7 +97,7 @@ static int udev_destructor(void *p)
        return 0;
 }
 
        return 0;
 }
 
-struct udev *udev_init(void)
+struct udev *udev_init(struct device_handler *handler)
 {
        struct sockaddr_un addr;
        struct udev *udev;
 {
        struct sockaddr_un addr;
        struct udev *udev;
@@ -177,6 +106,8 @@ struct udev *udev_init(void)
 
        udev = talloc(NULL, struct udev);
 
 
        udev = talloc(NULL, struct udev);
 
+       udev->handler = handler;
+
        udev->socket = socket(PF_UNIX, SOCK_DGRAM, 0);
        if (udev->socket < 0) {
                pb_log("Error creating udev socket: %s\n", strerror(errno));
        udev->socket = socket(PF_UNIX, SOCK_DGRAM, 0);
        if (udev->socket < 0) {
                pb_log("Error creating udev socket: %s\n", strerror(errno));
@@ -195,6 +126,8 @@ struct udev *udev_init(void)
 
        waiter_register(udev->socket, WAIT_IN, udev_process, udev);
 
 
        waiter_register(udev->socket, WAIT_IN, udev_process, udev);
 
+       pb_log("%s: waiting on %s\n", __func__, PBOOT_DEVICE_SOCKET);
+
        return udev;
 
 out_err:
        return udev;
 
 out_err:
@@ -202,6 +135,16 @@ out_err:
        return NULL;
 }
 
        return NULL;
 }
 
+int udev_trigger(struct udev __attribute__((unused)) *udev)
+{
+       int rc = system("/sbin/udevadm trigger --subsystem-match=block");
+
+       if (rc)
+               pb_log("udev trigger failed: %d (%d)\n", rc, WEXITSTATUS(rc));
+
+       return WEXITSTATUS(rc);
+}
+
 void udev_destroy(struct udev *udev)
 {
        talloc_free(udev);
 void udev_destroy(struct udev *udev)
 {
        talloc_free(udev);