Lines Matching full:notes
6 * copyright notes.
851 struct annotation *notes = symbol__annotation(sym); in symbol__alloc_hist_cycles() local
854 notes->src->cycles_hist = calloc(size, sizeof(struct cyc_hist)); in symbol__alloc_hist_cycles()
855 if (notes->src->cycles_hist == NULL) in symbol__alloc_hist_cycles()
862 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_zero_histograms() local
864 annotation__lock(notes); in symbol__annotate_zero_histograms()
865 if (notes->src != NULL) { in symbol__annotate_zero_histograms()
866 memset(notes->src->histograms, 0, in symbol__annotate_zero_histograms()
867 notes->src->nr_histograms * notes->src->sizeof_sym_hist); in symbol__annotate_zero_histograms()
868 if (notes->src->cycles_hist) in symbol__annotate_zero_histograms()
869 memset(notes->src->cycles_hist, 0, in symbol__annotate_zero_histograms()
872 annotation__unlock(notes); in symbol__annotate_zero_histograms()
963 struct annotation *notes = symbol__annotation(sym); in symbol__cycles_hist() local
965 if (notes->src == NULL) { in symbol__cycles_hist()
966 notes->src = annotated_source__new(); in symbol__cycles_hist()
967 if (notes->src == NULL) in symbol__cycles_hist()
972 if (!notes->src->cycles_hist) { in symbol__cycles_hist()
977 return notes->src->cycles_hist; in symbol__cycles_hist()
982 struct annotation *notes = symbol__annotation(sym); in symbol__hists() local
984 if (notes->src == NULL) { in symbol__hists()
985 notes->src = annotated_source__new(); in symbol__hists()
986 if (notes->src == NULL) in symbol__hists()
991 if (notes->src->histograms == NULL) { in symbol__hists()
993 annotated_source__alloc_histograms(notes->src, symbol__size(sym), in symbol__hists()
997 return notes->src; in symbol__hists()
1074 static unsigned annotation__count_insn(struct annotation *notes, u64 start, u64 end) in annotation__count_insn() argument
1080 if (notes->offsets[offset]) in annotation__count_insn()
1086 static void annotation__count_and_fill(struct annotation *notes, u64 start, u64 end, struct cyc_his… in annotation__count_and_fill() argument
1092 n_insn = annotation__count_insn(notes, start, end); in annotation__count_and_fill()
1101 struct annotation_line *al = notes->offsets[offset]; in annotation__count_and_fill()
1110 notes->hit_cycles += ch->cycles; in annotation__count_and_fill()
1111 notes->hit_insn += n_insn * ch->num; in annotation__count_and_fill()
1112 notes->cover_insn += cover_insn; in annotation__count_and_fill()
1117 void annotation__compute_ipc(struct annotation *notes, size_t size) in annotation__compute_ipc() argument
1121 if (!notes->src || !notes->src->cycles_hist) in annotation__compute_ipc()
1124 notes->total_insn = annotation__count_insn(notes, 0, size - 1); in annotation__compute_ipc()
1125 notes->hit_cycles = 0; in annotation__compute_ipc()
1126 notes->hit_insn = 0; in annotation__compute_ipc()
1127 notes->cover_insn = 0; in annotation__compute_ipc()
1129 annotation__lock(notes); in annotation__compute_ipc()
1133 ch = ¬es->src->cycles_hist[offset]; in annotation__compute_ipc()
1138 annotation__count_and_fill(notes, ch->start, offset, ch); in annotation__compute_ipc()
1139 al = notes->offsets[offset]; in annotation__compute_ipc()
1145 notes->have_cycles = true; in annotation__compute_ipc()
1148 annotation__unlock(notes); in annotation__compute_ipc()
1299 void annotation__exit(struct annotation *notes) in annotation__exit() argument
1301 annotated_source__delete(notes->src); in annotation__exit()
1312 static size_t annotation__hash(const struct annotation *notes) in annotation__hash() argument
1314 return (size_t)notes; in annotation__hash()
1317 static struct mutex *annotation__get_mutex(const struct annotation *notes) in annotation__get_mutex() argument
1325 return sharded_mutex__get_mutex(sharded_mutex, annotation__hash(notes)); in annotation__get_mutex()
1328 void annotation__lock(struct annotation *notes) in annotation__lock() argument
1331 struct mutex *mutex = annotation__get_mutex(notes); in annotation__lock()
1337 void annotation__unlock(struct annotation *notes) in annotation__unlock() argument
1340 struct mutex *mutex = annotation__get_mutex(notes); in annotation__unlock()
1346 bool annotation__trylock(struct annotation *notes) in annotation__trylock() argument
1348 struct mutex *mutex = annotation__get_mutex(notes); in annotation__trylock()
1480 struct annotation *notes = symbol__annotation(sym); in annotation_line__print() local
1502 list_for_each_entry_from(queue, ¬es->src->source, node) { in annotation_line__print()
1592 struct annotation *notes = symbol__annotation(sym); in symbol__parse_objdump_line() local
1649 annotation_line__add(&dl->al, ¬es->src->source); in symbol__parse_objdump_line()
1660 struct annotation *notes = symbol__annotation(sym); in delete_last_nop() local
1661 struct list_head *list = ¬es->src->source; in delete_last_nop()
1819 struct annotation *notes = symbol__annotation(sym); in symbol__disassemble_bpf() local
1939 ¬es->src->source); in symbol__disassemble_bpf()
1950 annotation_line__add(&dl->al, ¬es->src->source); in symbol__disassemble_bpf()
1975 struct annotation *notes = symbol__annotation(sym); in symbol__disassemble_bpf_image() local
1984 annotation_line__add(&dl->al, ¬es->src->source); in symbol__disassemble_bpf_image()
2264 static void annotation__calc_percent(struct annotation *notes, in annotation__calc_percent() argument
2270 list_for_each_entry(al, ¬es->src->source, node) { in annotation__calc_percent()
2277 next = annotation_line__next(al, ¬es->src->source); in annotation__calc_percent()
2287 sym_hist = annotation__histogram(notes, evsel->core.idx); in annotation__calc_percent()
2297 struct annotation *notes = symbol__annotation(sym); in symbol__calc_percent() local
2299 annotation__calc_percent(notes, evsel, symbol__size(sym)); in symbol__calc_percent()
2306 struct annotation *notes = symbol__annotation(sym); in symbol__annotate() local
2337 if (notes->options && notes->options->full_addr) in symbol__annotate()
2338 notes->start = map__objdump_2mem(ms->map, ms->sym->start); in symbol__annotate()
2340 notes->start = map__rip_2objdump(ms->map, ms->sym->start); in symbol__annotate()
2472 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_hits() local
2473 struct sym_hist *h = annotation__histogram(notes, evsel->core.idx); in symbol__annotate_hits()
2505 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_printf() local
2506 struct sym_hist *h = annotation__histogram(notes, evsel->core.idx); in symbol__annotate_printf()
2547 addr_fmt_width = annotated_source__addr_fmt_width(¬es->src->source, start); in symbol__annotate_printf()
2549 list_for_each_entry(pos, ¬es->src->source, node) { in symbol__annotate_printf()
2639 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_fprintf2() local
2651 list_for_each_entry(al, ¬es->src->source, node) { in symbol__annotate_fprintf2()
2652 if (annotation_line__filter(al, notes)) in symbol__annotate_fprintf2()
2654 annotation_line__write(al, notes, &wops, opts); in symbol__annotate_fprintf2()
2696 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_zero_histogram() local
2697 struct sym_hist *h = annotation__histogram(notes, evidx); in symbol__annotate_zero_histogram()
2699 memset(h, 0, notes->src->sizeof_sym_hist); in symbol__annotate_zero_histogram()
2704 struct annotation *notes = symbol__annotation(sym); in symbol__annotate_decay_histogram() local
2705 struct sym_hist *h = annotation__histogram(notes, evidx); in symbol__annotate_decay_histogram()
2763 void annotation__mark_jump_targets(struct annotation *notes, struct symbol *sym) in annotation__mark_jump_targets() argument
2772 struct annotation_line *al = notes->offsets[offset]; in annotation__mark_jump_targets()
2780 al = notes->offsets[dl->ops.target.offset]; in annotation__mark_jump_targets()
2789 if (++al->jump_sources > notes->max_jump_sources) in annotation__mark_jump_targets()
2790 notes->max_jump_sources = al->jump_sources; in annotation__mark_jump_targets()
2794 void annotation__set_offsets(struct annotation *notes, s64 size) in annotation__set_offsets() argument
2798 notes->max_line_len = 0; in annotation__set_offsets()
2799 notes->nr_entries = 0; in annotation__set_offsets()
2800 notes->nr_asm_entries = 0; in annotation__set_offsets()
2802 list_for_each_entry(al, ¬es->src->source, node) { in annotation__set_offsets()
2805 if (notes->max_line_len < line_len) in annotation__set_offsets()
2806 notes->max_line_len = line_len; in annotation__set_offsets()
2807 al->idx = notes->nr_entries++; in annotation__set_offsets()
2809 al->idx_asm = notes->nr_asm_entries++; in annotation__set_offsets()
2818 notes->offsets[al->offset] = al; in annotation__set_offsets()
2833 static int annotation__max_ins_name(struct annotation *notes) in annotation__max_ins_name() argument
2838 list_for_each_entry(al, ¬es->src->source, node) { in annotation__max_ins_name()
2850 void annotation__init_column_widths(struct annotation *notes, struct symbol *sym) in annotation__init_column_widths() argument
2852 notes->widths.addr = notes->widths.target = in annotation__init_column_widths()
2853 notes->widths.min_addr = hex_width(symbol__size(sym)); in annotation__init_column_widths()
2854 notes->widths.max_addr = hex_width(sym->end); in annotation__init_column_widths()
2855 notes->widths.jumps = width_jumps(notes->max_jump_sources); in annotation__init_column_widths()
2856 notes->widths.max_ins_name = annotation__max_ins_name(notes); in annotation__init_column_widths()
2859 void annotation__update_column_widths(struct annotation *notes) in annotation__update_column_widths() argument
2861 if (notes->options->use_offset) in annotation__update_column_widths()
2862 notes->widths.target = notes->widths.min_addr; in annotation__update_column_widths()
2863 else if (notes->options->full_addr) in annotation__update_column_widths()
2864 notes->widths.target = BITS_PER_LONG / 4; in annotation__update_column_widths()
2866 notes->widths.target = notes->widths.max_addr; in annotation__update_column_widths()
2868 notes->widths.addr = notes->widths.target; in annotation__update_column_widths()
2870 if (notes->options->show_nr_jumps) in annotation__update_column_widths()
2871 notes->widths.addr += notes->widths.jumps + 1; in annotation__update_column_widths()
2874 void annotation__toggle_full_addr(struct annotation *notes, struct map_symbol *ms) in annotation__toggle_full_addr() argument
2876 notes->options->full_addr = !notes->options->full_addr; in annotation__toggle_full_addr()
2878 if (notes->options->full_addr) in annotation__toggle_full_addr()
2879 notes->start = map__objdump_2mem(ms->map, ms->sym->start); in annotation__toggle_full_addr()
2881 notes->start = map__rip_2objdump(ms->map, ms->sym->start); in annotation__toggle_full_addr()
2883 annotation__update_column_widths(notes); in annotation__toggle_full_addr()
2886 static void annotation__calc_lines(struct annotation *notes, struct map *map, in annotation__calc_lines() argument
2893 list_for_each_entry(al, ¬es->src->source, node) { in annotation__calc_lines()
2910 al->path = get_srcline(map__dso(map), notes->start + al->offset, NULL, in annotation__calc_lines()
2911 false, true, notes->start + al->offset); in annotation__calc_lines()
2921 struct annotation *notes = symbol__annotation(ms->sym); in symbol__calc_lines() local
2923 annotation__calc_lines(notes, ms->map, root, opts); in symbol__calc_lines()
3002 struct annotation *notes, in annotation_line__max_percent() argument
3008 for (i = 0; i < notes->nr_events; i++) { in annotation_line__max_percent()
3021 static void disasm_line__write(struct disasm_line *dl, struct annotation *notes, in disasm_line__write() argument
3049 disasm_line__scnprintf(dl, bf, size, !notes->options->use_offset, notes->widths.max_ins_name); in disasm_line__write()
3052 static void ipc_coverage_string(char *bf, int size, struct annotation *notes) in ipc_coverage_string() argument
3056 if (notes->hit_cycles) in ipc_coverage_string()
3057 ipc = notes->hit_insn / ((double)notes->hit_cycles); in ipc_coverage_string()
3059 if (notes->total_insn) { in ipc_coverage_string()
3060 coverage = notes->cover_insn * 100.0 / in ipc_coverage_string()
3061 ((double)notes->total_insn); in ipc_coverage_string()
3068 static void __annotation_line__write(struct annotation_line *al, struct annotation *notes, in __annotation_line__write() argument
3078 double percent_max = annotation_line__max_percent(al, notes, percent_type); in __annotation_line__write()
3079 int pcnt_width = annotation__pcnt_width(notes), in __annotation_line__write()
3080 cycles_width = annotation__cycles_width(notes); in __annotation_line__write()
3086 if (notes->have_cycles) { in __annotation_line__write()
3096 for (i = 0; i < notes->nr_events; i++) { in __annotation_line__write()
3123 if (notes->have_cycles) { in __annotation_line__write()
3131 if (!notes->options->show_minmax_cycle) { in __annotation_line__write()
3165 ipc_coverage_string(bf, sizeof(bf), notes); in __annotation_line__write()
3175 if (al->line_nr && notes->options->show_linenr) in __annotation_line__write()
3176 printed = scnprintf(bf, sizeof(bf), "%-*d ", notes->widths.addr + 1, al->line_nr); in __annotation_line__write()
3178 printed = scnprintf(bf, sizeof(bf), "%-*s ", notes->widths.addr, " "); in __annotation_line__write()
3185 if (!notes->options->use_offset) in __annotation_line__write()
3186 addr += notes->start; in __annotation_line__write()
3188 if (!notes->options->use_offset) { in __annotation_line__write()
3192 notes->options->offset_level >= ANNOTATION__OFFSET_JUMP_TARGETS) { in __annotation_line__write()
3193 if (notes->options->show_nr_jumps) { in __annotation_line__write()
3196 notes->widths.jumps, in __annotation_line__write()
3205 notes->widths.target, addr); in __annotation_line__write()
3207 notes->options->offset_level >= ANNOTATION__OFFSET_CALL) { in __annotation_line__write()
3209 } else if (notes->options->offset_level == ANNOTATION__MAX_OFFSET_LEVEL) { in __annotation_line__write()
3213 notes->widths.addr, " "); in __annotation_line__write()
3223 disasm_line__write(disasm_line(al), notes, obj, bf, sizeof(bf), obj__printf, obj__write_graph); in __annotation_line__write()
3230 void annotation_line__write(struct annotation_line *al, struct annotation *notes, in annotation_line__write() argument
3234 __annotation_line__write(al, notes, wops->first_line, wops->current_entry, in annotation_line__write()
3246 struct annotation *notes = symbol__annotation(sym); in symbol__annotate2() local
3250 notes->offsets = zalloc(size * sizeof(struct annotation_line *)); in symbol__annotate2()
3251 if (notes->offsets == NULL) in symbol__annotate2()
3261 notes->options = options; in symbol__annotate2()
3265 annotation__set_offsets(notes, size); in symbol__annotate2()
3266 annotation__mark_jump_targets(notes, sym); in symbol__annotate2()
3267 annotation__compute_ipc(notes, size); in symbol__annotate2()
3268 annotation__init_column_widths(notes, sym); in symbol__annotate2()
3269 notes->nr_events = nr_pcnt; in symbol__annotate2()
3271 annotation__update_column_widths(notes); in symbol__annotate2()
3277 zfree(¬es->offsets); in symbol__annotate2()