[net-next RFC PATCH 1/2] net: mdio: implement mdio_mutex_nested guard() variant

From: Christian Marangi
Date: Wed Jun 26 2024 - 19:02:51 EST


Implement mdio_mutex_nested guard() variant.

guard() compes from the cleanup.h API that define handy class to
define the lifecycle of a critical section.

Many driver makes use of the mutex_lock_nested()/mutex_unlock() hence it
might be sensible to provide a variant of the generic guard(mutex),
guard(mdio_mutex_nested) to also support drivers that use
mutex_lock_nested with MDIO_MUTEX_NESTED.

Signed-off-by: Christian Marangi <ansuelsmth@xxxxxxxxx>
---
include/linux/mdio.h | 5 +++++
1 file changed, 5 insertions(+)

diff --git a/include/linux/mdio.h b/include/linux/mdio.h
index 68f8d2e970d4..f13a02d05eb2 100644
--- a/include/linux/mdio.h
+++ b/include/linux/mdio.h
@@ -8,6 +8,8 @@

#include <uapi/linux/mdio.h>
#include <linux/bitfield.h>
+#include <linux/cleanup.h>
+#include <linux/mutex.h>
#include <linux/mod_devicetable.h>

struct gpio_desc;
@@ -25,6 +27,9 @@ enum mdio_mutex_lock_class {
MDIO_MUTEX_NESTED,
};

+DEFINE_GUARD(mdio_mutex_nested, struct mutex *,
+ mutex_lock_nested(_T, MDIO_MUTEX_NESTED), mutex_unlock(_T))
+
struct mdio_device {
struct device dev;

--
2.45.1