From: Yu Watanabe Date: Wed, 4 Dec 2024 18:12:03 +0000 (+0900) Subject: udev: introduce reference counter for UdevEvent X-Git-Tag: v258-rc1~1822^2~1 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=4a90166488a4018effbf471df5e057f901f0b52d;p=thirdparty%2Fsystemd.git udev: introduce reference counter for UdevEvent No functional change, preparation for later commits. --- diff --git a/src/udev/test-udev-rule-runner.c b/src/udev/test-udev-rule-runner.c index d123c8ad1b2..9a04abf5904 100644 --- a/src/udev/test-udev-rule-runner.c +++ b/src/udev/test-udev-rule-runner.c @@ -89,7 +89,7 @@ static int fake_filesystems(void) { static int run(int argc, char *argv[]) { _cleanup_(udev_rules_freep) UdevRules *rules = NULL; - _cleanup_(udev_event_freep) UdevEvent *event = NULL; + _cleanup_(udev_event_unrefp) UdevEvent *event = NULL; _cleanup_(sd_device_unrefp) sd_device *dev = NULL; const char *devpath, *devname, *action; int r; diff --git a/src/udev/test-udev-spawn.c b/src/udev/test-udev-spawn.c index b9674f95531..b4e020cea6c 100644 --- a/src/udev/test-udev-spawn.c +++ b/src/udev/test-udev-spawn.c @@ -12,7 +12,7 @@ static void test_event_spawn_core(bool with_pidfd, const char *cmd, char *result_buf, size_t buf_size) { _cleanup_(sd_device_unrefp) sd_device *dev = NULL; - _cleanup_(udev_event_freep) UdevEvent *event = NULL; + _cleanup_(udev_event_unrefp) UdevEvent *event = NULL; ASSERT_OK_ERRNO(setenv("SYSTEMD_PIDFD", yes_no(with_pidfd), 1)); diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c index 9141a9d2a79..6a7c34b1628 100644 --- a/src/udev/udev-event.c +++ b/src/udev/udev-event.c @@ -29,6 +29,7 @@ UdevEvent* udev_event_new(sd_device *dev, UdevWorker *worker, EventMode mode) { return NULL; *event = (UdevEvent) { + .n_ref = 1, .worker = worker, .rtnl = worker ? sd_netlink_ref(worker->rtnl) : NULL, .dev = sd_device_ref(dev), @@ -44,7 +45,7 @@ UdevEvent* udev_event_new(sd_device *dev, UdevWorker *worker, EventMode mode) { return event; } -UdevEvent* udev_event_free(UdevEvent *event) { +static UdevEvent* udev_event_free(UdevEvent *event) { if (!event) return NULL; @@ -60,6 +61,8 @@ UdevEvent* udev_event_free(UdevEvent *event) { return mfree(event); } +DEFINE_TRIVIAL_REF_UNREF_FUNC(UdevEvent, udev_event, udev_event_free); + static int device_rename(sd_device *device, const char *name) { _cleanup_free_ char *new_syspath = NULL; const char *s; diff --git a/src/udev/udev-event.h b/src/udev/udev-event.h index 873e7ca421a..b1ad2bf0c2f 100644 --- a/src/udev/udev-event.h +++ b/src/udev/udev-event.h @@ -21,9 +21,10 @@ typedef struct UdevRules UdevRules; typedef struct UdevWorker UdevWorker; typedef struct UdevEvent { + unsigned n_ref; + UdevWorker *worker; sd_netlink *rtnl; - sd_device *dev; sd_device *dev_parent; sd_device *dev_db_clone; @@ -53,8 +54,9 @@ typedef struct UdevEvent { } UdevEvent; UdevEvent* udev_event_new(sd_device *dev, UdevWorker *worker, EventMode mode); -UdevEvent* udev_event_free(UdevEvent *event); -DEFINE_TRIVIAL_CLEANUP_FUNC(UdevEvent*, udev_event_free); +UdevEvent* udev_event_ref(UdevEvent *event); +UdevEvent* udev_event_unref(UdevEvent *event); +DEFINE_TRIVIAL_CLEANUP_FUNC(UdevEvent*, udev_event_unref); int udev_event_execute_rules(UdevEvent *event, UdevRules *rules); diff --git a/src/udev/udev-worker.c b/src/udev/udev-worker.c index 28cf26f1eaf..ee5831f66f9 100644 --- a/src/udev/udev-worker.c +++ b/src/udev/udev-worker.c @@ -170,7 +170,7 @@ static int worker_mark_block_device_read_only(sd_device *dev) { } static int worker_process_device(UdevWorker *worker, sd_device *dev) { - _cleanup_(udev_event_freep) UdevEvent *udev_event = NULL; + _cleanup_(udev_event_unrefp) UdevEvent *udev_event = NULL; _cleanup_close_ int fd_lock = -EBADF; int r; diff --git a/src/udev/udevadm-test-builtin.c b/src/udev/udevadm-test-builtin.c index 5815f2cc781..382897efd46 100644 --- a/src/udev/udevadm-test-builtin.c +++ b/src/udev/udevadm-test-builtin.c @@ -74,7 +74,7 @@ static int parse_argv(int argc, char *argv[]) { } int builtin_main(int argc, char *argv[], void *userdata) { - _cleanup_(udev_event_freep) UdevEvent *event = NULL; + _cleanup_(udev_event_unrefp) UdevEvent *event = NULL; _cleanup_(sd_device_unrefp) sd_device *dev = NULL; UdevBuiltinCommand cmd; int r; diff --git a/src/udev/udevadm-test.c b/src/udev/udevadm-test.c index 48714de33bc..0c2bc3438b6 100644 --- a/src/udev/udevadm-test.c +++ b/src/udev/udevadm-test.c @@ -93,7 +93,7 @@ static int parse_argv(int argc, char *argv[]) { int test_main(int argc, char *argv[], void *userdata) { _cleanup_(udev_rules_freep) UdevRules *rules = NULL; - _cleanup_(udev_event_freep) UdevEvent *event = NULL; + _cleanup_(udev_event_unrefp) UdevEvent *event = NULL; _cleanup_(sd_device_unrefp) sd_device *dev = NULL; sigset_t mask, sigmask_orig; int r;