Otherwise, gdb continue operation after a breakpoint is hit may trap
into endless breakpoint.
Signed-off-by: Sonic Zhang <sonic.zhang@analog.com>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
#ifdef CONFIG_IPIPE
static unsigned long kgdb_arch_imask;
+#endif
void kgdb_post_primary_code(struct pt_regs *regs, int e_vector, int err_code)
{
+ if (kgdb_single_step)
+ preempt_enable();
+
+#ifdef CONFIG_IPIPE
if (kgdb_arch_imask) {
cpu_pda[raw_smp_processor_id()].ex_imask = kgdb_arch_imask;
kgdb_arch_imask = 0;
}
-}
#endif
+}
int kgdb_arch_handle_exception(int vector, int signo,
int err_code, char *remcom_in_buffer,
*/
kgdb_single_step = i + 1;
+ preempt_disable();
#ifdef CONFIG_IPIPE
kgdb_arch_imask = cpu_pda[raw_smp_processor_id()].ex_imask;
cpu_pda[raw_smp_processor_id()].ex_imask = 0;