diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2011-02-07 16:30:49 -0500 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2011-03-29 08:47:52 -0400 |
commit | 1b7a2d90c83bec624ac89f0642cb57bed17a2d3d (patch) | |
tree | 2543ac3b3b4b0dfc73d45a013e21d587d273ec47 | |
parent | 1475b85d08b51b5ee2b7b426247d3ef3f531eafe (diff) |
arm: Use irq flag setter function
Use the proper accessor function instead of fiddling in the status
bits directly.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: linux-arm-kernel@lists.infradead.org
-rw-r--r-- | arch/arm/kernel/irq.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/arch/arm/kernel/irq.c b/arch/arm/kernel/irq.c index 3535d3793e65..9b3a6d86e8c1 100644 --- a/arch/arm/kernel/irq.c +++ b/arch/arm/kernel/irq.c | |||
@@ -144,24 +144,21 @@ asm_do_IRQ(unsigned int irq, struct pt_regs *regs) | |||
144 | 144 | ||
145 | void set_irq_flags(unsigned int irq, unsigned int iflags) | 145 | void set_irq_flags(unsigned int irq, unsigned int iflags) |
146 | { | 146 | { |
147 | struct irq_desc *desc; | 147 | unsigned long clr = 0, set = IRQ_NOREQUEST | IRQ_NOPROBE | IRQ_NOAUTOEN; |
148 | unsigned long flags; | ||
149 | 148 | ||
150 | if (irq >= nr_irqs) { | 149 | if (irq >= nr_irqs) { |
151 | printk(KERN_ERR "Trying to set irq flags for IRQ%d\n", irq); | 150 | printk(KERN_ERR "Trying to set irq flags for IRQ%d\n", irq); |
152 | return; | 151 | return; |
153 | } | 152 | } |
154 | 153 | ||
155 | desc = irq_to_desc(irq); | ||
156 | raw_spin_lock_irqsave(&desc->lock, flags); | ||
157 | desc->status |= IRQ_NOREQUEST | IRQ_NOPROBE | IRQ_NOAUTOEN; | ||
158 | if (iflags & IRQF_VALID) | 154 | if (iflags & IRQF_VALID) |
159 | desc->status &= ~IRQ_NOREQUEST; | 155 | clr |= IRQ_NOREQUEST; |
160 | if (iflags & IRQF_PROBE) | 156 | if (iflags & IRQF_PROBE) |
161 | desc->status &= ~IRQ_NOPROBE; | 157 | clr |= IRQ_NOPROBE; |
162 | if (!(iflags & IRQF_NOAUTOEN)) | 158 | if (!(iflags & IRQF_NOAUTOEN)) |
163 | desc->status &= ~IRQ_NOAUTOEN; | 159 | clr |= IRQ_NOAUTOEN; |
164 | raw_spin_unlock_irqrestore(&desc->lock, flags); | 160 | /* Order is clear bits in "clr" then set bits in "set" */ |
161 | irq_modify_status(irq, clr, set & ~clr); | ||
165 | } | 162 | } |
166 | 163 | ||
167 | void __init init_IRQ(void) | 164 | void __init init_IRQ(void) |