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