aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/oprofile/buffer_sync.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/oprofile/buffer_sync.c')
-rw-r--r--drivers/oprofile/buffer_sync.c22
1 files changed, 14 insertions, 8 deletions
diff --git a/drivers/oprofile/buffer_sync.c b/drivers/oprofile/buffer_sync.c
index 774b081b9b7f..7d61ae8ee8cf 100644
--- a/drivers/oprofile/buffer_sync.c
+++ b/drivers/oprofile/buffer_sync.c
@@ -561,6 +561,7 @@ void sync_buffer(int cpu)
561{ 561{
562 struct oprofile_cpu_buffer *cpu_buf = &per_cpu(cpu_buffer, cpu); 562 struct oprofile_cpu_buffer *cpu_buf = &per_cpu(cpu_buffer, cpu);
563 struct mm_struct *mm = NULL; 563 struct mm_struct *mm = NULL;
564 struct mm_struct *oldmm;
564 struct task_struct *new; 565 struct task_struct *new;
565 unsigned long cookie = 0; 566 unsigned long cookie = 0;
566 int in_kernel = 1; 567 int in_kernel = 1;
@@ -586,34 +587,39 @@ void sync_buffer(int cpu)
586 struct op_sample *s = &cpu_buf->buffer[cpu_buf->tail_pos]; 587 struct op_sample *s = &cpu_buf->buffer[cpu_buf->tail_pos];
587 588
588 if (is_code(s->eip)) { 589 if (is_code(s->eip)) {
589 if (s->event <= CPU_IS_KERNEL) { 590 switch (s->event) {
591 case 0:
592 case CPU_IS_KERNEL:
590 /* kernel/userspace switch */ 593 /* kernel/userspace switch */
591 in_kernel = s->event; 594 in_kernel = s->event;
592 if (state == sb_buffer_start) 595 if (state == sb_buffer_start)
593 state = sb_sample_start; 596 state = sb_sample_start;
594 add_kernel_ctx_switch(s->event); 597 add_kernel_ctx_switch(s->event);
595 } else if (s->event == CPU_TRACE_BEGIN) { 598 break;
599 case CPU_TRACE_BEGIN:
596 state = sb_bt_start; 600 state = sb_bt_start;
597 add_trace_begin(); 601 add_trace_begin();
602 break;
598#ifdef CONFIG_OPROFILE_IBS 603#ifdef CONFIG_OPROFILE_IBS
599 } else if (s->event == IBS_FETCH_BEGIN) { 604 case IBS_FETCH_BEGIN:
600 state = sb_bt_start; 605 state = sb_bt_start;
601 add_ibs_begin(cpu_buf, IBS_FETCH_CODE, mm); 606 add_ibs_begin(cpu_buf, IBS_FETCH_CODE, mm);
602 } else if (s->event == IBS_OP_BEGIN) { 607 break;
608 case IBS_OP_BEGIN:
603 state = sb_bt_start; 609 state = sb_bt_start;
604 add_ibs_begin(cpu_buf, IBS_OP_CODE, mm); 610 add_ibs_begin(cpu_buf, IBS_OP_CODE, mm);
611 break;
605#endif 612#endif
606 } else { 613 default:
607 struct mm_struct *oldmm = mm;
608
609 /* userspace context switch */ 614 /* userspace context switch */
615 oldmm = mm;
610 new = (struct task_struct *)s->event; 616 new = (struct task_struct *)s->event;
611
612 release_mm(oldmm); 617 release_mm(oldmm);
613 mm = take_tasks_mm(new); 618 mm = take_tasks_mm(new);
614 if (mm != oldmm) 619 if (mm != oldmm)
615 cookie = get_exec_dcookie(mm); 620 cookie = get_exec_dcookie(mm);
616 add_user_ctx_switch(new, cookie); 621 add_user_ctx_switch(new, cookie);
622 break;
617 } 623 }
618 } else if (state >= sb_bt_start && 624 } else if (state >= sb_bt_start &&
619 !add_sample(mm, s, in_kernel)) { 625 !add_sample(mm, s, in_kernel)) {