chiark / gitweb /
if needed, store database entries also for devices which do not have a device node
authorKay Sievers <kay.sievers@vrfy.org>
Sun, 28 Dec 2008 00:49:01 +0000 (01:49 +0100)
committerKay Sievers <kay.sievers@vrfy.org>
Sun, 28 Dec 2008 00:49:01 +0000 (01:49 +0100)
udev/lib/libudev-device-db-write.c
udev/udev-event.c

index 34095e5682303c08dd102ffe4287971a79e8301d..11e0ab5f60daaf6bc3892376405fe6a2629882a1 100644 (file)
@@ -56,11 +56,21 @@ int udev_device_update_db(struct udev_device *udev_device)
        udev_list_entry_foreach(list_entry, udev_device_get_properties_list_entry(udev_device))
                if (udev_list_entry_get_flag(list_entry))
                        goto file;
-       if (udev_device_get_num_fake_partitions(udev_device))
+       if (udev_device_get_num_fake_partitions(udev_device) != 0)
                goto file;
        if (udev_device_get_ignore_remove(udev_device))
                goto file;
-       /* try not to waste tmpfs memory; store values, if they fit, in a symlink target */
+       if (udev_device_get_devlink_priority(udev_device) != 0)
+               goto file;
+       if (udev_device_get_event_timeout(udev_device) >= 0)
+               goto file;
+       if (udev_device_get_devnode(udev_device) == NULL)
+               goto out;
+
+       /*
+        * if we have only the node and symlinks to store, try not to waste
+        * tmpfs memory -- store values, if they fit, in a symlink target
+        */
        util_strlcpy(target, &udev_device_get_devnode(udev_device)[devlen], sizeof(target));
        udev_list_entry_foreach(list_entry, udev_device_get_devlinks_list_entry(udev_device)) {
                size_t len;
@@ -86,9 +96,11 @@ file:
                }
        info(udev, "created db file for '%s' in '%s'\n", udev_device_get_devpath(udev_device), filename);
 
-       fprintf(f, "N:%s\n", &udev_device_get_devnode(udev_device)[devlen]);
-       udev_list_entry_foreach(list_entry, udev_device_get_devlinks_list_entry(udev_device))
-               fprintf(f, "S:%s\n", &udev_list_entry_get_name(list_entry)[devlen]);
+       if (udev_device_get_devnode(udev_device) != NULL) {
+               fprintf(f, "N:%s\n", &udev_device_get_devnode(udev_device)[devlen]);
+               udev_list_entry_foreach(list_entry, udev_device_get_devlinks_list_entry(udev_device))
+                       fprintf(f, "S:%s\n", &udev_list_entry_get_name(list_entry)[devlen]);
+       }
        if (udev_device_get_devlink_priority(udev_device) != 0)
                fprintf(f, "L:%u\n", udev_device_get_devlink_priority(udev_device));
        if (udev_device_get_event_timeout(udev_device) >= 0)
index bc692392d2b128298f9e8b3ca7c8cbf98b564634..93a65e7352602b27d3a993a1e62d3516ffb9f40a 100644 (file)
@@ -611,6 +611,7 @@ int udev_event_execute_rules(struct udev_event *event, struct udev_rules *rules)
        /* add netif */
        if (strcmp(udev_device_get_subsystem(dev), "net") == 0 && strcmp(udev_device_get_action(dev), "add") == 0) {
                dbg(event->udev, "netif add '%s'\n", udev_device_get_devpath(dev));
+               udev_device_delete_db(dev);
 
                udev_rules_apply_to_event(rules, event);
                if (event->ignore_device) {
@@ -644,6 +645,7 @@ int udev_event_execute_rules(struct udev_event *event, struct udev_rules *rules)
                                info(event->udev, "changed devpath to '%s'\n", udev_device_get_devpath(dev));
                        }
                }
+               udev_device_update_db(dev);
                goto exit;
        }
 
@@ -684,6 +686,11 @@ int udev_event_execute_rules(struct udev_event *event, struct udev_rules *rules)
        udev_rules_apply_to_event(rules, event);
        if (event->ignore_device)
                info(event->udev, "device event will be ignored\n");
+
+       if (strcmp(udev_device_get_action(dev), "remove") != 0)
+               udev_device_update_db(dev);
+       else
+               udev_device_delete_db(dev);
 exit:
        return err;
 }