diff options
Diffstat (limited to 'arch/powerpc/xmon/xmon.c')
| -rw-r--r-- | arch/powerpc/xmon/xmon.c | 33 | 
1 files changed, 22 insertions, 11 deletions
| diff --git a/arch/powerpc/xmon/xmon.c b/arch/powerpc/xmon/xmon.c index 36b8dc47a3c3..757b8499aba2 100644 --- a/arch/powerpc/xmon/xmon.c +++ b/arch/powerpc/xmon/xmon.c @@ -75,6 +75,9 @@ static int xmon_gate;  #define xmon_owner 0  #endif /* CONFIG_SMP */ +#ifdef CONFIG_PPC_PSERIES +static int set_indicator_token = RTAS_UNKNOWN_SERVICE; +#endif  static unsigned long in_xmon __read_mostly = 0;  static int xmon_on = IS_ENABLED(CONFIG_XMON_DEFAULT); @@ -273,7 +276,7 @@ Commands:\n\    X	exit monitor and don't recover\n"  #if defined(CONFIG_PPC64) && !defined(CONFIG_PPC_BOOK3E)  "  u	dump segment table or SLB\n" -#elif defined(CONFIG_PPC_STD_MMU_32) +#elif defined(CONFIG_PPC_BOOK3S_32)  "  u	dump segment registers\n"  #elif defined(CONFIG_44x) || defined(CONFIG_PPC_BOOK3E)  "  u	dump TLB\n" @@ -358,7 +361,6 @@ static inline void disable_surveillance(void)  #ifdef CONFIG_PPC_PSERIES  	/* Since this can't be a module, args should end up below 4GB. */  	static struct rtas_args args; -	int token;  	/*  	 * At this point we have got all the cpus we can into @@ -367,11 +369,11 @@ static inline void disable_surveillance(void)  	 * If we did try to take rtas.lock there would be a  	 * real possibility of deadlock.  	 */ -	token = rtas_token("set-indicator"); -	if (token == RTAS_UNKNOWN_SERVICE) +	if (set_indicator_token == RTAS_UNKNOWN_SERVICE)  		return; -	rtas_call_unlocked(&args, token, 3, 1, NULL, SURVEILLANCE_TOKEN, 0, 0); +	rtas_call_unlocked(&args, set_indicator_token, 3, 1, NULL, +			   SURVEILLANCE_TOKEN, 0, 0);  #endif /* CONFIG_PPC_PSERIES */  } @@ -1058,7 +1060,7 @@ cmds(struct pt_regs *excp)  		case 'P':  			show_tasks();  			break; -#ifdef CONFIG_PPC_STD_MMU +#ifdef CONFIG_PPC_BOOK3S  		case 'u':  			dump_segments();  			break; @@ -2793,7 +2795,7 @@ print_address(unsigned long addr)  	xmon_print_symbol(addr, "\t# ", "");  } -void +static void  dump_log_buf(void)  {  	struct kmsg_dumper dumper = { .active = 1 }; @@ -2994,13 +2996,13 @@ static void show_task(struct task_struct *tsk)  	printf("%px %016lx %6d %6d %c %2d %s\n", tsk,  		tsk->thread.ksp, -		tsk->pid, tsk->parent->pid, +		tsk->pid, rcu_dereference(tsk->parent)->pid,  		state, task_thread_info(tsk)->cpu,  		tsk->comm);  }  #ifdef CONFIG_PPC_BOOK3S_64 -void format_pte(void *ptep, unsigned long pte) +static void format_pte(void *ptep, unsigned long pte)  {  	pte_t entry = __pte(pte); @@ -3495,14 +3497,14 @@ void dump_segments(void)  }  #endif -#ifdef CONFIG_PPC_STD_MMU_32 +#ifdef CONFIG_PPC_BOOK3S_32  void dump_segments(void)  {  	int i;  	printf("sr0-15 =");  	for (i = 0; i < 16; ++i) -		printf(" %x", mfsrin(i)); +		printf(" %x", mfsrin(i << 28));  	printf("\n");  }  #endif @@ -3688,6 +3690,14 @@ static void xmon_init(int enable)  		__debugger_iabr_match = xmon_iabr_match;  		__debugger_break_match = xmon_break_match;  		__debugger_fault_handler = xmon_fault_handler; + +#ifdef CONFIG_PPC_PSERIES +		/* +		 * Get the token here to avoid trying to get a lock +		 * during the crash, causing a deadlock. +		 */ +		set_indicator_token = rtas_token("set-indicator"); +#endif  	} else {  		__debugger = NULL;  		__debugger_ipi = NULL; @@ -4033,6 +4043,7 @@ static int do_spu_cmd(void)  		subcmd = inchar();  		if (isxdigit(subcmd) || subcmd == '\n')  			termch = subcmd; +		/* fall through */  	case 'f':  		scanhex(&num);  		if (num >= XMON_NUM_SPUS || !spu_info[num].spu) { | 
