Dave, On Wed, 10 Apr 2013, Dave Hansen wrote:
> I think I got a full trace this time: > > http://sr71.net/~dave/linux/bigbox-trace.1365621899.txt.gz > > The last timestamp is pretty close to the timestamp on the console: > > [ 2071.033434] smpboot_thread_fn(): > [ 2071.033455] smpboot_thread_fn() cpu: 22 159 > [ 2071.033470] td->cpu: 22 > [ 2071.033475] smp_processor_id(): 21 > [ 2071.033486] comm: migration/%u Yes, that's helpful. Though it makes my mind boggle: migration/22-4335 [021] d.h. 2071.020530: sched_wakeup: comm=migration/21 pid=4323 prio=0 success=1 target_cpu=021^M migration/22-4335 [021] d... 2071.020541: sched_switch: prev_comm=migration/22 prev_pid=4335 prev_prio=0 prev_state=0x200 ==> next_comm=migration/21 next_pid=4323 next_prio=0^M migration/21-4323 [021] d... 2071.026110: sched_switch: prev_comm=migration/21 prev_pid=4323 prev_prio=0 prev_state=S ==> next_comm=migration/22 next_pid=4335 next_prio=0^M migration/22-4335 [021] .... 2071.033422: smpboot_thread_fn <-kthread^M So the migration thread schedules out with state TASK_PARKED and gets scheduled back in right away without a wakeup. Srivatsa was about right, that this might be related to the sched_set_stop_task() call, but the changelog led completely down the wrong road. So the issue is: CPU14 CPU21 create_thread(for CPU22) park_thread() wait_for_completion() park_me() complete() sched_set_stop_task() schedule(TASK_PARKED) The sched_set_stop_task() call is issued while the task is on the runqueue of CPU21 and that confuses the hell out of the stop_task class on that cpu. So as we have to synchronize the state for the bind call (the issue observed by Borislav) we need to do the same before issuing sched_set_stop_task(). Delta patch below. Thanks, tglx --- Index: linux-2.6/include/trace/events/sched.h =================================================================== --- linux-2.6.orig/include/trace/events/sched.h +++ linux-2.6/include/trace/events/sched.h @@ -147,7 +147,7 @@ TRACE_EVENT(sched_switch, __print_flags(__entry->prev_state & (TASK_STATE_MAX-1), "|", { 1, "S"} , { 2, "D" }, { 4, "T" }, { 8, "t" }, { 16, "Z" }, { 32, "X" }, { 64, "x" }, - { 128, "W" }) : "R", + { 128, "K" }, { 256, "W" }, { 512, "P" }) : "R", __entry->prev_state & TASK_STATE_MAX ? "+" : "", __entry->next_comm, __entry->next_pid, __entry->next_prio) ); Index: linux-2.6/kernel/smpboot.c =================================================================== --- linux-2.6.orig/kernel/smpboot.c +++ linux-2.6/kernel/smpboot.c @@ -185,8 +185,18 @@ __smpboot_create_thread(struct smp_hotpl } get_task_struct(tsk); *per_cpu_ptr(ht->store, cpu) = tsk; - if (ht->create) - ht->create(cpu); + if (ht->create) { + /* + * Make sure that the task has actually scheduled out + * into park position, before calling the create + * callback. At least the migration thread callback + * requires that the task is off the runqueue. + */ + if (!wait_task_inactive(tsk, TASK_PARKED)) + WARN_ON(1); + else + ht->create(cpu); + } return 0; } -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/