[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH] BUG() on soft lockup upon suspend/resume
Hi, In systems with vcpu > 1, a BUG due to a detected soft lockup seems to be triggered after system resume/suspend. This is probably due to the lack of seqlocking around the region that does the local time processing. The following patch fix this. -- Glauber de Oliveira Costa Red Hat Inc. "Free as in Freedom" --- linux-2.6.18-orig/arch/i386/kernel/time-xen.c 2006-10-06 14:37:41.000000000 -0400 +++ linux-2.6.18.x86_64/arch/i386/kernel/time-xen.c 2006-10-09 17:13:54.000000000 -0400 @@ -666,6 +666,13 @@ irqreturn_t timer_interrupt(int irq, voi clock_was_set(); } + /* Local timer processing (see update_process_times()). */ + run_local_timers(); + if (rcu_pending(cpu)) + rcu_check_callbacks(cpu, user_mode(regs)); + scheduler_tick(); + run_posix_cpu_timers(current); + write_sequnlock(&xtime_lock); /* @@ -709,13 +716,6 @@ irqreturn_t timer_interrupt(int irq, voi (cputime_t)delta_cpu); } - /* Local timer processing (see update_process_times()). */ - run_local_timers(); - if (rcu_pending(cpu)) - rcu_check_callbacks(cpu, user_mode(regs)); - scheduler_tick(); - run_posix_cpu_timers(current); - return IRQ_HANDLED; } _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |