diff options
Diffstat (limited to 'arch/arc/kernel')
| -rw-r--r-- | arch/arc/kernel/setup.c | 2 | ||||
| -rw-r--r-- | arch/arc/kernel/stacktrace.c | 2 | ||||
| -rw-r--r-- | arch/arc/kernel/traps.c | 14 | ||||
| -rw-r--r-- | arch/arc/kernel/troubleshoot.c | 3 | 
4 files changed, 19 insertions, 2 deletions
| diff --git a/arch/arc/kernel/setup.c b/arch/arc/kernel/setup.c index 7ef7d9a8ff89..9d27331fe69a 100644 --- a/arch/arc/kernel/setup.c +++ b/arch/arc/kernel/setup.c @@ -199,7 +199,7 @@ static void read_arc_build_cfg_regs(void)  			unsigned int exec_ctrl;  			READ_BCR(AUX_EXEC_CTRL, exec_ctrl); -			cpu->extn.dual_enb = exec_ctrl & 1; +			cpu->extn.dual_enb = !(exec_ctrl & 1);  			/* dual issue always present for this core */  			cpu->extn.dual = 1; diff --git a/arch/arc/kernel/stacktrace.c b/arch/arc/kernel/stacktrace.c index 74315f302971..bf40e06f3fb8 100644 --- a/arch/arc/kernel/stacktrace.c +++ b/arch/arc/kernel/stacktrace.c @@ -163,7 +163,7 @@ arc_unwind_core(struct task_struct *tsk, struct pt_regs *regs,   */  static int __print_sym(unsigned int address, void *unused)  { -	__print_symbol("  %s\n", address); +	printk("  %pS\n", (void *)address);  	return 0;  } diff --git a/arch/arc/kernel/traps.c b/arch/arc/kernel/traps.c index bcd7c9fc5d0f..133a4dae41fe 100644 --- a/arch/arc/kernel/traps.c +++ b/arch/arc/kernel/traps.c @@ -83,6 +83,7 @@ DO_ERROR_INFO(SIGILL, "Illegal Insn (or Seq)", insterror_is_error, ILL_ILLOPC)  DO_ERROR_INFO(SIGBUS, "Invalid Mem Access", __weak do_memory_error, BUS_ADRERR)  DO_ERROR_INFO(SIGTRAP, "Breakpoint Set", trap_is_brkpt, TRAP_BRKPT)  DO_ERROR_INFO(SIGBUS, "Misaligned Access", do_misaligned_error, BUS_ADRALN) +DO_ERROR_INFO(SIGSEGV, "gcc generated __builtin_trap", do_trap5_error, 0)  /*   * Entry Point for Misaligned Data access Exception, for emulating in software @@ -115,6 +116,8 @@ void do_machine_check_fault(unsigned long address, struct pt_regs *regs)   * Thus TRAP_S <n> can be used for specific purpose   *  -1 used for software breakpointing (gdb)   *  -2 used by kprobes + *  -5 __builtin_trap() generated by gcc (2018.03 onwards) for toggle such as + *     -fno-isolate-erroneous-paths-dereference   */  void do_non_swi_trap(unsigned long address, struct pt_regs *regs)  { @@ -134,6 +137,9 @@ void do_non_swi_trap(unsigned long address, struct pt_regs *regs)  		kgdb_trap(regs);  		break; +	case 5: +		do_trap5_error(address, regs); +		break;  	default:  		break;  	} @@ -155,3 +161,11 @@ void do_insterror_or_kprobe(unsigned long address, struct pt_regs *regs)  	insterror_is_error(address, regs);  } + +/* + * abort() call generated by older gcc for __builtin_trap() + */ +void abort(void) +{ +	__asm__ __volatile__("trap_s  5\n"); +} diff --git a/arch/arc/kernel/troubleshoot.c b/arch/arc/kernel/troubleshoot.c index 7d8c1d6c2f60..6e9a0a9a6a04 100644 --- a/arch/arc/kernel/troubleshoot.c +++ b/arch/arc/kernel/troubleshoot.c @@ -163,6 +163,9 @@ static void show_ecr_verbose(struct pt_regs *regs)  		else  			pr_cont("Bus Error, check PRM\n");  #endif +	} else if (vec == ECR_V_TRAP) { +		if (regs->ecr_param == 5) +			pr_cont("gcc generated __builtin_trap\n");  	} else {  		pr_cont("Check Programmer's Manual\n");  	} |