Lines Matching refs:tchart
197 static struct per_pid *find_create_pid(struct timechart *tchart, int pid) in find_create_pid() argument
199 struct per_pid *cursor = tchart->all_data; in find_create_pid()
209 cursor->next = tchart->all_data; in find_create_pid()
210 tchart->all_data = cursor; in find_create_pid()
214 static void pid_set_comm(struct timechart *tchart, int pid, char *comm) in pid_set_comm() argument
218 p = find_create_pid(tchart, pid); in pid_set_comm()
240 static void pid_fork(struct timechart *tchart, int pid, int ppid, u64 timestamp) in pid_fork() argument
243 p = find_create_pid(tchart, pid); in pid_fork()
244 pp = find_create_pid(tchart, ppid); in pid_fork()
247 pid_set_comm(tchart, pid, pp->current->comm); in pid_fork()
256 static void pid_exit(struct timechart *tchart, int pid, u64 timestamp) in pid_exit() argument
259 p = find_create_pid(tchart, pid); in pid_exit()
265 static void pid_put_sample(struct timechart *tchart, int pid, int type, in pid_put_sample() argument
273 p = find_create_pid(tchart, pid); in pid_put_sample()
316 struct timechart *tchart = container_of(tool, struct timechart, tool); in process_comm_event() local
317 pid_set_comm(tchart, event->comm.tid, event->comm.comm); in process_comm_event()
326 struct timechart *tchart = container_of(tool, struct timechart, tool); in process_fork_event() local
327 pid_fork(tchart, event->fork.pid, event->fork.ppid, event->fork.time); in process_fork_event()
336 struct timechart *tchart = container_of(tool, struct timechart, tool); in process_exit_event() local
337 pid_exit(tchart, event->fork.pid, event->fork.time); in process_exit_event()
351 static void c_state_end(struct timechart *tchart, int cpu, u64 timestamp) in c_state_end() argument
363 pwr->next = tchart->power_events; in c_state_end()
365 tchart->power_events = pwr; in c_state_end()
368 static void p_state_change(struct timechart *tchart, int cpu, u64 timestamp, u64 new_freq) in p_state_change() argument
384 pwr->next = tchart->power_events; in p_state_change()
387 pwr->start_time = tchart->first_time; in p_state_change()
389 tchart->power_events = pwr; in p_state_change()
394 if ((u64)new_freq > tchart->max_freq) in p_state_change()
395 tchart->max_freq = new_freq; in p_state_change()
397 if (new_freq < tchart->min_freq || tchart->min_freq == 0) in p_state_change()
398 tchart->min_freq = new_freq; in p_state_change()
400 if (new_freq == tchart->max_freq - 1000) in p_state_change()
401 tchart->turbo_frequency = tchart->max_freq; in p_state_change()
404 static void sched_wakeup(struct timechart *tchart, int cpu, u64 timestamp, in sched_wakeup() argument
421 we->next = tchart->wake_events; in sched_wakeup()
422 tchart->wake_events = we; in sched_wakeup()
423 p = find_create_pid(tchart, we->wakee); in sched_wakeup()
430 pid_put_sample(tchart, p->pid, p->current->state, cpu, in sched_wakeup()
437 static void sched_switch(struct timechart *tchart, int cpu, u64 timestamp, in sched_switch() argument
443 prev_p = find_create_pid(tchart, prev_pid); in sched_switch()
445 p = find_create_pid(tchart, next_pid); in sched_switch()
448 pid_put_sample(tchart, prev_pid, TYPE_RUNNING, cpu, in sched_switch()
453 pid_put_sample(tchart, next_pid, p->current->state, cpu, in sched_switch()
549 typedef int (*tracepoint_handler)(struct timechart *tchart,
560 struct timechart *tchart = container_of(tool, struct timechart, tool); in process_sample_event() local
563 if (!tchart->first_time || tchart->first_time > sample->time) in process_sample_event()
564 tchart->first_time = sample->time; in process_sample_event()
565 if (tchart->last_time < sample->time) in process_sample_event()
566 tchart->last_time = sample->time; in process_sample_event()
571 return f(tchart, evsel, sample, in process_sample_event()
579 process_sample_cpu_idle(struct timechart *tchart __maybe_unused, in process_sample_cpu_idle()
588 c_state_end(tchart, cpu_id, sample->time); in process_sample_cpu_idle()
595 process_sample_cpu_frequency(struct timechart *tchart, in process_sample_cpu_frequency() argument
603 p_state_change(tchart, cpu_id, sample->time, state); in process_sample_cpu_frequency()
608 process_sample_sched_wakeup(struct timechart *tchart, in process_sample_sched_wakeup() argument
617 sched_wakeup(tchart, sample->cpu, sample->time, waker, wakee, flags, backtrace); in process_sample_sched_wakeup()
622 process_sample_sched_switch(struct timechart *tchart, in process_sample_sched_switch() argument
631 sched_switch(tchart, sample->cpu, sample->time, prev_pid, next_pid, in process_sample_sched_switch()
638 process_sample_power_start(struct timechart *tchart __maybe_unused, in process_sample_power_start()
651 process_sample_power_end(struct timechart *tchart, in process_sample_power_end() argument
656 c_state_end(tchart, sample->cpu, sample->time); in process_sample_power_end()
661 process_sample_power_frequency(struct timechart *tchart, in process_sample_power_frequency() argument
669 p_state_change(tchart, cpu_id, sample->time, value); in process_sample_power_frequency()
678 static void end_sample_processing(struct timechart *tchart) in end_sample_processing() argument
683 for (cpu = 0; cpu <= tchart->numcpus; cpu++) { in end_sample_processing()
692 pwr->end_time = tchart->last_time; in end_sample_processing()
695 pwr->next = tchart->power_events; in end_sample_processing()
697 tchart->power_events = pwr; in end_sample_processing()
707 pwr->end_time = tchart->last_time; in end_sample_processing()
710 pwr->next = tchart->power_events; in end_sample_processing()
713 pwr->start_time = tchart->first_time; in end_sample_processing()
715 pwr->state = tchart->min_freq; in end_sample_processing()
716 tchart->power_events = pwr; in end_sample_processing()
720 static int pid_begin_io_sample(struct timechart *tchart, int pid, int type, in pid_begin_io_sample() argument
723 struct per_pid *p = find_create_pid(tchart, pid); in pid_begin_io_sample()
765 static int pid_end_io_sample(struct timechart *tchart, int pid, int type, in pid_end_io_sample() argument
768 struct per_pid *p = find_create_pid(tchart, pid); in pid_end_io_sample()
798 if (sample->end_time - sample->start_time < tchart->min_time) in pid_end_io_sample()
799 sample->end_time = sample->start_time + tchart->min_time; in pid_end_io_sample()
825 prev->end_time + tchart->merge_dist >= sample->start_time) { in pid_end_io_sample()
838 tchart->io_events++; in pid_end_io_sample()
844 process_enter_read(struct timechart *tchart, in process_enter_read() argument
849 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_READ, in process_enter_read()
854 process_exit_read(struct timechart *tchart, in process_exit_read() argument
859 return pid_end_io_sample(tchart, sample->tid, IOTYPE_READ, in process_exit_read()
864 process_enter_write(struct timechart *tchart, in process_enter_write() argument
869 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_WRITE, in process_enter_write()
874 process_exit_write(struct timechart *tchart, in process_exit_write() argument
879 return pid_end_io_sample(tchart, sample->tid, IOTYPE_WRITE, in process_exit_write()
884 process_enter_sync(struct timechart *tchart, in process_enter_sync() argument
889 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_SYNC, in process_enter_sync()
894 process_exit_sync(struct timechart *tchart, in process_exit_sync() argument
899 return pid_end_io_sample(tchart, sample->tid, IOTYPE_SYNC, in process_exit_sync()
904 process_enter_tx(struct timechart *tchart, in process_enter_tx() argument
909 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_TX, in process_enter_tx()
914 process_exit_tx(struct timechart *tchart, in process_exit_tx() argument
919 return pid_end_io_sample(tchart, sample->tid, IOTYPE_TX, in process_exit_tx()
924 process_enter_rx(struct timechart *tchart, in process_enter_rx() argument
929 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_RX, in process_enter_rx()
934 process_exit_rx(struct timechart *tchart, in process_exit_rx() argument
939 return pid_end_io_sample(tchart, sample->tid, IOTYPE_RX, in process_exit_rx()
944 process_enter_poll(struct timechart *tchart, in process_enter_poll() argument
949 return pid_begin_io_sample(tchart, sample->tid, IOTYPE_POLL, in process_enter_poll()
954 process_exit_poll(struct timechart *tchart, in process_exit_poll() argument
959 return pid_end_io_sample(tchart, sample->tid, IOTYPE_POLL, in process_exit_poll()
966 static void sort_pids(struct timechart *tchart) in sort_pids() argument
973 while (tchart->all_data) { in sort_pids()
974 p = tchart->all_data; in sort_pids()
975 tchart->all_data = p->next; in sort_pids()
1008 tchart->all_data = new_list; in sort_pids()
1012 static void draw_c_p_states(struct timechart *tchart) in draw_c_p_states() argument
1015 pwr = tchart->power_events; in draw_c_p_states()
1026 pwr = tchart->power_events; in draw_c_p_states()
1030 pwr->state = tchart->min_freq; in draw_c_p_states()
1037 static void draw_wakeups(struct timechart *tchart) in draw_wakeups() argument
1043 we = tchart->wake_events; in draw_wakeups()
1049 p = tchart->all_data; in draw_wakeups()
1105 static void draw_cpu_usage(struct timechart *tchart) in draw_cpu_usage() argument
1110 p = tchart->all_data; in draw_cpu_usage()
1133 static void draw_io_bars(struct timechart *tchart) in draw_io_bars() argument
1143 p = tchart->all_data; in draw_io_bars()
1158 if (tchart->skip_eagain && in draw_io_bars()
1248 static void draw_process_bars(struct timechart *tchart) in draw_process_bars() argument
1255 Y = 2 * tchart->numcpus + 2; in draw_process_bars()
1257 p = tchart->all_data; in draw_process_bars()
1337 static int determine_display_tasks_filtered(struct timechart *tchart) in determine_display_tasks_filtered() argument
1343 p = tchart->all_data; in determine_display_tasks_filtered()
1347 p->start_time = tchart->first_time; in determine_display_tasks_filtered()
1351 p->end_time = tchart->last_time; in determine_display_tasks_filtered()
1359 c->start_time = tchart->first_time; in determine_display_tasks_filtered()
1368 c->end_time = tchart->last_time; in determine_display_tasks_filtered()
1377 static int determine_display_tasks(struct timechart *tchart, u64 threshold) in determine_display_tasks() argument
1383 p = tchart->all_data; in determine_display_tasks()
1387 p->start_time = tchart->first_time; in determine_display_tasks()
1391 p->end_time = tchart->last_time; in determine_display_tasks()
1401 c->start_time = tchart->first_time; in determine_display_tasks()
1409 c->end_time = tchart->last_time; in determine_display_tasks()
1453 static void write_svg_file(struct timechart *tchart, const char *filename) in write_svg_file() argument
1457 int thresh = tchart->io_events ? BYTES_THRESH : TIME_THRESH; in write_svg_file()
1459 if (tchart->power_only) in write_svg_file()
1460 tchart->proc_num = 0; in write_svg_file()
1466 count = determine_display_tasks_filtered(tchart); in write_svg_file()
1467 else if (tchart->io_events) in write_svg_file()
1468 count = determine_display_io_tasks(tchart, thresh); in write_svg_file()
1470 count = determine_display_tasks(tchart, thresh); in write_svg_file()
1472 } while (!process_filter && thresh && count < tchart->proc_num); in write_svg_file()
1474 if (!tchart->proc_num) in write_svg_file()
1477 if (tchart->io_events) { in write_svg_file()
1478 open_svg(filename, 0, count, tchart->first_time, tchart->last_time); in write_svg_file()
1483 draw_io_bars(tchart); in write_svg_file()
1485 open_svg(filename, tchart->numcpus, count, tchart->first_time, tchart->last_time); in write_svg_file()
1491 for (i = 0; i < tchart->numcpus; i++) in write_svg_file()
1492 svg_cpu_box(i, tchart->max_freq, tchart->turbo_frequency); in write_svg_file()
1494 draw_cpu_usage(tchart); in write_svg_file()
1495 if (tchart->proc_num) in write_svg_file()
1496 draw_process_bars(tchart); in write_svg_file()
1497 if (!tchart->tasks_only) in write_svg_file()
1498 draw_c_p_states(tchart); in write_svg_file()
1499 if (tchart->proc_num) in write_svg_file()
1500 draw_wakeups(tchart); in write_svg_file()
1512 struct timechart *tchart = data; in process_header() local
1516 tchart->numcpus = ph->env.nr_cpus_avail; in process_header()
1520 if (!tchart->topology) in process_header()
1537 static int __cmd_timechart(struct timechart *tchart, const char *output_name) in __cmd_timechart() argument
1603 .force = tchart->force, in __cmd_timechart()
1607 &tchart->tool); in __cmd_timechart()
1617 tchart, in __cmd_timechart()
1633 end_sample_processing(tchart); in __cmd_timechart()
1635 sort_pids(tchart); in __cmd_timechart()
1637 write_svg_file(tchart, output_name); in __cmd_timechart()
1640 (tchart->last_time - tchart->first_time) / 1000000000.0, output_name); in __cmd_timechart()
1779 static int timechart__record(struct timechart *tchart, int argc, const char **argv) in timechart__record() argument
1827 if (tchart->power_only) in timechart__record()
1830 if (tchart->tasks_only) { in timechart__record()
1835 if (!tchart->with_backtrace) in timechart__record()
1922 struct timechart tchart = { in cmd_timechart() local
1942 OPT_BOOLEAN('P', "power-only", &tchart.power_only, "output power data only"), in cmd_timechart()
1943 OPT_BOOLEAN('T', "tasks-only", &tchart.tasks_only, in cmd_timechart()
1950 OPT_INTEGER('n', "proc-num", &tchart.proc_num, in cmd_timechart()
1952 OPT_BOOLEAN('t', "topology", &tchart.topology, in cmd_timechart()
1954 OPT_BOOLEAN(0, "io-skip-eagain", &tchart.skip_eagain, in cmd_timechart()
1956 OPT_CALLBACK(0, "io-min-time", &tchart.min_time, "time", in cmd_timechart()
1959 OPT_CALLBACK(0, "io-merge-dist", &tchart.merge_dist, "time", in cmd_timechart()
1962 OPT_BOOLEAN('f', "force", &tchart.force, "don't complain, do it"), in cmd_timechart()
1972 OPT_BOOLEAN('P', "power-only", &tchart.power_only, "output power data only"), in cmd_timechart()
1973 OPT_BOOLEAN('T', "tasks-only", &tchart.tasks_only, in cmd_timechart()
1975 OPT_BOOLEAN('I', "io-only", &tchart.io_only, in cmd_timechart()
1977 OPT_BOOLEAN('g', "callchain", &tchart.with_backtrace, "record callchain"), in cmd_timechart()
1987 if (tchart.power_only && tchart.tasks_only) { in cmd_timechart()
1997 if (tchart.power_only && tchart.tasks_only) { in cmd_timechart()
2002 if (tchart.io_only) in cmd_timechart()
2005 return timechart__record(&tchart, argc, argv); in cmd_timechart()
2011 return __cmd_timechart(&tchart, output_name); in cmd_timechart()