Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4773630pxu; Mon, 21 Dec 2020 23:53:34 -0800 (PST) X-Google-Smtp-Source: ABdhPJxh/tmOsMiA1RLEbDIHcPI+tGN6NxpI8Ry8JHxIBv+7i+uRJMgbU3x497cQJLv82gFBDrGh X-Received: by 2002:a17:906:cecd:: with SMTP id si13mr18527960ejb.441.1608623614383; Mon, 21 Dec 2020 23:53:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608623614; cv=none; d=google.com; s=arc-20160816; b=1Gj1+sBdxsDP0wZaZHMCrGj1xN2DNKOCZElJvaS7LIg/PE5xm/GbSoRCk537XqqB7e GEgvHfJdyStuPKVgQomKgJnBl6mi2P1q4vkBu91IbeedenZPdHN9L/dfxRxZWi7wfUgN iZesTUdVH3pF68AMo7CAwf4JThY0OcpvMnumZPQy3jYWDqlxIF0apsNKZ/Rtd446sasy Uh//7TJawHCy9zdMXxDzljjO9Lx/pA+xKbHK59kz2SdgtHQAO6piP//pTCmJsu7MxiPf W/P7y64m5JDyId9J60MdKoDhvKERi27A/G7J/ow3FwPr4dweZUVrrTLkGcbrN8GpZD7P laTw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:content-disposition:mime-version :mail-followup-to:message-id:subject:cc:to:date:from:dkim-signature; bh=EteXygXMCMIuOH65MtjowE2DhA9SwUq1uE5SG/8bUGA=; b=cWpKGrwHDtmPHWBt5S1Zmfwq8bLGW9RnWG5QysFzHhRWK4SfumL+uMryurHbjyUrqc sZ2UrVM1w+6AfZ3my7jUoujXLaRhGylgnFypFkwmFJYmUiv8W+ztldZwEc/h3k+WLMEk HwU7X7EXcIVTe3QTPvLKrW2lZl1MbrckY6jvwv0ohzFJS4e4fkA0/9P+wMu3lZ+8AduJ UKLWku2EOCJi4ERe0lRbra8TpaV1obGkIXgbQAV0dQ/logYr/IBazC1cOsAIxp2hnc4b 1H540BcALUEoirqZ1MP8AaPlZt7oRlM3yYbRk+VrmXflEBZWkou9FHTdWqasEpEeqy1U yrdg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=LGvosuLi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id ba7si11873502edb.70.2020.12.21.23.53.11; Mon, 21 Dec 2020 23:53:34 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=LGvosuLi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1726094AbgLVHt5 (ORCPT + 99 others); Tue, 22 Dec 2020 02:49:57 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34686 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725300AbgLVHt4 (ORCPT ); Tue, 22 Dec 2020 02:49:56 -0500 Received: from mail-pg1-x52a.google.com (mail-pg1-x52a.google.com [IPv6:2607:f8b0:4864:20::52a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7410FC0613D3 for ; Mon, 21 Dec 2020 23:49:16 -0800 (PST) Received: by mail-pg1-x52a.google.com with SMTP id g15so2960716pgu.9 for ; Mon, 21 Dec 2020 23:49:16 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:date:to:cc:subject:message-id:mail-followup-to:mime-version :content-disposition:user-agent; bh=EteXygXMCMIuOH65MtjowE2DhA9SwUq1uE5SG/8bUGA=; b=LGvosuLiYLgn1b5YwdnJwfvCqo3XbN555xW2S/pLyAc8CuUqtZAGHNlX5OhLPeQRO4 C9wIUC7lj+M+iU2FFT1wsEhktcwBwq76j874fWliVKllFErvCXfAAxAKVekLKJ0fPuX4 w9BPNrCcyE8RLp4U32xhMH4/yOciZ7ZmUVQsi7kvByf34AwsJf2PEPp8adJg0WcVurN9 y91b1qv/triV2c+4b/y4HigHiL/Sk+sYpuqdkd4PTNVp0q5YaDIas0IN7YMD2gFHzTrx eV/AGLh5tP8pePBFiPGWjo4RlSKftL1n+xJaqNVLxg/eXbhAbpkDrS1x2L8CHRsIt1/n D+sA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:date:to:cc:subject:message-id :mail-followup-to:mime-version:content-disposition:user-agent; bh=EteXygXMCMIuOH65MtjowE2DhA9SwUq1uE5SG/8bUGA=; b=bf9FcA2GYusaSnFzjW+AmUnsJsrULVSBRt2P+1sRmAxgSkpokoQNUph1A/fGPwBWSn KpmNCJNrhHslcTPsKKJxll3wXthJnwIOolkAhcgmscQ8z6MTKotcARQHg7ino5B/8RVT 6ECL3MJGBzgHWSeuVZg+1v9Jj+jBntHhvaxX7qtDZ+PDr9XXomfOba6Xdjf5BslfHU4l 3S3MBdnpuqVqI8MAaX6pgYu+7fr9WQWCRBquZh+HLlVw58k7nQYNF73cvf2XhxQJt/98 71f8ja65AxjWVYJTfMkM0yzA41TrT5ArvbDNQg4Dzj53v4UPD7nej8Rkd7VbQImDbbOO GBpw== X-Gm-Message-State: AOAM532ahgfY2D8CBOnpfjiOmnOBdqMC56f4SE69V8TqDWTIJ1T80pC9 +8ksyNy6qFOYMhbeybyjLFs= X-Received: by 2002:a63:445a:: with SMTP id t26mr18659351pgk.402.1608623356116; Mon, 21 Dec 2020 23:49:16 -0800 (PST) Received: from open-light-1.localdomain (66.98.113.28.16clouds.com. [66.98.113.28]) by smtp.gmail.com with ESMTPSA id b189sm19198904pfb.194.2020.12.21.23.49.14 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Mon, 21 Dec 2020 23:49:15 -0800 (PST) From: Liang Li X-Google-Original-From: Liang Li Date: Tue, 22 Dec 2020 02:49:13 -0500 To: Alexander Duyck , Mel Gorman , Andrew Morton , Andrea Arcangeli , Dan Williams , "Michael S. Tsirkin" , David Hildenbrand , Jason Wang , Dave Hansen , Michal Hocko , Liang Li , Mike Kravetz , Liang Li Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, virtualization@lists.linux-foundation.org, qemu-devel@nongnu.org Subject: [RFC PATCH 3/3] mm: support free hugepage pre zero out Message-ID: <20201222074910.GA30051@open-light-1.localdomain> Mail-Followup-To: Alexander Duyck , Mel Gorman , Andrew Morton , Andrea Arcangeli , Dan Williams , "Michael S. Tsirkin" , David Hildenbrand , Jason Wang , Dave Hansen , Michal Hocko , Liang Li , Mike Kravetz , Liang Li , linux-mm@kvack.org, linux-kernel@vger.kernel.org, virtualization@lists.linux-foundation.org, qemu-devel@nongnu.org MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.21 (2010-09-15) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch add support of pre zero out free hugepage, we can use this feature to speed up page population and page fault handing. Cc: Alexander Duyck Cc: Mel Gorman Cc: Andrea Arcangeli Cc: Dan Williams Cc: Dave Hansen Cc: David Hildenbrand Cc: Michal Hocko Cc: Andrew Morton Cc: Alex Williamson Cc: Michael S. Tsirkin Cc: Jason Wang Cc: Mike Kravetz Cc: Liang Li Signed-off-by: Liang Li --- mm/page_prezero.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/mm/page_prezero.c b/mm/page_prezero.c index c8ce720bfc54..dff4e0adf402 100644 --- a/mm/page_prezero.c +++ b/mm/page_prezero.c @@ -26,6 +26,7 @@ static unsigned long delay_millisecs = 1000; static unsigned long zeropage_enable __read_mostly; static DEFINE_MUTEX(kzeropaged_mutex); static struct page_reporting_dev_info zero_page_dev_info; +static struct page_reporting_dev_info zero_hugepage_dev_info; inline void clear_zero_page_flag(struct page *page, int order) { @@ -69,9 +70,17 @@ static int start_kzeropaged(void) zero_page_dev_info.delay_jiffies = msecs_to_jiffies(delay_millisecs); err = page_reporting_register(&zero_page_dev_info); + + zero_hugepage_dev_info.report = zero_free_pages; + zero_hugepage_dev_info.mini_order = mini_page_order; + zero_hugepage_dev_info.batch_size = batch_size; + zero_hugepage_dev_info.delay_jiffies = msecs_to_jiffies(delay_millisecs); + + err |= hugepage_reporting_register(&zero_hugepage_dev_info); pr_info("Zero page enabled\n"); } else { page_reporting_unregister(&zero_page_dev_info); + hugepage_reporting_unregister(&zero_hugepage_dev_info); pr_info("Zero page disabled\n"); } @@ -90,7 +99,15 @@ static int restart_kzeropaged(void) zero_page_dev_info.batch_size = batch_size; zero_page_dev_info.delay_jiffies = msecs_to_jiffies(delay_millisecs); + hugepage_reporting_unregister(&zero_hugepage_dev_info); + + zero_hugepage_dev_info.report = zero_free_pages; + zero_hugepage_dev_info.mini_order = mini_page_order; + zero_hugepage_dev_info.batch_size = batch_size; + zero_hugepage_dev_info.delay_jiffies = msecs_to_jiffies(delay_millisecs); + err = page_reporting_register(&zero_page_dev_info); + err |= hugepage_reporting_register(&zero_hugepage_dev_info); pr_info("Zero page enabled\n"); } -- 2.18.2