aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf
diff options
context:
space:
mode:
Diffstat (limited to 'tools/perf')
-rw-r--r--tools/perf/builtin-sched.c113
1 files changed, 37 insertions, 76 deletions
diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c
index 30ef82aca885..a25a023965bb 100644
--- a/tools/perf/builtin-sched.c
+++ b/tools/perf/builtin-sched.c
@@ -729,46 +729,30 @@ struct trace_sched_handler {
729 void (*switch_event)(struct trace_switch_event *, 729 void (*switch_event)(struct trace_switch_event *,
730 struct machine *, 730 struct machine *,
731 struct event_format *, 731 struct event_format *,
732 int cpu, 732 struct perf_sample *sample);
733 u64 timestamp,
734 struct thread *thread);
735 733
736 void (*runtime_event)(struct trace_runtime_event *, 734 void (*runtime_event)(struct trace_runtime_event *,
737 struct machine *, 735 struct machine *,
738 struct event_format *, 736 struct perf_sample *sample);
739 int cpu,
740 u64 timestamp,
741 struct thread *thread);
742 737
743 void (*wakeup_event)(struct trace_wakeup_event *, 738 void (*wakeup_event)(struct trace_wakeup_event *,
744 struct machine *, 739 struct machine *,
745 struct event_format *, 740 struct event_format *,
746 int cpu, 741 struct perf_sample *sample);
747 u64 timestamp,
748 struct thread *thread);
749 742
750 void (*fork_event)(struct trace_fork_event *, 743 void (*fork_event)(struct trace_fork_event *,
751 struct event_format *, 744 struct event_format *event);
752 int cpu,
753 u64 timestamp,
754 struct thread *thread);
755 745
756 void (*migrate_task_event)(struct trace_migrate_task_event *, 746 void (*migrate_task_event)(struct trace_migrate_task_event *,
757 struct machine *machine, 747 struct machine *machine,
758 struct event_format *, 748 struct perf_sample *sample);
759 int cpu,
760 u64 timestamp,
761 struct thread *thread);
762}; 749};
763 750
764 751
765static void 752static void
766replay_wakeup_event(struct trace_wakeup_event *wakeup_event, 753replay_wakeup_event(struct trace_wakeup_event *wakeup_event,
767 struct machine *machine __used, 754 struct machine *machine __used,
768 struct event_format *event, 755 struct event_format *event, struct perf_sample *sample)
769 int cpu __used,
770 u64 timestamp __used,
771 struct thread *thread __used)
772{ 756{
773 struct task_desc *waker, *wakee; 757 struct task_desc *waker, *wakee;
774 758
@@ -784,7 +768,7 @@ replay_wakeup_event(struct trace_wakeup_event *wakeup_event,
784 waker = register_pid(wakeup_event->common_pid, "<unknown>"); 768 waker = register_pid(wakeup_event->common_pid, "<unknown>");
785 wakee = register_pid(wakeup_event->pid, wakeup_event->comm); 769 wakee = register_pid(wakeup_event->pid, wakeup_event->comm);
786 770
787 add_sched_event_wakeup(waker, timestamp, wakee); 771 add_sched_event_wakeup(waker, sample->time, wakee);
788} 772}
789 773
790static u64 cpu_last_switched[MAX_CPUS]; 774static u64 cpu_last_switched[MAX_CPUS];
@@ -793,12 +777,11 @@ static void
793replay_switch_event(struct trace_switch_event *switch_event, 777replay_switch_event(struct trace_switch_event *switch_event,
794 struct machine *machine __used, 778 struct machine *machine __used,
795 struct event_format *event, 779 struct event_format *event,
796 int cpu, 780 struct perf_sample *sample)
797 u64 timestamp,
798 struct thread *thread __used)
799{ 781{
800 struct task_desc *prev, __used *next; 782 struct task_desc *prev, __used *next;
801 u64 timestamp0; 783 u64 timestamp0, timestamp = sample->time;
784 int cpu = sample->cpu;
802 s64 delta; 785 s64 delta;
803 786
804 if (verbose) 787 if (verbose)
@@ -835,10 +818,7 @@ replay_switch_event(struct trace_switch_event *switch_event,
835 818
836static void 819static void
837replay_fork_event(struct trace_fork_event *fork_event, 820replay_fork_event(struct trace_fork_event *fork_event,
838 struct event_format *event, 821 struct event_format *event)
839 int cpu __used,
840 u64 timestamp __used,
841 struct thread *thread __used)
842{ 822{
843 if (verbose) { 823 if (verbose) {
844 printf("sched_fork event %p\n", event); 824 printf("sched_fork event %p\n", event);
@@ -944,10 +924,7 @@ static void thread_atoms_insert(struct thread *thread)
944 924
945static void 925static void
946latency_fork_event(struct trace_fork_event *fork_event __used, 926latency_fork_event(struct trace_fork_event *fork_event __used,
947 struct event_format *event __used, 927 struct event_format *event __used)
948 int cpu __used,
949 u64 timestamp __used,
950 struct thread *thread __used)
951{ 928{
952 /* should insert the newcomer */ 929 /* should insert the newcomer */
953} 930}
@@ -1027,13 +1004,12 @@ static void
1027latency_switch_event(struct trace_switch_event *switch_event, 1004latency_switch_event(struct trace_switch_event *switch_event,
1028 struct machine *machine, 1005 struct machine *machine,
1029 struct event_format *event __used, 1006 struct event_format *event __used,
1030 int cpu, 1007 struct perf_sample *sample)
1031 u64 timestamp,
1032 struct thread *thread __used)
1033{ 1008{
1034 struct work_atoms *out_events, *in_events; 1009 struct work_atoms *out_events, *in_events;
1035 struct thread *sched_out, *sched_in; 1010 struct thread *sched_out, *sched_in;
1036 u64 timestamp0; 1011 u64 timestamp0, timestamp = sample->time;
1012 int cpu = sample->cpu;
1037 s64 delta; 1013 s64 delta;
1038 1014
1039 BUG_ON(cpu >= MAX_CPUS || cpu < 0); 1015 BUG_ON(cpu >= MAX_CPUS || cpu < 0);
@@ -1078,14 +1054,12 @@ latency_switch_event(struct trace_switch_event *switch_event,
1078 1054
1079static void 1055static void
1080latency_runtime_event(struct trace_runtime_event *runtime_event, 1056latency_runtime_event(struct trace_runtime_event *runtime_event,
1081 struct machine *machine, 1057 struct machine *machine, struct perf_sample *sample)
1082 struct event_format *event __used,
1083 int cpu,
1084 u64 timestamp,
1085 struct thread *this_thread __used)
1086{ 1058{
1087 struct thread *thread = machine__findnew_thread(machine, runtime_event->pid); 1059 struct thread *thread = machine__findnew_thread(machine, runtime_event->pid);
1088 struct work_atoms *atoms = thread_atoms_search(&atom_root, thread, &cmp_pid); 1060 struct work_atoms *atoms = thread_atoms_search(&atom_root, thread, &cmp_pid);
1061 u64 timestamp = sample->time;
1062 int cpu = sample->cpu;
1089 1063
1090 BUG_ON(cpu >= MAX_CPUS || cpu < 0); 1064 BUG_ON(cpu >= MAX_CPUS || cpu < 0);
1091 if (!atoms) { 1065 if (!atoms) {
@@ -1101,15 +1075,13 @@ latency_runtime_event(struct trace_runtime_event *runtime_event,
1101 1075
1102static void 1076static void
1103latency_wakeup_event(struct trace_wakeup_event *wakeup_event, 1077latency_wakeup_event(struct trace_wakeup_event *wakeup_event,
1104 struct machine *machine, 1078 struct machine *machine, struct event_format *event __used,
1105 struct event_format *__event __used, 1079 struct perf_sample *sample)
1106 int cpu __used,
1107 u64 timestamp,
1108 struct thread *thread __used)
1109{ 1080{
1110 struct work_atoms *atoms; 1081 struct work_atoms *atoms;
1111 struct work_atom *atom; 1082 struct work_atom *atom;
1112 struct thread *wakee; 1083 struct thread *wakee;
1084 u64 timestamp = sample->time;
1113 1085
1114 /* Note for later, it may be interesting to observe the failing cases */ 1086 /* Note for later, it may be interesting to observe the failing cases */
1115 if (!wakeup_event->success) 1087 if (!wakeup_event->success)
@@ -1149,12 +1121,9 @@ latency_wakeup_event(struct trace_wakeup_event *wakeup_event,
1149 1121
1150static void 1122static void
1151latency_migrate_task_event(struct trace_migrate_task_event *migrate_task_event, 1123latency_migrate_task_event(struct trace_migrate_task_event *migrate_task_event,
1152 struct machine *machine, 1124 struct machine *machine, struct perf_sample *sample)
1153 struct event_format *__event __used,
1154 int cpu __used,
1155 u64 timestamp,
1156 struct thread *thread __used)
1157{ 1125{
1126 u64 timestamp = sample->time;
1158 struct work_atoms *atoms; 1127 struct work_atoms *atoms;
1159 struct work_atom *atom; 1128 struct work_atom *atom;
1160 struct thread *migrant; 1129 struct thread *migrant;
@@ -1364,7 +1333,7 @@ process_sched_wakeup_event(struct perf_tool *tool __used,
1364 struct event_format *event, 1333 struct event_format *event,
1365 struct perf_sample *sample, 1334 struct perf_sample *sample,
1366 struct machine *machine, 1335 struct machine *machine,
1367 struct thread *thread) 1336 struct thread *thread __used)
1368{ 1337{
1369 void *data = sample->raw_data; 1338 void *data = sample->raw_data;
1370 struct trace_wakeup_event wakeup_event; 1339 struct trace_wakeup_event wakeup_event;
@@ -1378,8 +1347,7 @@ process_sched_wakeup_event(struct perf_tool *tool __used,
1378 FILL_FIELD(wakeup_event, cpu, event, data); 1347 FILL_FIELD(wakeup_event, cpu, event, data);
1379 1348
1380 if (trace_handler->wakeup_event) 1349 if (trace_handler->wakeup_event)
1381 trace_handler->wakeup_event(&wakeup_event, machine, event, 1350 trace_handler->wakeup_event(&wakeup_event, machine, event, sample);
1382 sample->cpu, sample->time, thread);
1383} 1351}
1384 1352
1385/* 1353/*
@@ -1399,15 +1367,13 @@ static void
1399map_switch_event(struct trace_switch_event *switch_event, 1367map_switch_event(struct trace_switch_event *switch_event,
1400 struct machine *machine, 1368 struct machine *machine,
1401 struct event_format *event __used, 1369 struct event_format *event __used,
1402 int this_cpu, 1370 struct perf_sample *sample)
1403 u64 timestamp,
1404 struct thread *thread __used)
1405{ 1371{
1406 struct thread *sched_out __used, *sched_in; 1372 struct thread *sched_out __used, *sched_in;
1407 int new_shortname; 1373 int new_shortname;
1408 u64 timestamp0; 1374 u64 timestamp0, timestamp = sample->time;
1409 s64 delta; 1375 s64 delta;
1410 int cpu; 1376 int cpu, this_cpu = sample->cpu;
1411 1377
1412 BUG_ON(this_cpu >= MAX_CPUS || this_cpu < 0); 1378 BUG_ON(this_cpu >= MAX_CPUS || this_cpu < 0);
1413 1379
@@ -1479,7 +1445,7 @@ process_sched_switch_event(struct perf_tool *tool __used,
1479 struct event_format *event, 1445 struct event_format *event,
1480 struct perf_sample *sample, 1446 struct perf_sample *sample,
1481 struct machine *machine, 1447 struct machine *machine,
1482 struct thread *thread) 1448 struct thread *thread __used)
1483{ 1449{
1484 int this_cpu = sample->cpu; 1450 int this_cpu = sample->cpu;
1485 void *data = sample->raw_data; 1451 void *data = sample->raw_data;
@@ -1504,8 +1470,7 @@ process_sched_switch_event(struct perf_tool *tool __used,
1504 nr_context_switch_bugs++; 1470 nr_context_switch_bugs++;
1505 } 1471 }
1506 if (trace_handler->switch_event) 1472 if (trace_handler->switch_event)
1507 trace_handler->switch_event(&switch_event, machine, event, 1473 trace_handler->switch_event(&switch_event, machine, event, sample);
1508 this_cpu, sample->time, thread);
1509 1474
1510 curr_pid[this_cpu] = switch_event.next_pid; 1475 curr_pid[this_cpu] = switch_event.next_pid;
1511} 1476}
@@ -1515,7 +1480,7 @@ process_sched_runtime_event(struct perf_tool *tool __used,
1515 struct event_format *event, 1480 struct event_format *event,
1516 struct perf_sample *sample, 1481 struct perf_sample *sample,
1517 struct machine *machine, 1482 struct machine *machine,
1518 struct thread *thread) 1483 struct thread *thread __used)
1519{ 1484{
1520 void *data = sample->raw_data; 1485 void *data = sample->raw_data;
1521 struct trace_runtime_event runtime_event; 1486 struct trace_runtime_event runtime_event;
@@ -1526,8 +1491,7 @@ process_sched_runtime_event(struct perf_tool *tool __used,
1526 FILL_FIELD(runtime_event, vruntime, event, data); 1491 FILL_FIELD(runtime_event, vruntime, event, data);
1527 1492
1528 if (trace_handler->runtime_event) 1493 if (trace_handler->runtime_event)
1529 trace_handler->runtime_event(&runtime_event, machine, event, 1494 trace_handler->runtime_event(&runtime_event, machine, sample);
1530 sample->cpu, sample->time, thread);
1531} 1495}
1532 1496
1533static void 1497static void
@@ -1535,7 +1499,7 @@ process_sched_fork_event(struct perf_tool *tool __used,
1535 struct event_format *event, 1499 struct event_format *event,
1536 struct perf_sample *sample, 1500 struct perf_sample *sample,
1537 struct machine *machine __used, 1501 struct machine *machine __used,
1538 struct thread *thread) 1502 struct thread *thread __used)
1539{ 1503{
1540 void *data = sample->raw_data; 1504 void *data = sample->raw_data;
1541 struct trace_fork_event fork_event; 1505 struct trace_fork_event fork_event;
@@ -1548,8 +1512,7 @@ process_sched_fork_event(struct perf_tool *tool __used,
1548 FILL_FIELD(fork_event, child_pid, event, data); 1512 FILL_FIELD(fork_event, child_pid, event, data);
1549 1513
1550 if (trace_handler->fork_event) 1514 if (trace_handler->fork_event)
1551 trace_handler->fork_event(&fork_event, event, 1515 trace_handler->fork_event(&fork_event, event);
1552 sample->cpu, sample->time, thread);
1553} 1516}
1554 1517
1555static void 1518static void
@@ -1568,7 +1531,7 @@ process_sched_migrate_task_event(struct perf_tool *tool __used,
1568 struct event_format *event, 1531 struct event_format *event,
1569 struct perf_sample *sample, 1532 struct perf_sample *sample,
1570 struct machine *machine, 1533 struct machine *machine,
1571 struct thread *thread) 1534 struct thread *thread __used)
1572{ 1535{
1573 void *data = sample->raw_data; 1536 void *data = sample->raw_data;
1574 struct trace_migrate_task_event migrate_task_event; 1537 struct trace_migrate_task_event migrate_task_event;
@@ -1581,9 +1544,7 @@ process_sched_migrate_task_event(struct perf_tool *tool __used,
1581 FILL_FIELD(migrate_task_event, cpu, event, data); 1544 FILL_FIELD(migrate_task_event, cpu, event, data);
1582 1545
1583 if (trace_handler->migrate_task_event) 1546 if (trace_handler->migrate_task_event)
1584 trace_handler->migrate_task_event(&migrate_task_event, machine, 1547 trace_handler->migrate_task_event(&migrate_task_event, machine, sample);
1585 event, sample->cpu,
1586 sample->time, thread);
1587} 1548}
1588 1549
1589typedef void (*tracepoint_handler)(struct perf_tool *tool, struct event_format *event, 1550typedef void (*tracepoint_handler)(struct perf_tool *tool, struct event_format *event,