From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-ed1-f70.google.com (mail-ed1-f70.google.com [209.85.208.70]) by kanga.kvack.org (Postfix) with ESMTP id A56FB8E0041 for ; Mon, 24 Sep 2018 15:56:06 -0400 (EDT) Received: by mail-ed1-f70.google.com with SMTP id d28-v6so3492360edb.17 for ; Mon, 24 Sep 2018 12:56:06 -0700 (PDT) Received: from mx1.suse.de (mx2.suse.de. [195.135.220.15]) by mx.google.com with ESMTPS id b17-v6si10716985edr.54.2018.09.24.12.56.05 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 24 Sep 2018 12:56:05 -0700 (PDT) Date: Mon, 24 Sep 2018 21:56:03 +0200 From: Michal Hocko Subject: Re: [patch v2] mm, thp: always specify ineligible vmas as nh in smaps Message-ID: <20180924195603.GJ18685@dhcp22.suse.cz> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: owner-linux-mm@kvack.org List-ID: To: David Rientjes Cc: Andrew Morton , Vlastimil Babka , Alexey Dobriyan , "Kirill A. Shutemov" , linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-api@vger.kernel.org On Mon 24-09-18 12:30:07, David Rientjes wrote: > Commit 1860033237d4 ("mm: make PR_SET_THP_DISABLE immediately active") > introduced a regression in that userspace cannot always determine the set > of vmas where thp is ineligible. > > Userspace relies on the "nh" flag being emitted as part of /proc/pid/smaps > to determine if a vma is eligible to be backed by hugepages. I was under impression that nh resp hg flags only tell about the madvise status. How do you exactly use these flags in an application? Your eligible rules as defined here: > + [*] A process mapping is eligible to be backed by transparent hugepages (thp) > + depending on system-wide settings and the mapping itself. See > + Documentation/admin-guide/mm/transhuge.rst for default behavior. If a > + mapping has a flag of "nh", it is not eligible to be backed by hugepages > + in any condition, either because of prctl(PR_SET_THP_DISABLE) or > + madvise(MADV_NOHUGEPAGE). PR_SET_THP_DISABLE takes precedence over any > + MADV_HUGEPAGE. doesn't seem to match the reality. I do not see all the file backed mappings to be nh marked. So is this really about eligibility rather than the madvise status? Maybe it is just the above documentation that needs to be updated. That being said, I do not object to the patch, I am just trying to understand what is the intended usage for the flag that does try to say more than the madvise status. -- Michal Hocko SUSE Labs