diff options
Diffstat (limited to 'arch/powerpc/kernel/kgdb.c')
| -rw-r--r-- | arch/powerpc/kernel/kgdb.c | 7 | 
1 files changed, 3 insertions, 4 deletions
diff --git a/arch/powerpc/kernel/kgdb.c b/arch/powerpc/kernel/kgdb.c index c1eef241017..8504657379f 100644 --- a/arch/powerpc/kernel/kgdb.c +++ b/arch/powerpc/kernel/kgdb.c @@ -15,7 +15,6 @@   */  #include <linux/kernel.h> -#include <linux/init.h>  #include <linux/kgdb.h>  #include <linux/smp.h>  #include <linux/signal.h> @@ -151,15 +150,16 @@ static int kgdb_handle_breakpoint(struct pt_regs *regs)  	return 1;  } +static DEFINE_PER_CPU(struct thread_info, kgdb_thread_info);  static int kgdb_singlestep(struct pt_regs *regs)  {  	struct thread_info *thread_info, *exception_thread_info; -	struct thread_info *backup_current_thread_info; +	struct thread_info *backup_current_thread_info = +		&__get_cpu_var(kgdb_thread_info);  	if (user_mode(regs))  		return 0; -	backup_current_thread_info = kmalloc(sizeof(struct thread_info), GFP_KERNEL);  	/*  	 * On Book E and perhaps other processors, singlestep is handled on  	 * the critical exception stack.  This causes current_thread_info() @@ -185,7 +185,6 @@ static int kgdb_singlestep(struct pt_regs *regs)  		/* Restore current_thread_info lastly. */  		memcpy(exception_thread_info, backup_current_thread_info, sizeof *thread_info); -	kfree(backup_current_thread_info);  	return 1;  }  | 
