zswap_cpu_comp_prepare() is called on a different CPU with the CPU which
will really send acomp_req. In order to use the right local compressors,
this patch specifies the NUMA node to which the CPU sending acomp_req
belongs.

Cc: Seth Jennings <sjenn...@redhat.com>
Cc: Dan Streetman <ddstr...@ieee.org>
Cc: Vitaly Wool <vitaly.w...@konsulko.com>
Cc: Herbert Xu <herb...@gondor.apana.org.au>
Cc: David S. Miller" <da...@davemloft.net>
Cc: Andrew Morton <a...@linux-foundation.org>
Signed-off-by: Barry Song <song.bao....@hisilicon.com>
---
 mm/zswap.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/mm/zswap.c b/mm/zswap.c
index 0d914ba6b4a0..9b1aa477022e 100644
--- a/mm/zswap.c
+++ b/mm/zswap.c
@@ -437,7 +437,7 @@ static int zswap_cpu_comp_prepare(unsigned int cpu, struct 
hlist_node *node)
                pr_err("Could not initialize acomp_ctx\n");
                return -ENOMEM;
        }
-       acomp = crypto_alloc_acomp(pool->tfm_name, 0, 0);
+       acomp = crypto_alloc_acomp_node(pool->tfm_name, 0, 0, cpu_to_node(cpu));
        if (IS_ERR_OR_NULL(acomp)) {
                pr_err("could not alloc crypto acomp %s : %ld\n",
                                pool->tfm_name, PTR_ERR(acomp));
-- 
2.27.0


Reply via email to