summaryrefslogtreecommitdiff
path: root/packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch
diff options
context:
space:
mode:
authorKoen Kooi <koen@openembedded.org>2007-09-04 12:07:11 +0000
committerKoen Kooi <koen@openembedded.org>2007-09-04 12:07:11 +0000
commit1c24210e3f0b3f6a5a5783ed597252d453e6bd64 (patch)
tree92a51cdf31cca39b866e3f818a799fa4fd6b570e /packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch
parentadc0e34177df635be3bec485a184e5573f13383e (diff)
parentb144d7d083863cb10a7d9219ddcede338f6e839a (diff)
propagate from branch 'org.openembedded.dev' (head 3fed235384e32b1c9ba26c86ff39b2ffb928fbed)
to branch 'org.openembedded.dev.avr32' (head 50c56d6b5b2d15f6bc9c32b4f9907bc0d1c3564b)
Diffstat (limited to 'packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch')
-rw-r--r--packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch30
1 files changed, 30 insertions, 0 deletions
diff --git a/packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch b/packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch
new file mode 100644
index 0000000000..c626016ff4
--- /dev/null
+++ b/packages/linux/linux-2.6.18/avr32-time-add-shared-interrupts.patch
@@ -0,0 +1,30 @@
+--- linux-2.6.18.orig/arch/avr32/kernel/time.c 2006-11-06 14:36:50.000000000 +0100
++++ linux-2.6.18/arch/avr32/kernel/time.c 2006-11-06 14:57:03.000000000 +0100
+@@ -21,6 +21,7 @@
+ #include <linux/profile.h>
+ #include <linux/sysdev.h>
+
++#include <asm/intc.h>
+ #include <asm/div64.h>
+ #include <asm/sysreg.h>
+ #include <asm/io.h>
+@@ -136,6 +137,10 @@
+ {
+ unsigned int count;
+
++ /* Check if interrupt is timer or performance counters */
++ if (!(intc_get_pending(irq) & 1))
++ return IRQ_NONE;
++
+ /* ack timer interrupt and try to set next interrupt */
+ count = avr32_hpt_read();
+ avr32_timer_ack();
+@@ -164,7 +169,7 @@
+
+ static struct irqaction timer_irqaction = {
+ .handler = timer_interrupt,
+- .flags = IRQF_DISABLED,
++ .flags = IRQF_DISABLED|IRQF_SHARED,
+ .name = "timer",
+ };
+