The patch titled minimal alpha pt_regs fixes has been added to the -mm tree. Its filename is minimal-alpha-pt_regs-fixes.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: minimal alpha pt_regs fixes From: Al Viro <viro@xxxxxxxxxxxxxxxx> Signed-off-by: Al Viro <viro@xxxxxxxxxxxxxxxxxx> Cc: Richard Henderson <rth@xxxxxxxxxxx> Cc: Ivan Kokshaysky <ink@xxxxxxxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/alpha/kernel/irq.c | 5 ++++- arch/alpha/kernel/proto.h | 2 +- arch/alpha/kernel/smp.c | 6 +++++- arch/alpha/kernel/time.c | 6 +++--- include/asm-alpha/irq_regs.h | 1 + 5 files changed, 14 insertions(+), 6 deletions(-) diff -puN arch/alpha/kernel/irq.c~minimal-alpha-pt_regs-fixes arch/alpha/kernel/irq.c --- a/arch/alpha/kernel/irq.c~minimal-alpha-pt_regs-fixes +++ a/arch/alpha/kernel/irq.c @@ -129,6 +129,7 @@ unlock: void handle_irq(int irq, struct pt_regs * regs) { + struct pt_regs *old_regs; /* * We ack quickly, we don't want the irq controller * thinking we're snobs just because some other CPU has @@ -149,6 +150,7 @@ handle_irq(int irq, struct pt_regs * reg return; } + old_regs = set_irq_regs(regs); irq_enter(); /* * __do_IRQ() must be called with IPL_MAX. Note that we do not @@ -157,6 +159,7 @@ handle_irq(int irq, struct pt_regs * reg * at IPL 0. */ local_irq_disable(); - __do_IRQ(irq, regs); + __do_IRQ(irq); irq_exit(); + set_irq_regs(old_regs); } diff -puN arch/alpha/kernel/proto.h~minimal-alpha-pt_regs-fixes arch/alpha/kernel/proto.h --- a/arch/alpha/kernel/proto.h~minimal-alpha-pt_regs-fixes +++ a/arch/alpha/kernel/proto.h @@ -133,7 +133,7 @@ extern void smp_percpu_timer_interrupt(s /* extern void reset_for_srm(void); */ /* time.c */ -extern irqreturn_t timer_interrupt(int irq, void *dev, struct pt_regs * regs); +extern irqreturn_t timer_interrupt(int irq, void *dev); extern void common_init_rtc(void); extern unsigned long est_cycle_freq; diff -puN arch/alpha/kernel/smp.c~minimal-alpha-pt_regs-fixes arch/alpha/kernel/smp.c --- a/arch/alpha/kernel/smp.c~minimal-alpha-pt_regs-fixes +++ a/arch/alpha/kernel/smp.c @@ -515,12 +515,15 @@ smp_cpus_done(unsigned int max_cpus) void smp_percpu_timer_interrupt(struct pt_regs *regs) { + struct pt_regs *old_regs; int cpu = smp_processor_id(); unsigned long user = user_mode(regs); struct cpuinfo_alpha *data = &cpu_data[cpu]; + old_regs = set_irq_regs(regs); + /* Record kernel PC. */ - profile_tick(CPU_PROFILING, regs); + profile_tick(CPU_PROFILING); if (!--data->prof_counter) { /* We need to make like a normal interrupt -- otherwise @@ -534,6 +537,7 @@ smp_percpu_timer_interrupt(struct pt_reg irq_exit(); } + set_irq_regs(old_regs); } int __init diff -puN arch/alpha/kernel/time.c~minimal-alpha-pt_regs-fixes arch/alpha/kernel/time.c --- a/arch/alpha/kernel/time.c~minimal-alpha-pt_regs-fixes +++ a/arch/alpha/kernel/time.c @@ -104,7 +104,7 @@ unsigned long long sched_clock(void) * timer_interrupt() needs to keep up the real-time clock, * as well as call the "do_timer()" routine every clocktick */ -irqreturn_t timer_interrupt(int irq, void *dev, struct pt_regs * regs) +irqreturn_t timer_interrupt(int irq, void *dev) { unsigned long delta; __u32 now; @@ -112,7 +112,7 @@ irqreturn_t timer_interrupt(int irq, voi #ifndef CONFIG_SMP /* Not SMP, do kernel PC profiling here. */ - profile_tick(CPU_PROFILING, regs); + profile_tick(CPU_PROFILING); #endif write_seqlock(&xtime_lock); @@ -132,7 +132,7 @@ irqreturn_t timer_interrupt(int irq, voi while (nticks > 0) { do_timer(1); #ifndef CONFIG_SMP - update_process_times(user_mode(regs)); + update_process_times(user_mode(get_irq_regs())); #endif nticks--; } diff -puN /dev/null include/asm-alpha/irq_regs.h --- /dev/null +++ a/include/asm-alpha/irq_regs.h @@ -0,0 +1 @@ +#include <asm-generic/irq_regs.h> _ Patches currently in -mm which might be from viro@xxxxxxxxxxxxxxxx are origin.patch minimal-alpha-pt_regs-fixes.patch slab-leaks3-default-y.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