Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp31591617rwd; Fri, 7 Jul 2023 01:21:26 -0700 (PDT) X-Google-Smtp-Source: APBJJlFW2238pKsXK6XnS6Q7yyyMWZAhNh9CjjwmtesLYaG740Je6yag0DCTCBLgUztXSns1EhUy X-Received: by 2002:a05:6a00:39a2:b0:666:66c0:fd5b with SMTP id fi34-20020a056a0039a200b0066666c0fd5bmr3984142pfb.18.1688718085682; Fri, 07 Jul 2023 01:21:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688718085; cv=none; d=google.com; s=arc-20160816; b=vR/zIh5Qv9YYLqEQlEbNklohIHG8A91WheT/Wl+RaWplxvxDAHCKPvZCMoTJkkpbO7 Fboqfh85NoxZGzfiY81ioZFgjkC/58a0t1DaaY00yfsjuPzwcPIrs91NHLLvTVwGsUhA MNEL8SKCqoPyR178SAUPnwZtquIlVIG/omjC0cScAFs/q1ooek+eYICOrUY6cMfMD4Q1 C4wrijKl0KTeQgBXXlX534hNp6DXx4tA0UW2DdG0t/2ftmQTv8oBwoGKR9so7Q+mf+hF BmdhHoSO6aeRZxyGpuC9djHV6pmTGlFozS4dPEjDfyclo13HFeFJIOd1Afdp3LsD29Te DIbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:message-id:in-reply-to :date:references:subject:cc:to:from:dkim-signature; bh=QHg2i/aOKzwmpPwZ8Fbtm8Hftg79By65Z4iSUddNHek=; fh=tMM1Mr0cXCt2NE7jtEGNwNrF1Fw5ySqzqxbAPeu1oQA=; b=mJIwQ/HU1xPgz3yhmNEo3kOvzf/i1eRXq541kIaEjUOuZbKjapR/VTYlG0t1er51ny sstmkskbLVVTJjqvgqQINztSlaJb/BWupzbx+xEeIjuNj9WZou+GfsKoAXZVawk/6qmC ofMEi6xdricCHQwdHbyv8+23Z+l9UhhJKI0LSfw5Jmv6CNXpDZshRhBj1zw+ifQELLdX 4q1xR9GN2RMT9R++4fMCMMCvJfilPUWqtxHiANNn/mX81ufd93fkugawF0UUxWWj3gjN BuC78A6CEgrhP2Tas1JkdMlT5YNUi3D6ZslrwmG8uTR2IXTaZCGfl3DfM++4G5SJ87q9 6pag== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="On/TLSeI"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y19-20020aa78553000000b0068208d19b23si3079160pfn.311.2023.07.07.01.21.14; Fri, 07 Jul 2023 01:21:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="On/TLSeI"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232799AbjGGIDl (ORCPT + 99 others); Fri, 7 Jul 2023 04:03:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46114 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232290AbjGGIDj (ORCPT ); Fri, 7 Jul 2023 04:03:39 -0400 Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 24C64171D for ; Fri, 7 Jul 2023 01:03:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1688717019; x=1720253019; h=from:to:cc:subject:references:date:in-reply-to: message-id:mime-version; bh=zeZySM/P+hW8gCRTMIgHwOEaGeKA9fS+25kTtwVY72I=; b=On/TLSeISB6HYNRY+ayDvvRHmodI6OYmC/iZzrpMexgcVYjWAaWqMXyF byDGTTCtQ20maieLF605oB04T6sI8lvOb6n0GV0JG+PUcqxcsPruEDyg/ GBRwFVJa6IM3aYkDmPmeM4nWFuic24I2BF7UN9vO9kc4QcMyl+A9N3CSq Xvl92phyRhMAXaZY2fcPPx4OH3ZTGsJudeGHcOJmTJMZk5Y6hHaUvA5VS jt+uDEUhrqpytK7R2r3gU5OxRQkJd6BvF/VxYoVbCwoT7OX6Jy503GZEf LxSkITpnoUakU+fiU0vj8oyS/OcdPKE6DiS8xzg4OEC/10aYRNgMnL+S+ w==; X-IronPort-AV: E=McAfee;i="6600,9927,10763"; a="362700206" X-IronPort-AV: E=Sophos;i="6.01,187,1684825200"; d="scan'208";a="362700206" Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Jul 2023 01:03:38 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10763"; a="966555855" X-IronPort-AV: E=Sophos;i="6.01,187,1684825200"; d="scan'208";a="966555855" Received: from yhuang6-desk2.sh.intel.com (HELO yhuang6-desk2.ccr.corp.intel.com) ([10.238.208.55]) by fmsmga006-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Jul 2023 01:03:35 -0700 From: "Huang, Ying" To: Ryan Roberts Cc: Andrew Morton , Matthew Wilcox , "Kirill A. Shutemov" , Yin Fengwei , David Hildenbrand , Yu Zhao , Catalin Marinas , Will Deacon , Anshuman Khandual , Yang Shi , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [PATCH v2 4/5] mm: FLEXIBLE_THP for improved performance References: <20230703135330.1865927-1-ryan.roberts@arm.com> <20230703135330.1865927-5-ryan.roberts@arm.com> Date: Fri, 07 Jul 2023 16:01:45 +0800 In-Reply-To: <20230703135330.1865927-5-ryan.roberts@arm.com> (Ryan Roberts's message of "Mon, 3 Jul 2023 14:53:29 +0100") Message-ID: <87edlkgnfa.fsf@yhuang6-desk2.ccr.corp.intel.com> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/28.2 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=ascii X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Ryan Roberts writes: > Introduce FLEXIBLE_THP feature, which allows anonymous memory to be > allocated in large folios of a specified order. All pages of the large > folio are pte-mapped during the same page fault, significantly reducing > the number of page faults. The number of per-page operations (e.g. ref > counting, rmap management lru list management) are also significantly > reduced since those ops now become per-folio. I likes the idea to share as much code as possible between large (anonymous) folio and THP. Finally, THP becomes just a special kind of large folio. Although we can use smaller page order for FLEXIBLE_THP, it's hard to avoid internal fragmentation completely. So, I think that finally we will need to provide a mechanism for the users to opt out, e.g., something like "always madvise never" via /sys/kernel/mm/transparent_hugepage/enabled. I'm not sure whether it's a good idea to reuse the existing interface of THP. Best Regards, Huang, Ying