aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arc/kernel/irq.c
diff options
context:
space:
mode:
authorVineet Gupta <vgupta@synopsys.com>2013-01-18 04:42:16 -0500
committerVineet Gupta <vgupta@synopsys.com>2013-02-11 09:30:30 -0500
commitac4c244d4e5d914f9a5642cdcc03b18780e55dbc (patch)
treefbc0a3da0a135dac46883eba654c862119060c3e /arch/arc/kernel/irq.c
parentcfdbc2e16e65c1ec1c23057640607cee98d1a1bd (diff)
ARC: irqflags - Interrupt enabling/disabling at in-core intc
ARC700 has an in-core intc which provides 2 priorities (a.k.a.) "levels" of interrupts (per IRQ) hencforth referred to as L1/L2 interrupts. CPU flags register STATUS32 has Interrupt Enable bits per level (E1/E2) to globally enable (or disable) all IRQs at a level. Hence the implementation of arch_local_irq_{save,restore,enable,disable}( ) The STATUS32 reg can be r/w only using the AUX Interface of ARC, hence the use of LR/SR instructions. Further, E1/E2 bits in there can only be updated using the FLAG insn. The intc supports 32 interrupts - and per IRQ enabling is controlled by a bit in the AUX_IENABLE register, hence the implmentation of arch_{,un}mask_irq( ) routines. Signed-off-by: Vineet Gupta <vgupta@synopsys.com> Cc: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/arc/kernel/irq.c')
-rw-r--r--arch/arc/kernel/irq.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/arch/arc/kernel/irq.c b/arch/arc/kernel/irq.c
new file mode 100644
index 000000000000..c4e9b25d305f
--- /dev/null
+++ b/arch/arc/kernel/irq.c
@@ -0,0 +1,32 @@
1/*
2 * Copyright (C) 2011-12 Synopsys, Inc. (www.synopsys.com)
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 */
9
10#include <linux/interrupt.h>
11#include <linux/module.h>
12#include <asm/irqflags.h>
13#include <asm/arcregs.h>
14
15void arch_local_irq_enable(void)
16{
17 unsigned long flags;
18
19 /*
20 * ARC IDE Drivers tries to re-enable interrupts from hard-isr
21 * context which is simply wrong
22 */
23 if (in_irq()) {
24 WARN_ONCE(1, "IRQ enabled from hard-isr");
25 return;
26 }
27
28 flags = arch_local_save_flags();
29 flags |= (STATUS_E1_MASK | STATUS_E2_MASK);
30 arch_local_irq_restore(flags);
31}
32EXPORT_SYMBOL(arch_local_irq_enable);