RDMA/mlx5: align MR mem allocation size to power-of-two
authorYuanyuan Zhong <yzhong@purestorage.com>
Thu, 29 Jun 2023 21:32:48 +0000 (15:32 -0600)
committerLeon Romanovsky <leon@kernel.org>
Wed, 12 Jul 2023 12:06:43 +0000 (15:06 +0300)
The MR memory allocation requests extra bytes to guarantee that there
is enough space to find the memory aligned to MLX5_UMR_ALIGN.

For power-of-two sizes, the alignment can be guaranteed by kmalloc()
according to commit 59bb47985c1d ("mm, sl[aou]b: guarantee natural
alignment for kmalloc(power-of-two)").

So if target alignment is power-of-two and adding the extra bytes
crosses a power-of-two boundary, use the next power-of-two as the
allocation size.

Signed-off-by: Yuanyuan Zhong <yzhong@purestorage.com>
Link: https://lore.kernel.org/r/20230629213248.3184245-2-yzhong@purestorage.com
Signed-off-by: Leon Romanovsky <leon@kernel.org>
drivers/infiniband/hw/mlx5/mr.c

index 2017ede100a62d793f161761fede1a73d104246f..92f35fafb2c0cf5c0b4a44929b3fe6d492b7f15f 100644 (file)
@@ -1766,6 +1766,11 @@ mlx5_alloc_priv_descs(struct ib_device *device,
        int ret;
 
        add_size = max_t(int, MLX5_UMR_ALIGN - ARCH_KMALLOC_MINALIGN, 0);
+       if (is_power_of_2(MLX5_UMR_ALIGN) && add_size) {
+               int end = max_t(int, MLX5_UMR_ALIGN, roundup_pow_of_two(size));
+
+               add_size = min_t(int, end - size, add_size);
+       }
 
        mr->descs_alloc = kzalloc(size + add_size, GFP_KERNEL);
        if (!mr->descs_alloc)