From mboxrd@z Thu Jan 1 00:00:00 1970 From: Michael Ellerman Date: Wed, 05 Jun 2019 11:19:22 +0000 Subject: Re: [RFC V2] mm: Generalize notify_page_fault() Message-Id: <87sgsomg91.fsf@concordia.ellerman.id.au> List-Id: References: <1559630046-12940-1-git-send-email-anshuman.khandual@arm.com> In-Reply-To: <1559630046-12940-1-git-send-email-anshuman.khandual@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Anshuman Khandual , linux-kernel@vger.kernel.org, linux-mm@kvack.org Cc: Mark Rutland , Michal Hocko , linux-ia64@vger.kernel.org, linux-sh@vger.kernel.org, Peter Zijlstra , Catalin Marinas , Dave Hansen , Will Deacon , Paul Mackerras , sparclinux@vger.kernel.org, Stephen Rothwell , linux-s390@vger.kernel.org, Yoshinori Sato , x86@kernel.org, Russell King , Matthew Wilcox , Ingo Molnar , Fenghua Yu , Andrey Konovalov , Andy Lutomirski , Thomas Gleixner , linux-arm-kernel@lists.infradead.org, Christophe Leroy , Tony Luck , Heiko Carstens , Martin Schwidefsky , Andrew Morton , linuxppc-dev@lists.ozlabs.org, "David S. Miller" Anshuman Khandual writes: > Similar notify_page_fault() definitions are being used by architectures > duplicating much of the same code. This attempts to unify them into a > single implementation, generalize it and then move it to a common place. > kprobes_built_in() can detect CONFIG_KPROBES, hence notify_page_fault() > need not be wrapped again within CONFIG_KPROBES. Trap number argument can > now contain upto an 'unsigned int' accommodating all possible platforms. ... > diff --git a/arch/arm/mm/fault.c b/arch/arm/mm/fault.c > index 58f69fa..1bc3b18 100644 > --- a/arch/arm/mm/fault.c > +++ b/arch/arm/mm/fault.c > @@ -30,28 +30,6 @@ > > #ifdef CONFIG_MMU > > -#ifdef CONFIG_KPROBES > -static inline int notify_page_fault(struct pt_regs *regs, unsigned int fsr) > -{ > - int ret = 0; > - > - if (!user_mode(regs)) { > - /* kprobe_running() needs smp_processor_id() */ > - preempt_disable(); > - if (kprobe_running() && kprobe_fault_handler(regs, fsr)) > - ret = 1; > - preempt_enable(); > - } > - > - return ret; > -} > -#else You've changed several of the architectures from something like above, where it disables preemption around the call into the below: > +int __kprobes notify_page_fault(struct pt_regs *regs, unsigned int trap) > +{ > + int ret = 0; > + > + /* > + * To be potentially processing a kprobe fault and to be allowed > + * to call kprobe_running(), we have to be non-preemptible. > + */ > + if (kprobes_built_in() && !preemptible() && !user_mode(regs)) { > + if (kprobe_running() && kprobe_fault_handler(regs, trap)) > + ret = 1; > + } > + return ret; > +} Which skips everything if we're preemptible. Is that an equivalent change? If so can you please explain why in more detail. Also why not have it return bool? cheers