Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1384897ybl; Thu, 22 Aug 2019 13:42:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqxDkLBQRWerQFLEeZpEN69AB+DE4kVy1DmArcy+5TvULCHzVLTkH97I+wbOwMeODo9rANwA X-Received: by 2002:a17:902:547:: with SMTP id 65mr741451plf.131.1566506574673; Thu, 22 Aug 2019 13:42:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566506574; cv=none; d=google.com; s=arc-20160816; b=LvuXUXZJpzxm0AZNggoNzn7IicXlK+Y0T7dQE2LqMNgitFkvBfznL3TZsJZXKIhayk x9y4XZTfIZMJ5Xr25GG9BoLeKcCDNvgdWyIuDXOT1qeO/0ZhEC2USEmHxL+v+CvbllJ5 TjNcs1Ov+lH1x1rD3i85vwyR3XkIZeQlRlV1TcEFVOvKiDOk0MverzSuX5M1amkau1vN Efb1gsy2fNfRBySD9begzwiHzMPjvSAx/QxP250nmx4fs9Yb7HO17LKK7wd29++5aFM6 Rzrnb2SKlh/WyQeCaoR1Bz4C6XMR4nVO/CFpOfmxmMtreaIzYgssu8CfxRnuKCIYan2K XtHw== 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=DJ/eC3LGuOL6//+DGNThc9YJfZBuiT1PO54o1KGcu30=; b=q1Ct6viyBTY+ZbKJHDQy48FrmKSlf7qjSRdkoNY/ivpxoXpaz9VXr9/KUyOCywdzU1 4HvghN0jk21qhydceHEg7KKaMqGzhJS3/Q2F4gBb5v9HpX0Y2xQoIowpJtZcEjSPOc0k m9REHdSYPrVB/PMyZC16T0b6L1s2CH4VPu/eM0xhQ6Jqe+oc+K0PSBVL0L3eKg2xtf7K U0ZSOrFh33AlUwxzuqa57MVmliotDjmnoZaQ0afkmoqE6H1XZq/hL2u/626Z73diB9FL cNxnHAXY3sTdk2WYSnvoSRbUjqzIcBcGYBE2m6Ac77yepHjrNhNaVGNsQwkZIekmlmMk DeSg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@shutemov-name.20150623.gappssmtp.com header.s=20150623 header.b=L8WPD7dT; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v45si314657pgn.10.2019.08.22.13.42.39; Thu, 22 Aug 2019 13:42:54 -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=@shutemov-name.20150623.gappssmtp.com header.s=20150623 header.b=L8WPD7dT; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389465AbfHVPtR (ORCPT + 99 others); Thu, 22 Aug 2019 11:49:17 -0400 Received: from mail-ed1-f68.google.com ([209.85.208.68]:38560 "EHLO mail-ed1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726387AbfHVPtR (ORCPT ); Thu, 22 Aug 2019 11:49:17 -0400 Received: by mail-ed1-f68.google.com with SMTP id r12so8610882edo.5 for ; Thu, 22 Aug 2019 08:49:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=shutemov-name.20150623.gappssmtp.com; s=20150623; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=DJ/eC3LGuOL6//+DGNThc9YJfZBuiT1PO54o1KGcu30=; b=L8WPD7dTrU3n/Wq91GZgxnLyJoEfJzls7dAI7jRFPS2OQUmzaI3fJOHoWKcsrFZaVP RvSdHC7FZ1z0sOk8IdvvB29K2NqNten9KEG0gvLCmSqtQFfFJ5uMgD4v43b36IcAv9bX KTtYiU4ADpMXlaL5IafhA5DT+coI1u60NzoVzh5Rw8mz0K07RDv2bxZ/AeulQBVIFehw kEYLsFZGGD1vqAftG2zGF3XUbDDqHOCP29WxaNddvB8HHtjCJm1SU7vcdk5mJlPG0h9V x9uHHr9bupiR3K6DrnD2mLXjtMpcO3ASDogaK2ABY0czTEVx4Z8FVuvhwL6Xr5eg/0q4 gRHw== 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=DJ/eC3LGuOL6//+DGNThc9YJfZBuiT1PO54o1KGcu30=; b=ZU5PMRhGYBoyBYIVZvUWgNMM9Uh6dPxtYEtmb9K5EmdJQ6mKDkzFd7riayFsNt1fu/ YQ9UcWK3ktuavCcCI7ypf6Ck+up4ldIh7grAKddN2JMP16bVPQG5jEkME7GLlzsCjuvZ 808cYwTHqXzcsTzO7XEaEj/c9a2wVMy56NCaCXTATtO8PFtKlnk+kgnYWwnPgUSXukod 2NIgSG2zCKZ7yyOjuecLzMjqR3UBk4217fj946xymq26AT3SmETKI7pQIHZd8CYH6arS FIJRNdtRQk2EhmNKvcw1FETpmtYM/1+L6kLI6Ry0py2IgE8UkbFrZn1+q01UoACXLtlV DphA== X-Gm-Message-State: APjAAAU5ly7Llqh9OlQPS+VEEB0cItYrxdvVVfo7Xs1CNY6r9lOGzCrV ZjAj+TEWvFRBbq+4UkEvZFsh2g== X-Received: by 2002:a05:6402:50a:: with SMTP id m10mr21388362edv.173.1566488955883; Thu, 22 Aug 2019 08:49:15 -0700 (PDT) Received: from box.localdomain ([86.57.175.117]) by smtp.gmail.com with ESMTPSA id p20sm3710384eja.59.2019.08.22.08.49.15 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 22 Aug 2019 08:49:15 -0700 (PDT) Received: by box.localdomain (Postfix, from userid 1000) id 7225D100853; Thu, 22 Aug 2019 18:49:14 +0300 (+03) Date: Thu, 22 Aug 2019 18:49:14 +0300 From: "Kirill A. Shutemov" To: Vlastimil Babka Cc: Michal Hocko , kirill.shutemov@linux.intel.com, Yang Shi , hannes@cmpxchg.org, rientjes@google.com, akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [v2 PATCH -mm] mm: account deferred split THPs into MemAvailable Message-ID: <20190822154914.gb5clks2tzziobfx@box> References: <1566410125-66011-1-git-send-email-yang.shi@linux.alibaba.com> <20190822080434.GF12785@dhcp22.suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Aug 22, 2019 at 02:56:56PM +0200, Vlastimil Babka wrote: > >> @@ -2816,11 +2821,14 @@ void free_transhuge_page(struct page *page) > >> ds_queue->split_queue_len--; > >> list_del(page_deferred_list(page)); > >> } > >> + __mod_node_page_state(page_pgdat(page), NR_KERNEL_MISC_RECLAIMABLE, > >> + -page[2].nr_freeable); > >> + page[2].nr_freeable = 0; > > Wouldn't it be safer to fully tie the nr_freeable use to adding the page to the > deffered list? So here the code would be in the if (!list_empty()) { } part above. > > >> spin_unlock_irqrestore(&ds_queue->split_queue_lock, flags); > >> free_compound_page(page); > >> } > >> > >> -void deferred_split_huge_page(struct page *page) > >> +void deferred_split_huge_page(struct page *page, unsigned int nr) > >> { > >> struct deferred_split *ds_queue = get_deferred_split_queue(page); > >> #ifdef CONFIG_MEMCG > >> @@ -2844,6 +2852,9 @@ void deferred_split_huge_page(struct page *page) > >> return; > >> > >> spin_lock_irqsave(&ds_queue->split_queue_lock, flags); > >> + page[2].nr_freeable += nr; > >> + __mod_node_page_state(page_pgdat(page), NR_KERNEL_MISC_RECLAIMABLE, > >> + nr); > > Same here, only do this when adding to the list, below? Or we might perhaps > account base pages multiple times? No, it cannot be under list_empty() check. Consider the case when a THP got unmapped 4k a time. You need to put it on the list once, but account it every time. -- Kirill A. Shutemov