From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-yw0-f198.google.com (mail-yw0-f198.google.com [209.85.161.198]) by kanga.kvack.org (Postfix) with ESMTP id C77DC6B0005 for ; Fri, 17 Jun 2016 11:39:33 -0400 (EDT) Received: by mail-yw0-f198.google.com with SMTP id w195so199194084ywd.2 for ; Fri, 17 Jun 2016 08:39:33 -0700 (PDT) Received: from aserp1040.oracle.com (aserp1040.oracle.com. [141.146.126.69]) by mx.google.com with ESMTPS id 42si31896493qtn.132.2016.06.17.08.39.32 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 17 Jun 2016 08:39:32 -0700 (PDT) Subject: Re: [PATCH] mm: fix account pmd page to the process References: <1466076971-24609-1-git-send-email-zhongjiang@huawei.com> <20160616154214.GA12284@dhcp22.suse.cz> <20160616154324.GN6836@dhcp22.suse.cz> <71df66ac-df29-9542-bfa9-7c94f374df5b@oracle.com> <20160616163119.GP6836@dhcp22.suse.cz> <20160617122506.GC6534@node.shutemov.name> From: Mike Kravetz Message-ID: <8141c2df-5643-4ba9-42a5-5b536517cdee@oracle.com> Date: Fri, 17 Jun 2016 08:39:02 -0700 MIME-Version: 1.0 In-Reply-To: <20160617122506.GC6534@node.shutemov.name> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: "Kirill A. Shutemov" Cc: Michal Hocko , zhongjiang , akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org On 06/17/2016 05:25 AM, Kirill A. Shutemov wrote: > > From fd22922e7b4664e83653a84331f0a95b985bff0c Mon Sep 17 00:00:00 2001 > From: "Kirill A. Shutemov" > Date: Fri, 17 Jun 2016 15:07:03 +0300 > Subject: [PATCH] hugetlb: fix nr_pmds accounting with shared page tables > > We account HugeTLB's shared page table to all processes who share it. > The accounting happens during huge_pmd_share(). > > If somebody populates pud entry under us, we should decrease pagetable's > refcount and decrease nr_pmds of the process. > > By mistake, I increase nr_pmds again in this case. :-/ > It will lead to "BUG: non-zero nr_pmds on freeing mm: 2" on process' > exit. > > Let's fix this by increasing nr_pmds only when we're sure that the page > table will be used. > > Signed-off-by: Kirill A. Shutemov Nice, Reviewed-by: Mike Kravetz I agree that we do not necessarily need a back port. I have not seen reports of people experiencing this race and seeing the BUG (on mm tear-down). zhongjiang, did someone actually hit the BUG? Or, did you find it by code examination? -- Mike Kravetz > Reported-by: zhongjiang > Fixes: dc6c9a35b66b ("mm: account pmd page tables to the process") > Cc: [4.0+] > --- > mm/hugetlb.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/mm/hugetlb.c b/mm/hugetlb.c > index e197cd7080e6..ed6a537f0878 100644 > --- a/mm/hugetlb.c > +++ b/mm/hugetlb.c > @@ -4216,7 +4216,6 @@ pte_t *huge_pmd_share(struct mm_struct *mm, unsigned long addr, pud_t *pud) > if (saddr) { > spte = huge_pte_offset(svma->vm_mm, saddr); > if (spte) { > - mm_inc_nr_pmds(mm); > get_page(virt_to_page(spte)); > break; > } > @@ -4231,9 +4230,9 @@ pte_t *huge_pmd_share(struct mm_struct *mm, unsigned long addr, pud_t *pud) > if (pud_none(*pud)) { > pud_populate(mm, pud, > (pmd_t *)((unsigned long)spte & PAGE_MASK)); > + mm_inc_nr_pmds(mm); > } else { > put_page(virt_to_page(spte)); > - mm_inc_nr_pmds(mm); > } > spin_unlock(ptl); > out: > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org