From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935202AbcIFQLq (ORCPT ); Tue, 6 Sep 2016 12:11:46 -0400 Received: from foss.arm.com ([217.140.101.70]:57396 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933625AbcIFQLp (ORCPT ); Tue, 6 Sep 2016 12:11:45 -0400 Date: Tue, 6 Sep 2016 17:11:39 +0100 From: Catalin Marinas To: Pratyush Anand Cc: linux-arm-kernel@lists.infradead.org, linux@arm.linux.org.uk, will.deacon@arm.com, Yang Shi , steve.capper@linaro.org, srikar@linux.vnet.ibm.com, Suzuki K Poulose , vijaya.kumar@caviumnetworks.com, linux-kernel@vger.kernel.org, oleg@redhat.com, dave.long@linaro.org, Sandeepa Prabhu , wcohen@redhat.com, Anna-Maria Gleixner Subject: Re: [PATCH 3/5] arm64: Handle TRAP_HWBRKPT for user mode as well Message-ID: <20160906161139.GG19605@e104818-lin.cambridge.arm.com> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Aug 02, 2016 at 11:00:07AM +0530, Pratyush Anand wrote: > --- a/arch/arm64/kernel/debug-monitors.c > +++ b/arch/arm64/kernel/debug-monitors.c > @@ -246,6 +246,8 @@ static void send_user_sigtrap(int si_code) > static int single_step_handler(unsigned long addr, unsigned int esr, > struct pt_regs *regs) > { > + bool handler_found = false; > + > /* > * If we are stepping a pending breakpoint, call the hw_breakpoint > * handler first. > @@ -253,7 +255,14 @@ static int single_step_handler(unsigned long addr, unsigned int esr, > if (!reinstall_suspended_bps(regs)) > return 0; > > - if (user_mode(regs)) { > +#ifdef CONFIG_KPROBES > + if (kprobe_single_step_handler(regs, esr) == DBG_HOOK_HANDLED) > + handler_found = true; > +#endif > + if (!handler_found && call_step_hook(regs, esr) == DBG_HOOK_HANDLED) > + handler_found = true; > + > + if (!handler_found && user_mode(regs)) { > send_user_sigtrap(TRAP_HWBKPT); Could we register kprobe_single_step_handler() via register_set_hook() and only invoke call_step_hook() above? -- Catalin