1*fae548d3Szrj /*
2*fae548d3Szrj * Copyright (c) 1983, 1993, 2001
3*fae548d3Szrj * The Regents of the University of California. All rights reserved.
4*fae548d3Szrj *
5*fae548d3Szrj * Redistribution and use in source and binary forms, with or without
6*fae548d3Szrj * modification, are permitted provided that the following conditions
7*fae548d3Szrj * are met:
8*fae548d3Szrj * 1. Redistributions of source code must retain the above copyright
9*fae548d3Szrj * notice, this list of conditions and the following disclaimer.
10*fae548d3Szrj * 2. Redistributions in binary form must reproduce the above copyright
11*fae548d3Szrj * notice, this list of conditions and the following disclaimer in the
12*fae548d3Szrj * documentation and/or other materials provided with the distribution.
13*fae548d3Szrj * 3. Neither the name of the University nor the names of its contributors
14*fae548d3Szrj * may be used to endorse or promote products derived from this software
15*fae548d3Szrj * without specific prior written permission.
16*fae548d3Szrj *
17*fae548d3Szrj * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18*fae548d3Szrj * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*fae548d3Szrj * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*fae548d3Szrj * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21*fae548d3Szrj * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22*fae548d3Szrj * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23*fae548d3Szrj * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24*fae548d3Szrj * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25*fae548d3Szrj * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26*fae548d3Szrj * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27*fae548d3Szrj * SUCH DAMAGE.
28*fae548d3Szrj */
29*fae548d3Szrj #include "gprof.h"
30*fae548d3Szrj #include "demangle.h"
31*fae548d3Szrj #include "search_list.h"
32*fae548d3Szrj #include "source.h"
33*fae548d3Szrj #include "symtab.h"
34*fae548d3Szrj #include "cg_arcs.h"
35*fae548d3Szrj #include "utils.h"
36*fae548d3Szrj #include "corefile.h"
37*fae548d3Szrj
38*fae548d3Szrj
39*fae548d3Szrj /*
40*fae548d3Szrj * Print name of symbol. Return number of characters printed.
41*fae548d3Szrj */
42*fae548d3Szrj int
print_name_only(Sym * self)43*fae548d3Szrj print_name_only (Sym *self)
44*fae548d3Szrj {
45*fae548d3Szrj const char *name = self->name;
46*fae548d3Szrj const char *filename;
47*fae548d3Szrj char *demangled = 0;
48*fae548d3Szrj char buf[PATH_MAX];
49*fae548d3Szrj int size = 0;
50*fae548d3Szrj
51*fae548d3Szrj if (name)
52*fae548d3Szrj {
53*fae548d3Szrj if (!bsd_style_output && demangle)
54*fae548d3Szrj {
55*fae548d3Szrj demangled = bfd_demangle (core_bfd, name, DMGL_ANSI | DMGL_PARAMS);
56*fae548d3Szrj if (demangled)
57*fae548d3Szrj name = demangled;
58*fae548d3Szrj }
59*fae548d3Szrj printf ("%s", name);
60*fae548d3Szrj size = strlen (name);
61*fae548d3Szrj if ((line_granularity || inline_file_names) && self->file)
62*fae548d3Szrj {
63*fae548d3Szrj filename = self->file->name;
64*fae548d3Szrj if (!print_path)
65*fae548d3Szrj {
66*fae548d3Szrj filename = strrchr (filename, '/');
67*fae548d3Szrj if (filename)
68*fae548d3Szrj {
69*fae548d3Szrj ++filename;
70*fae548d3Szrj }
71*fae548d3Szrj else
72*fae548d3Szrj {
73*fae548d3Szrj filename = self->file->name;
74*fae548d3Szrj }
75*fae548d3Szrj }
76*fae548d3Szrj if (line_granularity)
77*fae548d3Szrj {
78*fae548d3Szrj sprintf (buf, " (%s:%d @ %lx)", filename, self->line_num,
79*fae548d3Szrj (unsigned long) self->addr);
80*fae548d3Szrj }
81*fae548d3Szrj else
82*fae548d3Szrj {
83*fae548d3Szrj sprintf (buf, " (%s:%d)", filename, self->line_num);
84*fae548d3Szrj }
85*fae548d3Szrj printf ("%s", buf);
86*fae548d3Szrj size += strlen (buf);
87*fae548d3Szrj }
88*fae548d3Szrj if (demangled)
89*fae548d3Szrj {
90*fae548d3Szrj free (demangled);
91*fae548d3Szrj }
92*fae548d3Szrj DBG (DFNDEBUG, printf ("{%d} ", self->cg.top_order));
93*fae548d3Szrj DBG (PROPDEBUG, printf ("%4.0f%% ", 100.0 * self->cg.prop.fract));
94*fae548d3Szrj }
95*fae548d3Szrj return size;
96*fae548d3Szrj }
97*fae548d3Szrj
98*fae548d3Szrj
99*fae548d3Szrj void
print_name(Sym * self)100*fae548d3Szrj print_name (Sym *self)
101*fae548d3Szrj {
102*fae548d3Szrj print_name_only (self);
103*fae548d3Szrj
104*fae548d3Szrj if (self->cg.cyc.num != 0)
105*fae548d3Szrj {
106*fae548d3Szrj printf (_(" <cycle %d>"), self->cg.cyc.num);
107*fae548d3Szrj }
108*fae548d3Szrj if (self->cg.index != 0)
109*fae548d3Szrj {
110*fae548d3Szrj if (self->cg.print_flag)
111*fae548d3Szrj {
112*fae548d3Szrj printf (" [%d]", self->cg.index);
113*fae548d3Szrj }
114*fae548d3Szrj else
115*fae548d3Szrj {
116*fae548d3Szrj printf (" (%d)", self->cg.index);
117*fae548d3Szrj }
118*fae548d3Szrj }
119*fae548d3Szrj }
120