Lines Matching full:sample
519 pr_err("Display of symbols requested but neither sample IP nor " in evsel__check_attr()
520 "sample address\navailable. Hence, no addresses to convert " in evsel__check_attr()
535 pr_err("Display of source line number requested but sample IP is not\n" in evsel__check_attr()
795 static int perf_sample__fprintf_iregs(struct perf_sample *sample, in perf_sample__fprintf_iregs() argument
798 if (!sample->intr_regs) in perf_sample__fprintf_iregs()
801 return perf_sample__fprintf_regs(perf_sample__intr_regs(sample), in perf_sample__fprintf_iregs()
805 static int perf_sample__fprintf_uregs(struct perf_sample *sample, in perf_sample__fprintf_uregs() argument
808 if (!sample->user_regs) in perf_sample__fprintf_uregs()
811 return perf_sample__fprintf_regs(perf_sample__user_regs(sample), in perf_sample__fprintf_uregs()
816 struct perf_sample *sample, in perf_sample__fprintf_start() argument
839 if (PRINT_FIELD(MACHINE_PID) && sample->machine_pid) in perf_sample__fprintf_start()
840 printed += fprintf(fp, "VM:%5d ", sample->machine_pid); in perf_sample__fprintf_start()
843 if (PRINT_FIELD(VCPU) && sample->machine_pid) in perf_sample__fprintf_start()
844 printed += fprintf(fp, "VCPU:%03d ", sample->vcpu); in perf_sample__fprintf_start()
858 printed += fprintf(fp, "%7d/%-7d ", sample->pid, sample->tid); in perf_sample__fprintf_start()
860 printed += fprintf(fp, "%7d ", sample->pid); in perf_sample__fprintf_start()
862 printed += fprintf(fp, "%7d ", sample->tid); in perf_sample__fprintf_start()
866 printed += fprintf(fp, "%3d ", sample->cpu); in perf_sample__fprintf_start()
868 printed += fprintf(fp, "[%03d] ", sample->cpu); in perf_sample__fprintf_start()
875 (sample->misc & PERF_RECORD_MISC_##m) == PERF_RECORD_MISC_##m in perf_sample__fprintf_start()
902 if (sample->misc & PERF_RECORD_MISC_SWITCH_OUT_PREEMPT) in perf_sample__fprintf_start()
916 tod_scnprintf(script, tstr, sizeof(tstr), sample->time); in perf_sample__fprintf_start()
921 u64 t = sample->time; in perf_sample__fprintf_start()
924 initial_time = sample->time; in perf_sample__fprintf_start()
925 t = sample->time - initial_time; in perf_sample__fprintf_start()
928 t = sample->time - previous_time; in perf_sample__fprintf_start()
932 previous_time = sample->time; in perf_sample__fprintf_start()
976 static int perf_sample__fprintf_brstack(struct perf_sample *sample, in perf_sample__fprintf_brstack() argument
980 struct branch_stack *br = sample->branch_stack; in perf_sample__fprintf_brstack()
981 struct branch_entry *entries = perf_sample__branch_entries(sample); in perf_sample__fprintf_brstack()
998 thread__find_map_fb(thread, sample->cpumode, from, &alf); in perf_sample__fprintf_brstack()
999 thread__find_map_fb(thread, sample->cpumode, to, &alt); in perf_sample__fprintf_brstack()
1015 static int perf_sample__fprintf_brstacksym(struct perf_sample *sample, in perf_sample__fprintf_brstacksym() argument
1019 struct branch_stack *br = sample->branch_stack; in perf_sample__fprintf_brstacksym()
1020 struct branch_entry *entries = perf_sample__branch_entries(sample); in perf_sample__fprintf_brstacksym()
1035 thread__find_symbol_fb(thread, sample->cpumode, from, &alf); in perf_sample__fprintf_brstacksym()
1036 thread__find_symbol_fb(thread, sample->cpumode, to, &alt); in perf_sample__fprintf_brstacksym()
1053 static int perf_sample__fprintf_brstackoff(struct perf_sample *sample, in perf_sample__fprintf_brstackoff() argument
1057 struct branch_stack *br = sample->branch_stack; in perf_sample__fprintf_brstackoff()
1058 struct branch_entry *entries = perf_sample__branch_entries(sample); in perf_sample__fprintf_brstackoff()
1073 if (thread__find_map_fb(thread, sample->cpumode, from, &alf) && in perf_sample__fprintf_brstackoff()
1077 if (thread__find_map_fb(thread, sample->cpumode, to, &alt) && in perf_sample__fprintf_brstackoff()
1351 static int perf_sample__fprintf_brstackinsn(struct perf_sample *sample, in perf_sample__fprintf_brstackinsn() argument
1357 struct branch_stack *br = sample->branch_stack; in perf_sample__fprintf_brstackinsn()
1358 struct branch_entry *entries = perf_sample__branch_entries(sample); in perf_sample__fprintf_brstackinsn()
1376 x.cpu = sample->cpu; in perf_sample__fprintf_brstackinsn()
1378 if (PRINT_FIELD(BRCNTR) && sample->branch_stack_cntr) in perf_sample__fprintf_brstackinsn()
1379 br_cntr = sample->branch_stack_cntr[nr - 1]; in perf_sample__fprintf_brstackinsn()
1422 if (PRINT_FIELD(BRCNTR) && sample->branch_stack_cntr) in perf_sample__fprintf_brstackinsn()
1423 br_cntr = sample->branch_stack_cntr[i]; in perf_sample__fprintf_brstackinsn()
1451 if (entries[0].from == sample->ip) in perf_sample__fprintf_brstackinsn()
1457 * Print final block up to sample in perf_sample__fprintf_brstackinsn()
1461 * between final branch and sample. When this happens just in perf_sample__fprintf_brstackinsn()
1465 end = sample->ip; in perf_sample__fprintf_brstackinsn()
1474 len = grab_bb(buffer, sample->ip, sample->ip, in perf_sample__fprintf_brstackinsn()
1479 printed += fprintf(fp, "\t%016" PRIx64 "\t", sample->ip); in perf_sample__fprintf_brstackinsn()
1480 printed += any_dump_insn(evsel, &x, sample->ip, buffer, len, &ilen, fp); in perf_sample__fprintf_brstackinsn()
1485 print_srccode(thread, x.cpumode, sample->ip); in perf_sample__fprintf_brstackinsn()
1499 && start + off != sample->ip) { in perf_sample__fprintf_brstackinsn()
1503 printed += fprintf(fp, "\t... not reaching sample ...\n"); in perf_sample__fprintf_brstackinsn()
1513 static int perf_sample__fprintf_addr(struct perf_sample *sample, in perf_sample__fprintf_addr() argument
1518 int printed = fprintf(fp, "%16" PRIx64, sample->addr); in perf_sample__fprintf_addr()
1524 thread__resolve(thread, &al, sample); in perf_sample__fprintf_addr()
1541 static const char *resolve_branch_sym(struct perf_sample *sample, in resolve_branch_sym() argument
1550 if (sample->flags & (PERF_IP_FLAG_CALL | PERF_IP_FLAG_TRACE_BEGIN)) { in resolve_branch_sym()
1553 thread__resolve(thread, addr_al, sample); in resolve_branch_sym()
1557 *ip = sample->addr; in resolve_branch_sym()
1559 *ip = sample->addr; in resolve_branch_sym()
1561 } else if (sample->flags & (PERF_IP_FLAG_RETURN | PERF_IP_FLAG_TRACE_END)) { in resolve_branch_sym()
1565 *ip = sample->ip; in resolve_branch_sym()
1570 static int perf_sample__fprintf_callindent(struct perf_sample *sample, in perf_sample__fprintf_callindent() argument
1577 size_t depth = thread_stack__depth(thread, sample->cpu); in perf_sample__fprintf_callindent()
1588 if (thread__ts(thread) && sample->flags & PERF_IP_FLAG_RETURN) in perf_sample__fprintf_callindent()
1591 name = resolve_branch_sym(sample, evsel, thread, al, addr_al, &ip); in perf_sample__fprintf_callindent()
1620 static int perf_sample__fprintf_insn(struct perf_sample *sample, in perf_sample__fprintf_insn() argument
1629 script_fetch_insn(sample, thread, machine, native_arch); in perf_sample__fprintf_insn()
1632 printed += fprintf(fp, " ilen: %d", sample->insn_len); in perf_sample__fprintf_insn()
1633 if (PRINT_FIELD(INSN) && sample->insn_len) { in perf_sample__fprintf_insn()
1635 printed += sample__fprintf_insn_raw(sample, fp); in perf_sample__fprintf_insn()
1637 if (PRINT_FIELD(DISASM) && sample->insn_len) { in perf_sample__fprintf_insn()
1639 printed += sample__fprintf_insn_asm(sample, thread, machine, fp, al); in perf_sample__fprintf_insn()
1642 printed += perf_sample__fprintf_brstackinsn(sample, evsel, thread, attr, machine, fp); in perf_sample__fprintf_insn()
1647 static int perf_sample__fprintf_ipc(struct perf_sample *sample, in perf_sample__fprintf_ipc() argument
1652 if (!PRINT_FIELD(IPC) || !sample->cyc_cnt || !sample->insn_cnt) in perf_sample__fprintf_ipc()
1655 ipc = (sample->insn_cnt * 100) / sample->cyc_cnt; in perf_sample__fprintf_ipc()
1658 ipc / 100, ipc % 100, sample->insn_cnt, sample->cyc_cnt); in perf_sample__fprintf_ipc()
1661 static int perf_sample__fprintf_bts(struct perf_sample *sample, in perf_sample__fprintf_bts() argument
1674 printed += perf_sample__fprintf_callindent(sample, evsel, thread, al, addr_al, fp); in perf_sample__fprintf_bts()
1681 if (symbol_conf.use_callchain && sample->callchain) { in perf_sample__fprintf_bts()
1684 sample, NULL, NULL, in perf_sample__fprintf_bts()
1697 printed += sample__fprintf_sym(sample, al, 0, print_opts, cursor, in perf_sample__fprintf_bts()
1706 printed += perf_sample__fprintf_addr(sample, thread, evsel, fp); in perf_sample__fprintf_bts()
1709 printed += perf_sample__fprintf_ipc(sample, evsel, fp); in perf_sample__fprintf_bts()
1714 printed += perf_sample__fprintf_insn(sample, evsel, attr, thread, machine, fp, al); in perf_sample__fprintf_bts()
1807 static int perf_sample__fprintf_bpf_output(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_bpf_output() argument
1809 unsigned int nr_bytes = sample->raw_size; in perf_sample__fprintf_bpf_output()
1811 int printed = binary__fprintf(sample->raw_data, nr_bytes, 8, in perf_sample__fprintf_bpf_output()
1815 printed += fprintf(fp, "%17s \"%s\"\n", "BPF string:", (char *)(sample->raw_data)); in perf_sample__fprintf_bpf_output()
1854 static int perf_sample__fprintf_synth_ptwrite(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_ptwrite() argument
1856 struct perf_synth_intel_ptwrite *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_ptwrite()
1861 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_ptwrite()
1874 static int perf_sample__fprintf_synth_mwait(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_mwait() argument
1876 struct perf_synth_intel_mwait *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_mwait()
1879 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_mwait()
1887 static int perf_sample__fprintf_synth_pwre(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_pwre() argument
1889 struct perf_synth_intel_pwre *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_pwre()
1892 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_pwre()
1900 static int perf_sample__fprintf_synth_exstop(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_exstop() argument
1902 struct perf_synth_intel_exstop *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_exstop()
1905 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_exstop()
1912 static int perf_sample__fprintf_synth_pwrx(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_pwrx() argument
1914 struct perf_synth_intel_pwrx *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_pwrx()
1917 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_pwrx()
1926 static int perf_sample__fprintf_synth_cbr(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_cbr() argument
1928 struct perf_synth_intel_cbr *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_cbr()
1932 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_cbr()
1944 static int perf_sample__fprintf_synth_psb(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_psb() argument
1946 struct perf_synth_intel_psb *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_psb()
1949 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_psb()
1957 static int perf_sample__fprintf_synth_evt(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_evt() argument
1959 struct perf_synth_intel_evt *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_evt()
1967 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_evt()
1993 static int perf_sample__fprintf_synth_iflag_chg(struct perf_sample *sample, FILE *fp) in perf_sample__fprintf_synth_iflag_chg() argument
1995 struct perf_synth_intel_iflag_chg *data = perf_sample__synth_ptr(sample); in perf_sample__fprintf_synth_iflag_chg()
1998 if (perf_sample__bad_synth_size(sample, *data)) in perf_sample__fprintf_synth_iflag_chg()
2006 static int perf_sample__fprintf_synth(struct perf_sample *sample, in perf_sample__fprintf_synth() argument
2011 return perf_sample__fprintf_synth_ptwrite(sample, fp); in perf_sample__fprintf_synth()
2013 return perf_sample__fprintf_synth_mwait(sample, fp); in perf_sample__fprintf_synth()
2015 return perf_sample__fprintf_synth_pwre(sample, fp); in perf_sample__fprintf_synth()
2017 return perf_sample__fprintf_synth_exstop(sample, fp); in perf_sample__fprintf_synth()
2019 return perf_sample__fprintf_synth_pwrx(sample, fp); in perf_sample__fprintf_synth()
2021 return perf_sample__fprintf_synth_cbr(sample, fp); in perf_sample__fprintf_synth()
2023 return perf_sample__fprintf_synth_psb(sample, fp); in perf_sample__fprintf_synth()
2025 return perf_sample__fprintf_synth_evt(sample, fp); in perf_sample__fprintf_synth()
2027 return perf_sample__fprintf_synth_iflag_chg(sample, fp); in perf_sample__fprintf_synth()
2072 struct perf_sample *sample; member
2087 perf_sample__fprintf_start(NULL, mctx->sample, mctx->thread, mctx->evsel, in script_print_metric()
2102 perf_sample__fprintf_start(NULL, mctx->sample, mctx->thread, mctx->evsel, in script_new_line()
2110 struct perf_sample *sample, in perf_sample__fprint_metric() argument
2118 .sample = sample, in perf_sample__fprint_metric()
2132 val = sample->period * evsel->scale; in perf_sample__fprint_metric()
2138 sample->cpu, in perf_sample__fprint_metric()
2145 static bool show_event(struct perf_sample *sample, in show_event() argument
2151 int depth = thread_stack__depth(thread, sample->cpu); in show_event()
2165 const char *name = resolve_branch_sym(sample, evsel, thread, al, addr_al, in show_event()
2188 struct perf_sample *sample, struct evsel *evsel, in process_event() argument
2206 perf_sample__fprintf_start(script, sample, thread, evsel, in process_event()
2210 fprintf(fp, "%10" PRIu64 " ", sample->period); in process_event()
2222 perf_sample__fprintf_flags(sample->flags, fp); in process_event()
2225 perf_sample__fprintf_bts(sample, evsel, thread, al, addr_al, machine, fp); in process_event()
2229 if (PRINT_FIELD(TRACE) && sample->raw_data) { in process_event()
2233 event_format__fprintf(tp_format, sample->cpu, in process_event()
2234 sample->raw_data, sample->raw_size, in process_event()
2240 perf_sample__fprintf_synth(sample, evsel, fp); in process_event()
2243 perf_sample__fprintf_addr(sample, thread, evsel, fp); in process_event()
2246 data_src__fprintf(sample->data_src, fp); in process_event()
2249 fprintf(fp, "%16" PRIu64, sample->weight); in process_event()
2252 fprintf(fp, "%16" PRIu16, sample->ins_lat); in process_event()
2255 fprintf(fp, "%16" PRIu16, sample->weight3); in process_event()
2260 sample->cgroup); in process_event()
2274 if (symbol_conf.use_callchain && sample->callchain) { in process_event()
2277 sample, NULL, NULL, in process_event()
2282 sample__fprintf_sym(sample, al, 0, output[type].print_ip_opts, cursor, in process_event()
2287 perf_sample__fprintf_iregs(sample, attr, arch, fp); in process_event()
2290 perf_sample__fprintf_uregs(sample, attr, arch, fp); in process_event()
2293 perf_sample__fprintf_brstack(sample, thread, evsel, fp); in process_event()
2295 perf_sample__fprintf_brstacksym(sample, thread, evsel, fp); in process_event()
2297 perf_sample__fprintf_brstackoff(sample, thread, evsel, fp); in process_event()
2300 perf_sample__fprintf_bpf_output(sample, fp); in process_event()
2301 perf_sample__fprintf_insn(sample, evsel, attr, thread, machine, fp, al); in process_event()
2304 fprintf(fp, "%16" PRIx64, sample->phys_addr); in process_event()
2307 fprintf(fp, " %s", get_page_size_name(sample->data_page_size, str)); in process_event()
2310 fprintf(fp, " %s", get_page_size_name(sample->code_page_size, str)); in process_event()
2312 perf_sample__fprintf_ipc(sample, evsel, fp); in process_event()
2323 perf_sample__fprint_metric(script, thread, evsel, sample, fp); in process_event()
2396 static bool filter_cpu(struct perf_sample *sample) in filter_cpu() argument
2398 if (cpu_list && sample->cpu != (u32)-1) in filter_cpu()
2399 return !test_bit(sample->cpu, cpu_bitmap); in filter_cpu()
2405 struct perf_sample *sample, in process_sample_event() argument
2418 ret = dlfilter__filter_event_early(dlfilter, event, sample, evsel, machine, &al, &addr_al); in process_sample_event()
2426 sample->time)) { in process_sample_event()
2431 if (sample->time < last_timestamp) { in process_sample_event()
2434 sample->time); in process_sample_event()
2437 last_timestamp = sample->time; in process_sample_event()
2441 if (filter_cpu(sample)) in process_sample_event()
2444 if (!al.thread && machine__resolve(machine, &al, sample) < 0) { in process_sample_event()
2454 if (!show_event(sample, evsel, al.thread, &al, &addr_al)) in process_sample_event()
2460 ret = dlfilter__filter_event(dlfilter, event, sample, evsel, machine, &al, &addr_al); in process_sample_event()
2473 thread__resolve(al.thread, &addr_al, sample); in process_sample_event()
2476 scripting_ops->process_event(event, sample, evsel, &al, addr_al_ptr); in process_sample_event()
2478 process_event(scr, sample, evsel, &al, &addr_al, machine); in process_sample_event()
2558 struct perf_sample *sample, in print_event_with_time() argument
2564 struct evsel *evsel = evlist__id2evsel(session->evlist, sample->id); in print_event_with_time()
2568 sample->cpu = 0; in print_event_with_time()
2569 sample->time = timestamp; in print_event_with_time()
2570 sample->pid = pid; in print_event_with_time()
2571 sample->tid = tid; in print_event_with_time()
2574 if (filter_cpu(sample)) in print_event_with_time()
2581 perf_sample__fprintf_start(script, sample, thread, evsel, in print_event_with_time()
2593 struct perf_sample *sample, struct machine *machine, in print_event() argument
2596 return print_event_with_time(tool, event, sample, machine, pid, tid, 0); in print_event()
2601 struct perf_sample *sample, in process_comm_event() argument
2604 if (perf_event__process_comm(tool, event, sample, machine) < 0) in process_comm_event()
2607 return print_event(tool, event, sample, machine, event->comm.pid, in process_comm_event()
2613 struct perf_sample *sample, in process_namespaces_event() argument
2616 if (perf_event__process_namespaces(tool, event, sample, machine) < 0) in process_namespaces_event()
2619 return print_event(tool, event, sample, machine, event->namespaces.pid, in process_namespaces_event()
2625 struct perf_sample *sample, in process_cgroup_event() argument
2628 if (perf_event__process_cgroup(tool, event, sample, machine) < 0) in process_cgroup_event()
2631 return print_event(tool, event, sample, machine, sample->pid, in process_cgroup_event()
2632 sample->tid); in process_cgroup_event()
2637 struct perf_sample *sample, in process_fork_event() argument
2640 if (perf_event__process_fork(tool, event, sample, machine) < 0) in process_fork_event()
2643 return print_event_with_time(tool, event, sample, machine, in process_fork_event()
2649 struct perf_sample *sample, in process_exit_event() argument
2653 if (print_event_with_time(tool, event, sample, machine, event->fork.pid, in process_exit_event()
2657 return perf_event__process_exit(tool, event, sample, machine); in process_exit_event()
2662 struct perf_sample *sample, in process_mmap_event() argument
2665 if (perf_event__process_mmap(tool, event, sample, machine) < 0) in process_mmap_event()
2668 return print_event(tool, event, sample, machine, event->mmap.pid, in process_mmap_event()
2674 struct perf_sample *sample, in process_mmap2_event() argument
2677 if (perf_event__process_mmap2(tool, event, sample, machine) < 0) in process_mmap2_event()
2680 return print_event(tool, event, sample, machine, event->mmap2.pid, in process_mmap2_event()
2686 struct perf_sample *sample, in process_switch_event() argument
2691 if (perf_event__process_switch(tool, event, sample, machine) < 0) in process_switch_event()
2694 if (scripting_ops && scripting_ops->process_switch && !filter_cpu(sample)) in process_switch_event()
2695 scripting_ops->process_switch(event, sample, machine); in process_switch_event()
2700 return print_event(tool, event, sample, machine, sample->pid, in process_switch_event()
2701 sample->tid); in process_switch_event()
2718 struct perf_sample *sample, in process_lost_event() argument
2721 return print_event(tool, event, sample, machine, sample->pid, in process_lost_event()
2722 sample->tid); in process_lost_event()
2728 struct perf_sample *sample, in process_throttle_event() argument
2732 scripting_ops->process_throttle(event, sample, machine); in process_throttle_event()
2749 struct perf_sample *sample, in process_bpf_events() argument
2752 if (machine__process_ksymbol(machine, event, sample) < 0) in process_bpf_events()
2755 return print_event(tool, event, sample, machine, sample->pid, in process_bpf_events()
2756 sample->tid); in process_bpf_events()
2769 struct perf_sample *sample, in process_text_poke_events() argument
2772 if (perf_event__process_text_poke(tool, event, sample, machine) < 0) in process_text_poke_events()
2775 return print_event(tool, event, sample, machine, sample->pid, in process_text_poke_events()
2776 sample->tid); in process_text_poke_events()
3881 * Enable guest sample processing. in cmd_script()
4082 script.tool.sample = process_sample_event; in cmd_script()