From: Michal Hocko <mhocko@kernel.org> To: Mike Rapoport <rppt@linux.ibm.com>, Andrew Morton <akpm@linux-foundation.org> Cc: Paul Oppenheimer <bepvte@gmail.com>, Vlastimil Babka <vbabka@suse.cz>, David Rientjes <rientjes@google.com>, Jan Kara <jack@suse.cz>, linux-mm@kvack.org, LKML <linux-kernel@vger.kernel.org> Subject: Re: Bug with report THP eligibility for each vma Date: Mon, 24 Dec 2018 19:51:06 +0100 [thread overview] Message-ID: <20181224185106.GC16738@dhcp22.suse.cz> (raw) In-Reply-To: <20181224121250.GA2070@rapoport-lnx> On Mon 24-12-18 14:12:51, Mike Rapoport wrote: > On Mon, Dec 24, 2018 at 08:49:16AM +0100, Michal Hocko wrote: > > [Cc-ing mailing list and people involved in the original patch] > > > > On Fri 21-12-18 13:42:24, Paul Oppenheimer wrote: > > > Hello! I've never reported a kernel bug before, and since its on the > > > "next" tree I was told to email the author of the relevant commit. > > > Please redirect me to the correct place if I've made a mistake. > > > > > > When opening firefox or chrome, and using it for a good 7 seconds, it > > > hangs in "uninterruptible sleep" and I recieve a "BUG" in dmesg. This > > > doesn't occur when reverting this commit: > > > https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=48cf516f8c. > > > Ive attached the output of decode_stacktrace.sh and the relevant dmesg > > > log to this email. > > > > > > Thanks > > > > > BUG: unable to handle kernel NULL pointer dereference at 00000000000000e8 > > > > Thanks for the bug report! This is offset 232 and that matches > > file->f_mapping as per pahole > > pahole -C file ./vmlinux | grep f_mapping > > struct address_space * f_mapping; /* 232 8 */ > > > > I thought that each file really has to have a mapping. But the following > > should heal the issue and add an extra care. > > > > diff --git a/mm/huge_memory.c b/mm/huge_memory.c > > index f64733c23067..fc9d70a9fbd1 100644 > > --- a/mm/huge_memory.c > > +++ b/mm/huge_memory.c > > @@ -66,6 +66,8 @@ bool transparent_hugepage_enabled(struct vm_area_struct *vma) > > { > > if (vma_is_anonymous(vma)) > > return __transparent_hugepage_enabled(vma); > > + if (!vma->vm_file || !vma->vm_file->f_mapping) > > + return false; > > if (shmem_mapping(vma->vm_file->f_mapping) && shmem_huge_enabled(vma)) > > return __transparent_hugepage_enabled(vma); > > We have vma_is_shmem(), it can be used to replace shmem_mapping() without > adding the check for !vma->vm_file Yes, this looks like a much better choice. Thanks! Andrew, could you fold this in instead. diff --git a/mm/huge_memory.c b/mm/huge_memory.c index f64733c23067..e093cf5e4640 100644 --- a/mm/huge_memory.c +++ b/mm/huge_memory.c @@ -66,7 +66,7 @@ bool transparent_hugepage_enabled(struct vm_area_struct *vma) { if (vma_is_anonymous(vma)) return __transparent_hugepage_enabled(vma); - if (shmem_mapping(vma->vm_file->f_mapping) && shmem_huge_enabled(vma)) + if (vma_is_shmem(vma) && shmem_huge_enabled(vma)) return __transparent_hugepage_enabled(vma); return false; -- Michal Hocko SUSE Labs
prev parent reply other threads:[~2018-12-24 18:51 UTC|newest] Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top [not found] <CALouPAi8KEuPw_Ly5W=MkYi8Yw3J6vr8mVezYaxxVyKCxH1x_g@mail.gmail.com> 2018-12-24 7:49 ` Michal Hocko 2018-12-24 11:35 ` William Kucharski 2018-12-24 12:12 ` Mike Rapoport 2018-12-24 18:51 ` Michal Hocko [this message]
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20181224185106.GC16738@dhcp22.suse.cz \ --to=mhocko@kernel.org \ --cc=akpm@linux-foundation.org \ --cc=bepvte@gmail.com \ --cc=jack@suse.cz \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-mm@kvack.org \ --cc=rientjes@google.com \ --cc=rppt@linux.ibm.com \ --cc=vbabka@suse.cz \ --subject='Re: Bug with report THP eligibility for each vma' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.