[PATCH v2 4/4] watchdog: register watchdog class
Sascha Hauer
s.hauer at pengutronix.de
Mon Jun 10 22:12:37 PDT 2024
Register watchdog devices as class devices. This allows us to implement
for_each_watchdog() by iterating over the network class devices.
Signed-off-by: Sascha Hauer <s.hauer at pengutronix.de>
---
drivers/watchdog/wd_core.c | 14 ++++++++------
1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/drivers/watchdog/wd_core.c b/drivers/watchdog/wd_core.c
index 42cbd7b72c..90ae233b0f 100644
--- a/drivers/watchdog/wd_core.c
+++ b/drivers/watchdog/wd_core.c
@@ -11,7 +11,9 @@
#include <watchdog.h>
#include <restart.h>
-static LIST_HEAD(watchdog_list);
+#define for_each_watchdog(wd) list_for_each_entry(wd, &watchdog_class.devices, dev.class_list)
+
+DEFINE_DEV_CLASS(watchdog_class, "watchdog");
static const char *watchdog_name(struct watchdog *wd)
{
@@ -267,7 +269,7 @@ int watchdog_register(struct watchdog *wd)
dev_warn(&wd->dev, "failed to register restart handler\n");
}
- list_add_tail(&wd->list, &watchdog_list);
+ class_add_device(&watchdog_class, &wd->dev);
pr_debug("registering watchdog %s with priority %d\n", watchdog_name(wd),
wd->priority);
@@ -287,7 +289,7 @@ int watchdog_deregister(struct watchdog *wd)
poller_async_unregister(&wd->poller);
}
- unregister_device(&wd->dev);
+ class_remove_device(&watchdog_class, &wd->dev);
list_del(&wd->list);
return 0;
@@ -299,7 +301,7 @@ struct watchdog *watchdog_get_default(void)
struct watchdog *tmp, *wd = NULL;
int priority = 0;
- list_for_each_entry(tmp, &watchdog_list, list) {
+ for_each_watchdog(tmp) {
if (tmp->priority > priority) {
priority = tmp->priority;
wd = tmp;
@@ -336,7 +338,7 @@ struct watchdog *watchdog_get_by_name(const char *name)
if (!dev)
return NULL;
- list_for_each_entry(tmp, &watchdog_list, list) {
+ for_each_watchdog(tmp) {
if (dev == tmp->hwdev || dev == &tmp->dev)
return tmp;
}
@@ -350,7 +352,7 @@ int watchdog_inhibit_all(void)
struct watchdog *wd;
int ret = 0;
- list_for_each_entry(wd, &watchdog_list, list) {
+ for_each_watchdog(wd) {
int err;
if (!wd->priority || watchdog_hw_running(wd) == false)
continue;
--
2.39.2
More information about the barebox
mailing list