]> www.infradead.org Git - linux.git/commitdiff
bcachefs: darray: convert to alloc_hooks()
authorKent Overstreet <kent.overstreet@linux.dev>
Thu, 22 Aug 2024 07:50:22 +0000 (03:50 -0400)
committerKent Overstreet <kent.overstreet@linux.dev>
Mon, 9 Sep 2024 13:41:49 +0000 (09:41 -0400)
better memory allocation profiling support

Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/darray.c
fs/bcachefs/darray.h

index b7d223f85873e2e8e5c2d1b0969f28dc5c06d1ff..4f06cd8bbbe15be2bb68d7c2187eea3eef5d8720 100644 (file)
@@ -4,12 +4,12 @@
 #include <linux/slab.h>
 #include "darray.h"
 
-int __bch2_darray_resize(darray_char *d, size_t element_size, size_t new_size, gfp_t gfp)
+int __bch2_darray_resize_noprof(darray_char *d, size_t element_size, size_t new_size, gfp_t gfp)
 {
        if (new_size > d->size) {
                new_size = roundup_pow_of_two(new_size);
 
-               void *data = kvmalloc_array(new_size, element_size, gfp);
+               void *data = kvmalloc_array_noprof(new_size, element_size, gfp);
                if (!data)
                        return -ENOMEM;
 
index 4b340d13caace03b12f75e788316ad5af7e08d1c..8f4c3f0665c451b7c31aa8aa83ef39332f260470 100644 (file)
@@ -22,29 +22,23 @@ struct {                                                            \
 typedef DARRAY(char)   darray_char;
 typedef DARRAY(char *) darray_str;
 
-int __bch2_darray_resize(darray_char *, size_t, size_t, gfp_t);
-
-static inline int __darray_resize(darray_char *d, size_t element_size,
-                                 size_t new_size, gfp_t gfp)
-{
-       return unlikely(new_size > d->size)
-               ? __bch2_darray_resize(d, element_size, new_size, gfp)
-               : 0;
-}
+int __bch2_darray_resize_noprof(darray_char *, size_t, size_t, gfp_t);
+
+#define __bch2_darray_resize(...)      alloc_hooks(__bch2_darray_resize_noprof(__VA_ARGS__))
+
+#define __darray_resize(_d, _element_size, _new_size, _gfp)            \
+       (unlikely((_new_size) > (_d)->size)                             \
+        ? __bch2_darray_resize((_d), (_element_size), (_new_size), (_gfp))\
+        : 0)
 
 #define darray_resize_gfp(_d, _new_size, _gfp)                         \
-       unlikely(__darray_resize((darray_char *) (_d), sizeof((_d)->data[0]), (_new_size), _gfp))
+       __darray_resize((darray_char *) (_d), sizeof((_d)->data[0]), (_new_size), _gfp)
 
 #define darray_resize(_d, _new_size)                                   \
        darray_resize_gfp(_d, _new_size, GFP_KERNEL)
 
-static inline int __darray_make_room(darray_char *d, size_t t_size, size_t more, gfp_t gfp)
-{
-       return __darray_resize(d, t_size, d->nr + more, gfp);
-}
-
 #define darray_make_room_gfp(_d, _more, _gfp)                          \
-       __darray_make_room((darray_char *) (_d), sizeof((_d)->data[0]), (_more), _gfp)
+       darray_resize_gfp((_d), (_d)->nr + (_more), _gfp)
 
 #define darray_make_room(_d, _more)                                    \
        darray_make_room_gfp(_d, _more, GFP_KERNEL)