Re: [PATCH 07/12] staging: lustre: libcfs: simplify memory allocation.

From: NeilBrown
Date: Wed Dec 13 2017 - 19:01:14 EST


On Wed, Dec 13 2017, NeilBrown wrote:

> 1/ Use kvmalloc() instead of kmalloc or vmalloc
> 2/ Discard the _GFP() interfaces that are never used.
> We only ever do GFP_NOFS and GFP_ATOMIC allocations,
> so support each of those explicitly.

Hi,
I just remembered that posting this patch was, maybe, a little premature.
vmalloc() doesn't support GFP_NOFS, so kvmalloc() warns about an attempt
to use GFP_NOFS.
lustre potentially used vmalloc in GFP_NOFS context, and so now calls
kvmalloc() with GFP_NOFS, which triggers a warning.

I haven't yet looking into how to remove the warning. Maybe all
GFP_NOFS usages should use kmalloc(), not kvmalloc(), and accept the
increased chance of failure.
I'll dig deeper and hope to have a clearer opinion soon.

As it is only a warning, it is probably OK to keep the patch in
staging-next, but I wouldn't object if it was dropped.

Thanks,
NeilBrown



>
> Signed-off-by: NeilBrown <neilb@xxxxxxxx>
> ---
> .../lustre/include/linux/libcfs/libcfs_private.h | 42 ++++++--------------
> 1 file changed, 12 insertions(+), 30 deletions(-)
>
> diff --git a/drivers/staging/lustre/include/linux/libcfs/libcfs_private.h b/drivers/staging/lustre/include/linux/libcfs/libcfs_private.h
> index 2f4ff595fac9..c874f9d15c72 100644
> --- a/drivers/staging/lustre/include/linux/libcfs/libcfs_private.h
> +++ b/drivers/staging/lustre/include/linux/libcfs/libcfs_private.h
> @@ -84,14 +84,6 @@ do { \
> lbug_with_loc(&msgdata); \
> } while (0)
>
> -#ifndef LIBCFS_VMALLOC_SIZE
> -#define LIBCFS_VMALLOC_SIZE (2 << PAGE_SHIFT) /* 2 pages */
> -#endif
> -
> -#define LIBCFS_ALLOC_PRE(size, mask) \
> - LASSERT(!in_interrupt() || ((size) <= LIBCFS_VMALLOC_SIZE && \
> - !gfpflags_allow_blocking(mask)))
> -
> #define LIBCFS_ALLOC_POST(ptr, size) \
> do { \
> if (unlikely(!(ptr))) { \
> @@ -103,46 +95,36 @@ do { \
> } while (0)
>
> /**
> - * allocate memory with GFP flags @mask
> + * default allocator
> */
> -#define LIBCFS_ALLOC_GFP(ptr, size, mask) \
> +#define LIBCFS_ALLOC(ptr, size) \
> do { \
> - LIBCFS_ALLOC_PRE((size), (mask)); \
> - (ptr) = (size) <= LIBCFS_VMALLOC_SIZE ? \
> - kmalloc((size), (mask)) : vmalloc(size); \
> + LASSERT(!in_interrupt()); \
> + (ptr) = kvmalloc((size), GFP_NOFS); \
> LIBCFS_ALLOC_POST((ptr), (size)); \
> } while (0)
>
> -/**
> - * default allocator
> - */
> -#define LIBCFS_ALLOC(ptr, size) \
> - LIBCFS_ALLOC_GFP(ptr, size, GFP_NOFS)
> -
> /**
> * non-sleeping allocator
> */
> -#define LIBCFS_ALLOC_ATOMIC(ptr, size) \
> - LIBCFS_ALLOC_GFP(ptr, size, GFP_ATOMIC)
> +#define LIBCFS_ALLOC_ATOMIC(ptr, size) \
> +do { \
> + (ptr) = kmalloc((size), GFP_ATOMIC); \
> + LIBCFS_ALLOC_POST(ptr, size); \
> +} while (0)
>
> /**
> * allocate memory for specified CPU partition
> * \a cptab != NULL, \a cpt is CPU partition id of \a cptab
> * \a cptab == NULL, \a cpt is HW NUMA node id
> */
> -#define LIBCFS_CPT_ALLOC_GFP(ptr, cptab, cpt, size, mask) \
> +#define LIBCFS_CPT_ALLOC(ptr, cptab, cpt, size) \
> do { \
> - LIBCFS_ALLOC_PRE((size), (mask)); \
> - (ptr) = (size) <= LIBCFS_VMALLOC_SIZE ? \
> - kmalloc_node((size), (mask), cfs_cpt_spread_node(cptab, cpt)) :\
> - vmalloc_node(size, cfs_cpt_spread_node(cptab, cpt)); \
> + LASSERT(!in_interrupt()); \
> + (ptr) = kvmalloc_node((size), GFP_NOFS, cfs_cpt_spread_node(cptab, cpt)); \
> LIBCFS_ALLOC_POST((ptr), (size)); \
> } while (0)
>
> -/** default numa allocator */
> -#define LIBCFS_CPT_ALLOC(ptr, cptab, cpt, size) \
> - LIBCFS_CPT_ALLOC_GFP(ptr, cptab, cpt, size, GFP_NOFS)
> -
> #define LIBCFS_FREE(ptr, size) \
> do { \
> if (unlikely(!(ptr))) { \

Attachment: signature.asc
Description: PGP signature