mirror of
https://github.com/systemd/systemd.git
synced 2024-11-01 17:51:22 +03:00
udev: use sd_device for udev_event.dev_db
Also, this adds sd_device_unref for the object in udev_event_free() for safety and readability of code.
This commit is contained in:
parent
e0bb2ff94b
commit
480ecb7d28
@ -67,6 +67,8 @@ struct udev_event *udev_event_free(struct udev_event *event) {
|
||||
if (!event)
|
||||
return NULL;
|
||||
|
||||
udev_device_unref(event->dev);
|
||||
sd_device_unref(event->dev_db_clone);
|
||||
sd_netlink_unref(event->rtnl);
|
||||
while ((p = hashmap_steal_first_key(event->run_list)))
|
||||
free(p);
|
||||
@ -739,8 +741,8 @@ static int update_devnode(struct udev_event *event) {
|
||||
return log_device_error_errno(dev, r, "Failed to get devnum: %m");
|
||||
|
||||
/* remove/update possible left-over symlinks from old database entry */
|
||||
if (event->dev_db)
|
||||
(void) udev_node_update_old_links(dev, event->dev_db->device);
|
||||
if (event->dev_db_clone)
|
||||
(void) udev_node_update_old_links(dev, event->dev_db_clone);
|
||||
|
||||
if (!event->owner_set) {
|
||||
r = device_get_devnode_uid(dev, &event->uid);
|
||||
@ -812,7 +814,6 @@ int udev_event_execute_rules(struct udev_event *event,
|
||||
usec_t timeout_usec, usec_t timeout_warn_usec,
|
||||
Hashmap *properties_list,
|
||||
struct udev_rules *rules) {
|
||||
_cleanup_(sd_device_unrefp) sd_device *clone = NULL;
|
||||
sd_device *dev = event->dev->device;
|
||||
const char *subsystem, *action;
|
||||
int r;
|
||||
@ -833,28 +834,24 @@ int udev_event_execute_rules(struct udev_event *event,
|
||||
return 0;
|
||||
}
|
||||
|
||||
r = device_clone_with_db(dev, &clone);
|
||||
r = device_clone_with_db(dev, &event->dev_db_clone);
|
||||
if (r < 0)
|
||||
log_device_debug_errno(dev, r, "Failed to clone sd_device object, ignoring: %m");
|
||||
|
||||
if (clone) {
|
||||
event->dev_db = udev_device_new(NULL, clone);
|
||||
if (!event->dev_db)
|
||||
return -ENOMEM;
|
||||
|
||||
if (event->dev_db_clone) {
|
||||
r = sd_device_get_devnum(dev, NULL);
|
||||
if (r < 0) {
|
||||
if (r != -ENOENT)
|
||||
log_device_debug_errno(dev, r, "Failed to get devnum, ignoring: %m");
|
||||
|
||||
if (streq(action, "move")) {
|
||||
r = device_copy_properties(dev, clone);
|
||||
r = device_copy_properties(dev, event->dev_db_clone);
|
||||
if (r < 0)
|
||||
log_device_debug_errno(dev, r, "Failed to copy properties from cloned device, ignoring: %m");
|
||||
}
|
||||
} else
|
||||
/* Disable watch during event processing. */
|
||||
(void) udev_watch_end(clone);
|
||||
(void) udev_watch_end(event->dev_db_clone);
|
||||
}
|
||||
|
||||
(void) udev_rules_apply_to_event(rules, event,
|
||||
@ -865,12 +862,12 @@ int udev_event_execute_rules(struct udev_event *event,
|
||||
(void) update_devnode(event);
|
||||
|
||||
/* preserve old, or get new initialization timestamp */
|
||||
r = device_ensure_usec_initialized(dev, clone);
|
||||
r = device_ensure_usec_initialized(dev, event->dev_db_clone);
|
||||
if (r < 0)
|
||||
log_device_debug_errno(dev, r, "Failed to set initialization timestamp, ignoring: %m");
|
||||
|
||||
/* (re)write database file */
|
||||
r = device_tag_index(dev, clone, true);
|
||||
r = device_tag_index(dev, event->dev_db_clone, true);
|
||||
if (r < 0)
|
||||
log_device_debug_errno(dev, r, "Failed to update tags under /run/udev/tag/, ignoring: %m");
|
||||
|
||||
@ -880,7 +877,7 @@ int udev_event_execute_rules(struct udev_event *event,
|
||||
|
||||
device_set_is_initialized(dev);
|
||||
|
||||
event->dev_db = udev_device_unref(event->dev_db);
|
||||
event->dev_db_clone = sd_device_unref(event->dev_db_clone);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -16,6 +16,7 @@
|
||||
#include "alloc-util.h"
|
||||
#include "conf-files.h"
|
||||
#include "def.h"
|
||||
#include "device-util.h"
|
||||
#include "dirent-util.h"
|
||||
#include "escape.h"
|
||||
#include "fd-util.h"
|
||||
@ -2030,13 +2031,10 @@ int udev_rules_apply_to_event(
|
||||
const char *key = rules_str(rules, cur->key.value_off);
|
||||
const char *value;
|
||||
|
||||
value = udev_device_get_property_value(event->dev_db, key);
|
||||
if (value != NULL)
|
||||
if (sd_device_get_property_value(event->dev_db_clone, key, &value) >= 0)
|
||||
udev_device_add_property(event->dev, key, value);
|
||||
else {
|
||||
if (cur->key.op != OP_NOMATCH)
|
||||
goto nomatch;
|
||||
}
|
||||
else if (cur->key.op != OP_NOMATCH)
|
||||
goto nomatch;
|
||||
break;
|
||||
}
|
||||
case TK_M_IMPORT_CMDLINE: {
|
||||
|
@ -23,7 +23,7 @@
|
||||
struct udev_event {
|
||||
struct udev_device *dev;
|
||||
struct udev_device *dev_parent;
|
||||
struct udev_device *dev_db;
|
||||
sd_device *dev_db_clone;
|
||||
char *name;
|
||||
char *program_result;
|
||||
mode_t mode;
|
||||
|
Loading…
Reference in New Issue
Block a user