mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 20:51:03 +02:00
locking: Introduce __cleanup() based infrastructure
Use __attribute__((__cleanup__(func))) to build: - simple auto-release pointers using __free() - 'classes' with constructor and destructor semantics for scope-based resource management. - lock guards based on the above classes. Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lkml.kernel.org/r/20230612093537.614161713%40infradead.org
This commit is contained in:
@@ -30,6 +30,7 @@
|
||||
#include <linux/device/bus.h>
|
||||
#include <linux/device/class.h>
|
||||
#include <linux/device/driver.h>
|
||||
#include <linux/cleanup.h>
|
||||
#include <asm/device.h>
|
||||
|
||||
struct device;
|
||||
@@ -899,6 +900,9 @@ void device_unregister(struct device *dev);
|
||||
void device_initialize(struct device *dev);
|
||||
int __must_check device_add(struct device *dev);
|
||||
void device_del(struct device *dev);
|
||||
|
||||
DEFINE_FREE(device_del, struct device *, if (_T) device_del(_T))
|
||||
|
||||
int device_for_each_child(struct device *dev, void *data,
|
||||
int (*fn)(struct device *dev, void *data));
|
||||
int device_for_each_child_reverse(struct device *dev, void *data,
|
||||
@@ -1066,6 +1070,9 @@ extern int (*platform_notify_remove)(struct device *dev);
|
||||
*/
|
||||
struct device *get_device(struct device *dev);
|
||||
void put_device(struct device *dev);
|
||||
|
||||
DEFINE_FREE(put_device, struct device *, if (_T) put_device(_T))
|
||||
|
||||
bool kill_device(struct device *dev);
|
||||
|
||||
#ifdef CONFIG_DEVTMPFS
|
||||
|
Reference in New Issue
Block a user