diff options
Diffstat (limited to 'arch/arc/kernel')
| -rw-r--r-- | arch/arc/kernel/ctx_sw_asm.S | 2 | ||||
| -rw-r--r-- | arch/arc/kernel/devtree.c | 2 | ||||
| -rw-r--r-- | arch/arc/kernel/head.S | 7 | ||||
| -rw-r--r-- | arch/arc/kernel/ptrace.c | 4 | ||||
| -rw-r--r-- | arch/arc/kernel/smp.c | 15 | ||||
| -rw-r--r-- | arch/arc/kernel/vmlinux.lds.S | 2 | 
6 files changed, 24 insertions, 8 deletions
| diff --git a/arch/arc/kernel/ctx_sw_asm.S b/arch/arc/kernel/ctx_sw_asm.S index 2ff0347a2fd7..e248594097e7 100644 --- a/arch/arc/kernel/ctx_sw_asm.S +++ b/arch/arc/kernel/ctx_sw_asm.S @@ -10,9 +10,9 @@   *  -This is the more "natural" hand written assembler   */ +#include <linux/linkage.h>  #include <asm/entry.h>       /* For the SAVE_* macros */  #include <asm/asm-offsets.h> -#include <asm/linkage.h>  #define KSP_WORD_OFF 	((TASK_THREAD + THREAD_KSP) / 4) diff --git a/arch/arc/kernel/devtree.c b/arch/arc/kernel/devtree.c index 0b3ef4025d89..fffdb5e41b20 100644 --- a/arch/arc/kernel/devtree.c +++ b/arch/arc/kernel/devtree.c @@ -41,7 +41,7 @@ const struct machine_desc * __init setup_machine_fdt(void *dt)  {  	const struct machine_desc *mdesc;  	unsigned long dt_root; -	void *clk; +	const void *clk;  	int len;  	if (!early_init_dt_scan(dt)) diff --git a/arch/arc/kernel/head.S b/arch/arc/kernel/head.S index 07a58f2d3077..4d2481bd8b98 100644 --- a/arch/arc/kernel/head.S +++ b/arch/arc/kernel/head.S @@ -77,10 +77,11 @@ stext:  	; Clear BSS before updating any globals  	; XXX: use ZOL here  	mov	r5, __bss_start -	mov	r6, __bss_stop +	sub	r6, __bss_stop, r5 +	lsr.f	lp_count, r6, 2 +	lpnz	1f +	st.ab   0, [r5, 4]  1: -	st.ab   0, [r5,4] -	brlt    r5, r6, 1b  	; Uboot - kernel ABI  	;    r0 = [0] No uboot interaction, [1] cmdline in r2, [2] DTB in r2 diff --git a/arch/arc/kernel/ptrace.c b/arch/arc/kernel/ptrace.c index 5d76706139dd..13b3ffb27a38 100644 --- a/arch/arc/kernel/ptrace.c +++ b/arch/arc/kernel/ptrace.c @@ -146,6 +146,10 @@ long arch_ptrace(struct task_struct *child, long request,  	pr_debug("REQ=%ld: ADDR =0x%lx, DATA=0x%lx)\n", request, addr, data);  	switch (request) { +	case PTRACE_GET_THREAD_AREA: +		ret = put_user(task_thread_info(child)->thr_ptr, +			       (unsigned long __user *)data); +		break;  	default:  		ret = ptrace_request(child, request, addr, data);  		break; diff --git a/arch/arc/kernel/smp.c b/arch/arc/kernel/smp.c index cf90b6f4d3e0..c802bb500602 100644 --- a/arch/arc/kernel/smp.c +++ b/arch/arc/kernel/smp.c @@ -337,8 +337,19 @@ irqreturn_t do_IPI(int irq, void *dev_id)   * API called by platform code to hookup arch-common ISR to their IPI IRQ   */  static DEFINE_PER_CPU(int, ipi_dev); + +static struct irqaction arc_ipi_irq = { +        .name    = "IPI Interrupt", +        .flags   = IRQF_PERCPU, +        .handler = do_IPI, +}; +  int smp_ipi_irq_setup(int cpu, int irq)  { -	int *dev_id = &per_cpu(ipi_dev, smp_processor_id()); -	return request_percpu_irq(irq, do_IPI, "IPI Interrupt", dev_id); +	if (!cpu) +		return setup_irq(irq, &arc_ipi_irq); +	else +		arch_unmask_irq(irq); + +	return 0;  } diff --git a/arch/arc/kernel/vmlinux.lds.S b/arch/arc/kernel/vmlinux.lds.S index 2555f5886af6..dd35bde39f69 100644 --- a/arch/arc/kernel/vmlinux.lds.S +++ b/arch/arc/kernel/vmlinux.lds.S @@ -116,7 +116,7 @@ SECTIONS  	_edata = .; -	BSS_SECTION(0, 0, 0) +	BSS_SECTION(4, 4, 4)  #ifdef CONFIG_ARC_DW2_UNWIND  	. = ALIGN(PAGE_SIZE); | 
