From 4d3f23780e5bb06268ad660c68d3fd2ff8c2a96c Mon Sep 17 00:00:00 2001 From: Lucas De Marchi Date: Sat, 30 Nov 2024 18:49:00 -0600 Subject: [PATCH] Add TAKE_PTR() Similar to macro in systemd codebase: add a macro that documents we are "leaking" a pointer that would otherwise be cleaned up by the cleanup attribute. Signed-off-by: Lucas De Marchi --- libkmod/libkmod-config.c | 12 ++++++++---- libkmod/libkmod-file-zlib.c | 6 +++--- libkmod/libkmod-module.c | 2 +- shared/util.c | 8 +++++--- shared/util.h | 7 +++++++ 5 files changed, 24 insertions(+), 11 deletions(-) diff --git a/libkmod/libkmod-config.c b/libkmod/libkmod-config.c index 648656e1..77b93929 100644 --- a/libkmod/libkmod-config.c +++ b/libkmod/libkmod-config.c @@ -146,8 +146,9 @@ static int kmod_config_add_command(struct kmod_config *config, const char *modna if (!l) return -ENOMEM; + TAKE_PTR(cmd); *list = l; - cmd = NULL; + return 0; } @@ -175,8 +176,9 @@ static int kmod_config_add_options(struct kmod_config *config, const char *modna if (!list) return -ENOMEM; - opt = NULL; + TAKE_PTR(opt); config->options = list; + return 0; } @@ -202,8 +204,9 @@ static int kmod_config_add_alias(struct kmod_config *config, const char *name, if (!list) return -ENOMEM; - alias = NULL; + TAKE_PTR(alias); config->aliases = list; + return 0; } @@ -222,8 +225,9 @@ static int kmod_config_add_blacklist(struct kmod_config *config, const char *mod if (!list) return -ENOMEM; - p = NULL; + TAKE_PTR(p); config->blacklists = list; + return 0; } diff --git a/libkmod/libkmod-file-zlib.c b/libkmod/libkmod-file-zlib.c index 54b39a8e..478a8c80 100644 --- a/libkmod/libkmod-file-zlib.c +++ b/libkmod/libkmod-file-zlib.c @@ -22,9 +22,9 @@ int kmod_file_load_zlib(struct kmod_file *file) { + _cleanup_free_ unsigned char *p = NULL; int err = 0; off_t did = 0, total = 0; - _cleanup_free_ unsigned char *p = NULL; gzFile gzf; int gzfd; @@ -68,10 +68,10 @@ int kmod_file_load_zlib(struct kmod_file *file) did += r; } - file->memory = p; + file->memory = TAKE_PTR(p); file->size = did; - p = NULL; gzclose(gzf); + return 0; error: diff --git a/libkmod/libkmod-module.c b/libkmod/libkmod-module.c index b989aa8b..0d74100c 100644 --- a/libkmod/libkmod-module.c +++ b/libkmod/libkmod-module.c @@ -648,9 +648,9 @@ static int do_finit_module(struct kmod_module *mod, unsigned int flags, const ch static int do_init_module(struct kmod_module *mod, unsigned int flags, const char *args) { + _cleanup_free_ const void *stripped = NULL; struct kmod_elf *elf; const void *mem; - _cleanup_free_ const void *stripped = NULL; off_t size; int err; diff --git a/shared/util.c b/shared/util.c index 5d05c014..81026ca3 100644 --- a/shared/util.c +++ b/shared/util.c @@ -332,11 +332,12 @@ char *freadline_wrapped(FILE *fp, unsigned int *linenum) n++; { - char *ret = buf; + char *ret = TAKE_PTR(buf); + ret[i] = '\0'; - buf = NULL; if (linenum) *linenum += n; + return ret; } @@ -390,7 +391,8 @@ char *path_make_absolute_cwd(const char *p) if (r == NULL) return NULL; - cwd = NULL; + TAKE_PTR(cwd); + r[cwdlen] = '/'; memcpy(&r[cwdlen + 1], p, plen + 1); diff --git a/shared/util.h b/shared/util.h index 58431baa..7c8bb95b 100644 --- a/shared/util.h +++ b/shared/util.h @@ -158,3 +158,10 @@ static inline bool umulsz_overflow(size_t a, size_t b, size_t *res) #error "Unknown sizeof(size_t)" #endif } + +#define TAKE_PTR(x) \ + ({ \ + typeof(x) x__ = x; \ + (x) = NULL; \ + x__; \ + })