The patch titled irq-flags: CRIS: Use the new IRQF_ constansts has been added to the -mm tree. Its filename is irq-flags-chris-use-the-new-irqf_-constansts.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: irq-flags: CRIS: Use the new IRQF_ constansts From: Thomas Gleixner <tglx@xxxxxxxxxxxxx> Use the new IRQF_ constants and remove the SA_INTERRUPT define Signed-off-by: Thomas Gleixner <tglx@xxxxxxxxxxxxx> Cc: Ingo Molnar <mingo@xxxxxxx> Cc: "David S. Miller" <davem@xxxxxxxxxxxxx> Cc: Benjamin Herrenschmidt <benh@xxxxxxxxxxxxxxxxxxx> Cc: Mikael Starvik <starvik@xxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/cris/arch-v10/drivers/gpio.c | 4 ++-- arch/cris/arch-v10/kernel/time.c | 6 +++--- arch/cris/arch-v32/drivers/gpio.c | 4 ++-- arch/cris/arch-v32/kernel/arbiter.c | 2 +- arch/cris/arch-v32/kernel/fasttimer.c | 2 +- arch/cris/arch-v32/kernel/irq.c | 2 +- arch/cris/arch-v32/kernel/smp.c | 2 +- arch/cris/arch-v32/kernel/time.c | 12 ++++++++---- arch/cris/kernel/irq.c | 2 +- include/asm-cris/arch-v10/irq.h | 2 +- include/asm-cris/arch-v32/irq.h | 2 +- include/asm-cris/signal.h | 2 -- 12 files changed, 22 insertions(+), 20 deletions(-) diff -puN arch/cris/arch-v10/drivers/gpio.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v10/drivers/gpio.c --- a/arch/cris/arch-v10/drivers/gpio.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v10/drivers/gpio.c @@ -937,11 +937,11 @@ gpio_init(void) * in some tests. */ if (request_irq(TIMER0_IRQ_NBR, gpio_poll_timer_interrupt, - SA_SHIRQ | SA_INTERRUPT,"gpio poll", NULL)) { + IRQF_SHARED | IRQF_DISABLED,"gpio poll", NULL)) { printk(KERN_CRIT "err: timer0 irq for gpio\n"); } if (request_irq(PA_IRQ_NBR, gpio_pa_interrupt, - SA_SHIRQ | SA_INTERRUPT,"gpio PA", NULL)) { + IRQF_SHARED | IRQF_DISABLED,"gpio PA", NULL)) { printk(KERN_CRIT "err: PA irq for gpio\n"); } diff -puN arch/cris/arch-v10/kernel/time.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v10/kernel/time.c --- a/arch/cris/arch-v10/kernel/time.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v10/kernel/time.c @@ -251,11 +251,11 @@ timer_interrupt(int irq, void *dev_id, s return IRQ_HANDLED; } -/* timer is SA_SHIRQ so drivers can add stuff to the timer irq chain - * it needs to be SA_INTERRUPT to make the jiffies update work properly +/* timer is IRQF_SHARED so drivers can add stuff to the timer irq chain + * it needs to be IRQF_DISABLED to make the jiffies update work properly */ -static struct irqaction irq2 = { timer_interrupt, SA_SHIRQ | SA_INTERRUPT, +static struct irqaction irq2 = { timer_interrupt, IRQF_SHARED | IRQF_DISABLED, CPU_MASK_NONE, "timer", NULL, NULL}; void __init diff -puN arch/cris/arch-v32/drivers/gpio.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/drivers/gpio.c --- a/arch/cris/arch-v32/drivers/gpio.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/drivers/gpio.c @@ -744,11 +744,11 @@ gpio_init(void) * in some tests. */ if (request_irq(TIMER_INTR_VECT, gpio_poll_timer_interrupt, - SA_SHIRQ | SA_INTERRUPT,"gpio poll", &alarmlist)) { + IRQF_SHARED | IRQF_DISABLED,"gpio poll", &alarmlist)) { printk("err: timer0 irq for gpio\n"); } if (request_irq(GEN_IO_INTR_VECT, gpio_pa_interrupt, - SA_SHIRQ | SA_INTERRUPT,"gpio PA", &alarmlist)) { + IRQF_SHARED | IRQF_DISABLED,"gpio PA", &alarmlist)) { printk("err: PA irq for gpio\n"); } /* enable the gio and timer irq in global config */ diff -puN arch/cris/arch-v32/kernel/arbiter.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/kernel/arbiter.c --- a/arch/cris/arch-v32/kernel/arbiter.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/kernel/arbiter.c @@ -119,7 +119,7 @@ static void crisv32_arbiter_init(void) crisv32_arbiter_config(EXT_REGION); crisv32_arbiter_config(INT_REGION); - if (request_irq(MEMARB_INTR_VECT, crisv32_arbiter_irq, SA_INTERRUPT, + if (request_irq(MEMARB_INTR_VECT, crisv32_arbiter_irq, IRQF_DISABLED, "arbiter", NULL)) printk(KERN_ERR "Couldn't allocate arbiter IRQ\n"); diff -puN arch/cris/arch-v32/kernel/fasttimer.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/kernel/fasttimer.c --- a/arch/cris/arch-v32/kernel/fasttimer.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/kernel/fasttimer.c @@ -981,7 +981,7 @@ void fast_timer_init(void) proc_register_dynamic(&proc_root, &fasttimer_proc_entry); #endif #endif /* PROC_FS */ - if(request_irq(TIMER_INTR_VECT, timer_trig_interrupt, SA_INTERRUPT, + if(request_irq(TIMER_INTR_VECT, timer_trig_interrupt, IRQF_DISABLED, "fast timer int", NULL)) { printk("err: timer1 irq\n"); diff -puN arch/cris/arch-v32/kernel/irq.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/kernel/irq.c --- a/arch/cris/arch-v32/kernel/irq.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/kernel/irq.c @@ -268,7 +268,7 @@ void crisv32_do_IRQ(int irq, int block, struct pt_regs* regs) { /* Interrupts that may not be moved to another CPU and - * are SA_INTERRUPT may skip blocking. This is currently + * are IRQF_DISABLED may skip blocking. This is currently * only valid for the timer IRQ and the IPI and is used * for the timer interrupt to avoid watchdog starvation. */ diff -puN arch/cris/arch-v32/kernel/smp.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/kernel/smp.c --- a/arch/cris/arch-v32/kernel/smp.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/kernel/smp.c @@ -62,7 +62,7 @@ static unsigned long irq_regs[NR_CPUS] = static irqreturn_t crisv32_ipi_interrupt(int irq, void *dev_id, struct pt_regs *regs); static int send_ipi(int vector, int wait, cpumask_t cpu_mask); -static struct irqaction irq_ipi = { crisv32_ipi_interrupt, SA_INTERRUPT, +static struct irqaction irq_ipi = { crisv32_ipi_interrupt, IRQF_DISABLED, CPU_MASK_NONE, "ipi", NULL, NULL}; extern void cris_mmu_init(void); diff -puN arch/cris/arch-v32/kernel/time.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/arch-v32/kernel/time.c --- a/arch/cris/arch-v32/kernel/time.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/arch-v32/kernel/time.c @@ -241,12 +241,16 @@ timer_interrupt(int irq, void *dev_id, s return IRQ_HANDLED; } -/* timer is SA_SHIRQ so drivers can add stuff to the timer irq chain - * it needs to be SA_INTERRUPT to make the jiffies update work properly +/* timer is IRQF_SHARED so drivers can add stuff to the timer irq chain + * it needs to be IRQF_DISABLED to make the jiffies update work properly */ -static struct irqaction irq_timer = { timer_interrupt, SA_SHIRQ | SA_INTERRUPT, - CPU_MASK_NONE, "timer", NULL, NULL}; +static struct irqaction irq_timer = { + .mask = timer_interrupt, + .flags = IRQF_SHARED | IRQF_DISABLED, + .mask = CPU_MASK_NONE, + .name = "timer" +}; void __init cris_timer_init(void) diff -puN arch/cris/kernel/irq.c~irq-flags-chris-use-the-new-irqf_-constansts arch/cris/kernel/irq.c --- a/arch/cris/kernel/irq.c~irq-flags-chris-use-the-new-irqf_-constansts +++ a/arch/cris/kernel/irq.c @@ -85,7 +85,7 @@ skip: /* called by the assembler IRQ entry functions defined in irq.h * to dispatch the interrupts to registred handlers * interrupts are disabled upon entry - depending on if the - * interrupt was registred with SA_INTERRUPT or not, interrupts + * interrupt was registred with IRQF_DISABLED or not, interrupts * are re-enabled or not. */ diff -puN include/asm-cris/arch-v10/irq.h~irq-flags-chris-use-the-new-irqf_-constansts include/asm-cris/arch-v10/irq.h --- a/include/asm-cris/arch-v10/irq.h~irq-flags-chris-use-the-new-irqf_-constansts +++ a/include/asm-cris/arch-v10/irq.h @@ -141,7 +141,7 @@ __asm__ ( \ * it here, we would not get the multiple_irq at all. * * The non-blocking here is based on the knowledge that the timer interrupt is - * registred as a fast interrupt (SA_INTERRUPT) so that we _know_ there will not + * registred as a fast interrupt (IRQF_DISABLED) so that we _know_ there will not * be an sti() before the timer irq handler is run to acknowledge the interrupt. */ diff -puN include/asm-cris/arch-v32/irq.h~irq-flags-chris-use-the-new-irqf_-constansts include/asm-cris/arch-v32/irq.h --- a/include/asm-cris/arch-v32/irq.h~irq-flags-chris-use-the-new-irqf_-constansts +++ a/include/asm-cris/arch-v32/irq.h @@ -98,7 +98,7 @@ __asm__ ( \ * if we had BLOCK'edit here, we would not get the multiple_irq at all. * * The non-blocking here is based on the knowledge that the timer interrupt is - * registred as a fast interrupt (SA_INTERRUPT) so that we _know_ there will not + * registred as a fast interrupt (IRQF_DISABLED) so that we _know_ there will not * be an sti() before the timer irq handler is run to acknowledge the interrupt. */ #define BUILD_TIMER_IRQ(nr, mask) \ diff -puN include/asm-cris/signal.h~irq-flags-chris-use-the-new-irqf_-constansts include/asm-cris/signal.h --- a/include/asm-cris/signal.h~irq-flags-chris-use-the-new-irqf_-constansts +++ a/include/asm-cris/signal.h @@ -74,7 +74,6 @@ typedef unsigned long sigset_t; * SA_FLAGS values: * * SA_ONSTACK indicates that a registered stack_t will be used. - * SA_INTERRUPT is a no-op, but left due to historical reasons. Use the * SA_RESTART flag to get restarting signals (which were the default long ago) * SA_NOCLDSTOP flag to turn off SIGCHLD when children stop. * SA_RESETHAND clears the handler when the signal is delivered. @@ -95,7 +94,6 @@ typedef unsigned long sigset_t; #define SA_NOMASK SA_NODEFER #define SA_ONESHOT SA_RESETHAND -#define SA_INTERRUPT 0x20000000 /* dummy -- ignored */ #define SA_RESTORER 0x04000000 _ Patches currently in -mm which might be from tglx@xxxxxxxxxxxxx are origin.patch irq-use-sa_percpu_irq-not-irq_per_cpu-for-irqactionflags.patch irq-warning-message-cleanup.patch irq-flags-consolidate-flags-for-request_irq.patch irq-flags-alpha-use-the-new-irqf_-constansts.patch irq-flags-arm26-use-the-new-irqf_-constansts.patch irq-flags-arm-use-the-new-irqf_-constansts.patch irq-flags-chris-use-the-new-irqf_-constansts.patch irq-flags-frv-use-the-new-irqf_-constansts.patch irq-flags-h8300-use-the-new-irqf_-constansts.patch irq-flags-i386-use-the-new-irqf_-constansts.patch irq-flags-ia64-use-the-new-irqf_-constansts.patch irq-flags-m32r-use-the-new-irqf_-constansts.patch irq-flags-m68knommu-use-the-new-irqf_-constansts.patch irq-flags-m68k-use-the-new-irqf_-constansts.patch irq-flags-mips-use-the-new-irqf_-constansts.patch irq-flags-parisc-use-the-new-irqf_-constansts.patch irq-flags-powerpc-use-the-new-irqf_-constansts.patch irq-flags-ppc-use-the-new-irqf_-constansts.patch irq-flags-s390-use-the-new-irqf_-constansts.patch irq-flags-sh64-use-the-new-irqf_-constansts.patch irq-flags-sh-use-the-new-irqf_-constansts.patch irq-flags-sparc64-use-the-new-irqf_-constansts.patch irq-flags-sparc-use-the-new-irqf_-constansts.patch irq-flags-um-use-the-new-irqf_-constansts.patch irq-flags-v850-use-the-new-irqf_-constansts.patch irq-flags-x86_64-use-the-new-irqf_-constansts.patch irq-flags-xtensa-use-the-new-irqf_-constansts.patch irq-flags-generic-irq-use-the-new-irqf_-constansts.patch irq-flags-drivers-block-use-the-new-irqf_-constansts.patch irq-flags-drivers-char-use-the-new-irqf_-constansts.patch irq-flags-drivers-drm-use-the-new-irqf_-constansts.patch irq-flags-ide-use-the-new-irqf_-constansts.patch irq-flags-firewire-use-the-new-irqf_-constansts.patch irq-flags-isdn-use-the-new-irqf_-constansts.patch irq-flags-media-use-the-new-irqf_-constansts.patch irq-flags-misc-drivers-use-the-new-irqf_-constansts.patch irq-flags-drivers-net-use-the-new-irqf_-constansts.patch irq-flags-parisc-use-the-new-irqf_-constansts-2.patch irq-flags-pci-use-the-new-irqf_-constansts.patch irq-flags-rio-use-the-new-irqf_-constansts.patch irq-flags-scsi-use-the-new-irqf_-constansts.patch irq-flags-serial-use-the-new-irqf_-constansts.patch irq-flags-usb-use-the-new-irqf_-constansts.patch irq-flags-video-use-the-new-irqf_-constansts.patch irq-flags-sound-use-the-new-irqf_-constansts.patch irq-flags-documentation-use-the-new-irqf_-constansts.patch git-mtd.patch lockdep-add-disable-enable_irq_lockdep-api.patch genirq-convert-the-x86_64-architecture-to-irq-chips.patch genirq-convert-the-i386-architecture-to-irq-chips.patch genirq-irq-convert-the-move_irq-flag-from-a-32bit-word-to-a-single-bit.patch genirq-irq-add-moved_masked_irq.patch genirq-x86_64-irq-reenable-migrating-irqs-to-other-cpus.patch genirq-x86_64-irq-reenable-migrating-irqs-to-other-cpus-fix.patch genirq-msi-simplify-msi-enable-and-disable.patch genirq-msi-simplify-msi-enable-and-disable-fix.patch genirq-msi-make-the-msi-boolean-tests-return-either-0-or-1.patch genirq-msi-implement-helper-functions-read_msi_msg-and-write_msi_msg.patch genirq-msi-refactor-the-msi_ops.patch genirq-msi-simplify-the-msi-irq-limit-policy.patch genirq-irq-add-a-dynamic-irq-creation-api.patch genirq-ia64-irq-dynamic-irq-support.patch genirq-ia64-irq-dynamic-irq-support-fix.patch genirq-i386-irq-dynamic-irq-support.patch genirq-i386-irq-dynamic-irq-support-fix.patch genirq-x86_64-irq-dynamic-irq-support.patch genirq-msi-make-the-msi-code-irq-based-and-not-vector-based.patch genirq-x86_64-irq-move-msi-message-composition-into-io_apicc.patch genirq-i386-irq-move-msi-message-composition-into-io_apicc.patch genirq-msi-only-build-msi-apicc-on-ia64.patch genirq-x86_64-irq-remove-the-msi-assumption-that-irq-==-vector.patch genirq-i386-irq-remove-the-msi-assumption-that-irq-==-vector.patch genirq-i386-irq-remove-the-msi-assumption-that-irq-==-vector-fix.patch genirq-irq-remove-msi-hacks.patch genirq-irq-generalize-the-check-for-hardirq_bits.patch genirq-x86_64-irq-make-the-external-irq-handlers-report-their-vector-not-the-irq-number.patch genirq-x86_64-irq-make-vector_irq-per-cpu.patch genirq-x86_64-irq-kill-gsi_irq_sharing.patch genirq-x86_64-irq-kill-irq-compression.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html