From: Tom Gundersen Date: Fri, 6 Mar 2015 14:22:30 +0000 (+0100) Subject: libudev: introduce clone_with_db() X-Git-Tag: v219.0~379 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=8f0f13f04555d3bc67511d2e334c667cef7e8971;hp=a4445e88cece0444c66d70876b03065158dd4685 libudev: introduce clone_with_db() This allows us to move the db reading from udevd to libudev. --- diff --git a/src/libudev/libudev-device.c b/src/libudev/libudev-device.c index 2604ad705..c0a061af6 100644 --- a/src/libudev/libudev-device.c +++ b/src/libudev/libudev-device.c @@ -1986,6 +1986,20 @@ struct udev_device *udev_device_shallow_clone(struct udev_device *old_device) return device; } +struct udev_device *udev_device_clone_with_db(struct udev_device *old_device) +{ + struct udev_device *device; + + device = udev_device_shallow_clone(old_device); + if (!device) + return NULL; + + udev_device_read_db(device); + udev_device_set_info_loaded(device); + + return device; +} + struct udev_device *udev_device_new_from_nulstr(struct udev *udev, char *nulstr, ssize_t buflen) { struct udev_device *device; ssize_t bufpos = 0; diff --git a/src/libudev/libudev-private.h b/src/libudev/libudev-private.h index c0f9fbe76..a34c0f74e 100644 --- a/src/libudev/libudev-private.h +++ b/src/libudev/libudev-private.h @@ -39,6 +39,7 @@ int udev_get_rules_path(struct udev *udev, char **path[], usec_t *ts_usec[]); /* libudev-device.c */ struct udev_device *udev_device_new_from_nulstr(struct udev *udev, char *nulstr, ssize_t buflen); struct udev_device *udev_device_shallow_clone(struct udev_device *old_device); +struct udev_device *udev_device_clone_with_db(struct udev_device *old_device); int udev_device_copy_properties(struct udev_device *dst, struct udev_device *src); mode_t udev_device_get_devnode_mode(struct udev_device *udev_device); uid_t udev_device_get_devnode_uid(struct udev_device *udev_device); diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c index 4ca73d3db..f62c1eaf4 100644 --- a/src/udev/udev-event.c +++ b/src/udev/udev-event.c @@ -807,11 +807,8 @@ void udev_event_execute_rules(struct udev_event *event, udev_device_delete_db(dev); udev_device_tag_index(dev, NULL, false); } else { - event->dev_db = udev_device_shallow_clone(dev); + event->dev_db = udev_device_clone_with_db(dev); if (event->dev_db != NULL) { - udev_device_read_db(event->dev_db); - udev_device_set_info_loaded(event->dev_db); - /* disable watch during event processing */ if (major(udev_device_get_devnum(dev)) != 0) udev_watch_end(event->udev, event->dev_db);