]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
cyclic: make cyclic_unregister() idempotent
authorRasmus Villemoes <ravi@prevas.dk>
Wed, 7 May 2025 10:58:19 +0000 (12:58 +0200)
committerStefan Roese <sr@denx.de>
Fri, 16 May 2025 11:44:19 +0000 (13:44 +0200)
Make cyclic_unregister() safe to call with an already unregistered, or
possibly never registered, struct cyclic_info. This is similar to how
the various timer APIs in the linux kernel work (they all allow
calling delete/cancel/... on an inactive timer object).

This means callers don't have to separately keep track of whether
their cyclic callback is registered or not, and avoids them trying to
peek into the struct cyclic_info for that information - which leads to
somewhat ugly code as it would have to be guarded by ifdef
CONFIG_CYCLIC.

Signed-off-by: Rasmus Villemoes <ravi@prevas.dk>
Reviewed-by: Stefan Roese <sr@denx.de>
common/cyclic.c

index b695f092f52aaace88995d57ce9d5a5ae18ca78e..75662d9f6138bb0fa15a40601ea98ad7524d678c 100644 (file)
@@ -28,6 +28,18 @@ struct hlist_head *cyclic_get_list(void)
        return (struct hlist_head *)&gd->cyclic_list;
 }
 
+static bool cyclic_is_registered(const struct cyclic_info *cyclic)
+{
+       const struct cyclic_info *c;
+
+       hlist_for_each_entry(c, cyclic_get_list(), list) {
+               if (c == cyclic)
+                       return true;
+       }
+
+       return false;
+}
+
 void cyclic_register(struct cyclic_info *cyclic, cyclic_func_t func,
                     uint64_t delay_us, const char *name)
 {
@@ -43,6 +55,9 @@ void cyclic_register(struct cyclic_info *cyclic, cyclic_func_t func,
 
 void cyclic_unregister(struct cyclic_info *cyclic)
 {
+       if (!cyclic_is_registered(cyclic))
+               return;
+
        hlist_del(&cyclic->list);
 }