linux-watchdog.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH -next v2 1/2] watchdog: Clean up error handlings of __watchdog_register_device
@ 2020-11-03  6:52 Wang Wensheng
  2020-11-03  6:52 ` [PATCH -next v2 2/2] watchdog: Fix potential dereferencing of null pointer Wang Wensheng
  2020-11-03  7:05 ` [PATCH -next v2 1/2] watchdog: Clean up error handlings of __watchdog_register_device Christophe Leroy
  0 siblings, 2 replies; 4+ messages in thread
From: Wang Wensheng @ 2020-11-03  6:52 UTC (permalink / raw)
  To: wim, linux, linux-watchdog, linux-kernel; +Cc: rui.xiang, guohanjun

Signed-off-by: Wang Wensheng <wangwensheng4@huawei.com>
---
 drivers/watchdog/watchdog_core.c | 17 ++++++++++-------
 1 file changed, 10 insertions(+), 7 deletions(-)

diff --git a/drivers/watchdog/watchdog_core.c b/drivers/watchdog/watchdog_core.c
index 423844757812..c73871f41142 100644
--- a/drivers/watchdog/watchdog_core.c
+++ b/drivers/watchdog/watchdog_core.c
@@ -252,10 +252,8 @@ static int __watchdog_register_device(struct watchdog_device *wdd)
 		wdd->id = id;
 
 		ret = watchdog_dev_register(wdd);
-		if (ret) {
-			ida_simple_remove(&watchdog_ida, id);
-			return ret;
-		}
+		if (ret)
+			goto id_remove;
 	}
 
 	/* Module parameter to force watchdog policy on reboot. */
@@ -273,9 +271,7 @@ static int __watchdog_register_device(struct watchdog_device *wdd)
 		if (ret) {
 			pr_err("watchdog%d: Cannot register reboot notifier (%d)\n",
 			       wdd->id, ret);
-			watchdog_dev_unregister(wdd);
-			ida_simple_remove(&watchdog_ida, id);
-			return ret;
+			goto dev_unregister;
 		}
 	}
 
@@ -289,6 +285,13 @@ static int __watchdog_register_device(struct watchdog_device *wdd)
 	}
 
 	return 0;
+
+dev_unregister:
+	watchdog_dev_unregister(wdd);
+id_remove:
+	ida_simple_remove(&watchdog_ida, id);
+
+	return ret;
 }
 
 /**
-- 
2.25.0


^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2020-11-03 13:05 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-11-03  6:52 [PATCH -next v2 1/2] watchdog: Clean up error handlings of __watchdog_register_device Wang Wensheng
2020-11-03  6:52 ` [PATCH -next v2 2/2] watchdog: Fix potential dereferencing of null pointer Wang Wensheng
2020-11-03  7:05 ` [PATCH -next v2 1/2] watchdog: Clean up error handlings of __watchdog_register_device Christophe Leroy
2020-11-03 13:05   ` Guenter Roeck

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).