Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp5973733ybi; Wed, 29 May 2019 00:26:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqx2I8bNGGn/9Tg0LnkxyeK/aB7Rxyvins3EysZCpYLUXJpcGlE3O0w3qsoQ2H9nMgb4ZLQi X-Received: by 2002:a65:64d9:: with SMTP id t25mr136165799pgv.130.1559114771778; Wed, 29 May 2019 00:26:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559114771; cv=none; d=google.com; s=arc-20160816; b=D48rycpWuMaYUB+bwvwbTSXSHx2IZhO2d/d393hOM16W7rDfdkZgIrrHjLqb5sRUA3 /i+C+jtFGF1TQhCisQfDEhIWBh2/sVvFMVam9F3XY+zjjKCsejKRJbndXmCz625JnD+D UC56m4Q+NlI7uu7SxkWvQPz2UM8OOYjhZrkNVk5dp/fm5FGKkCU1R2b3J7VdA1uxeAyp Md8nByt6CFL7bQ3SOxachTi+DvoV54/S4+OVXUHVitGhpLUbhzKq6bu7ioYb+0kpDYOM n+OqPXm7v5zBlQEmIUvipv/0L0hZVUZDwH4wQCt2JR5AlTzELHapsyP/6ZSfMoL6O86r j/CQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=xpHPXBq8KvHvbVOvl8VVx4rTQEIBc+yRDEo5R/DXTDM=; b=ueOeeEYuHuwHKN2ntqQW/hfnWFDaH9Qc4Fv7RcbBK01E/JF650zXyumjgyGncSOAK/ vN8dRpdYVDi7jmoX7b//tOiuexPNkPvEy3uI4BroRvGOQGyvVHFfP2OzZ0j7PD8V+WVN UF13ez6ttq/pINxD9N1asj41ZNyPAW5OOAFO7H3yMwKA6/f6HJiLnbz08zUvqLdv9qgY 4223tcbImSuftd8P32IgmJGIXBC02J/7M3KBbg5LHmf+COPVwI9HgWhrctJSTaStjtrT wwdb0rh9HnjKe0LHsILrSgjyO68jKq63w+Ed4kD++E+ZeQkiptp/pGQHiMaRyTfViJFv Omag== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=ML6xZxh0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i195si28192940pfe.20.2019.05.29.00.25.55; Wed, 29 May 2019 00:26:11 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=ML6xZxh0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726693AbfE2HYa (ORCPT + 99 others); Wed, 29 May 2019 03:24:30 -0400 Received: from mail-pf1-f194.google.com ([209.85.210.194]:46248 "EHLO mail-pf1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725894AbfE2HYa (ORCPT ); Wed, 29 May 2019 03:24:30 -0400 Received: by mail-pf1-f194.google.com with SMTP id y11so1012758pfm.13 for ; Wed, 29 May 2019 00:24:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=xpHPXBq8KvHvbVOvl8VVx4rTQEIBc+yRDEo5R/DXTDM=; b=ML6xZxh0hJe90j/v3mWzzYkO2KOVBfDxOp7EOrttZpaxNgo4v+jkI3jRGxPjOxUYsz k4iwHnLNKvBlXesx1X/1jJY006WLsz3g+q47Fld6/v+0QSazSDC5D1/my1y5oxIy9UjG nCJ3dtpF+62FL6onG4KgZa/e+vQU8Bu1MZXxqUg6X2rLeKY5D8E8mDqKzjua+yFsVEi+ ohpMrYnsqr5+HTSyR3+ESLIcZUgtcDqWRPTut2AFJmoO/x88CKkBBfGzldCg+zibW2Kw po7tc87f+I9Mp2oOBaTx8WyH7K91cz1Wk8vl4V9UdwTmdylc6FuvDYKfnWUWbPSmBkdU AI9A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=xpHPXBq8KvHvbVOvl8VVx4rTQEIBc+yRDEo5R/DXTDM=; b=NAJO/D5lr1lIu0+OIbDKfYOEJzC5E94Yjo6yW5YLLuCoRGrPibjfpY7DAFFPt9QfXi qvpDP8upBpqpg5360Vi3KSWcp/kUZ/ySPOKp2lakpRrsmE5qqgFyd1sEMVXU6hzO9Oyq Rf811m2Dto2gEfMOLA3vSg6AcbK0ho9QXKHOQIU2K6OZSvTrVkovflNdpivsv0En1FQn QxnnDRtZO2TFs6Vvdmv4BVp9mlrrICgVK2B/L5KrNkPMedZjPMJREJbZ05aG9RE4tENt 01uZilUcPV7s+qAqSS4ydRGXT+iBV0pigA0R4t2cQkkvhx0ZLbOs5NWsNheTfzl4KguU W5lQ== X-Gm-Message-State: APjAAAUKEoZZbSnj42lBuYG+BpjTM4WkSKVO/o33LSjjMrUV2YJUxCHm dOpZY6j+F+V5Gbfg0X3mDM2xqIRK X-Received: by 2002:a17:90a:9b8b:: with SMTP id g11mr10095555pjp.103.1559114669495; Wed, 29 May 2019 00:24:29 -0700 (PDT) Received: from localhost ([110.70.55.225]) by smtp.gmail.com with ESMTPSA id l8sm5093517pgb.76.2019.05.29.00.24.28 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 29 May 2019 00:24:28 -0700 (PDT) Date: Wed, 29 May 2019 16:24:24 +0900 From: Sergey Senozhatsky To: Hui Zhu Cc: minchan@kernel.org, ngupta@vflare.org, sergey.senozhatsky.work@gmail.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Andrew Morton Subject: Re: [UPSTREAM KERNEL] mm/zsmalloc.c: Add module parameter malloc_force_movable Message-ID: <20190529072424.GA29276@jagdpanzerIV> References: <20190529012230.89042-1-teawaterz@linux.alibaba.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190529012230.89042-1-teawaterz@linux.alibaba.com> User-Agent: Mutt/1.12.0 (2019-05-25) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On (05/29/19 09:22), Hui Zhu wrote: > When it enabled: > ~# echo 1 > /sys/module/zsmalloc/parameters/malloc_force_movable > ~# echo lz4 > /sys/module/zswap/parameters/compressor > ~# echo zsmalloc > /sys/module/zswap/parameters/zpool > ~# echo 1 > /sys/module/zswap/parameters/enabled > ~# swapon /swapfile [..] > * We assign a page to ZS_ALMOST_EMPTY fullness group when: > * n <= N / f, where > @@ -1479,6 +1486,9 @@ unsigned long zs_malloc(struct zs_pool *pool, size_t size, gfp_t gfp) > if (unlikely(!size || size > ZS_MAX_ALLOC_SIZE)) > return 0; > > + if (zs_malloc_force_movable) > + gfp |= __GFP_HIGHMEM | __GFP_MOVABLE; > + > handle = cache_alloc_handle(pool, gfp); > if (!handle) > return 0; It's zsmalloc user's responsibility to pass appropriate GFP mask to zs_malloc(). Take a loot at ZRAM, for instance, handle = zs_malloc(zram->mem_pool, comp_len, __GFP_KSWAPD_RECLAIM | __GFP_NOWARN | __GFP_HIGHMEM | __GFP_MOVABLE); zsmalloc should not change GFP. If zswap, for some reason, doesn't pass __GFP_MOVABLE, then I'd suggest to patch zswap. -ss