1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
7 * with the License.
8 *
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
13 *
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
19 *
20 * CDDL HEADER END
21 */
22
23 /*
24 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
25 * Use is subject to license terms.
26 */
27
28 #pragma ident "%Z%%M% %I% %E% SMI"
29
30 #include "gprof.h"
31
32 /*
33 * these are the lists of names:
34 * there is the list head and then the listname
35 * is a pointer to the list head
36 * (for ease of passing to stringlist functions).
37 */
38 struct stringlist fhead = { 0, 0 };
39 struct stringlist *flist = &fhead;
40 struct stringlist Fhead = { 0, 0 };
41 struct stringlist *Flist = &Fhead;
42 struct stringlist ehead = { 0, 0 };
43 struct stringlist *elist = &ehead;
44 struct stringlist Ehead = { 0, 0 };
45 struct stringlist *Elist = &Ehead;
46
47 void
addlist(struct stringlist * listp,char * funcname)48 addlist(struct stringlist *listp, char *funcname)
49 {
50 struct stringlist *slp;
51
52 slp = malloc(sizeof (struct stringlist));
53
54 if (slp == NULL) {
55 (void) fprintf(stderr, "gprof: ran out room for printlist\n");
56 exit(1);
57 }
58
59 slp->next = listp->next;
60 slp->string = funcname;
61 listp->next = slp;
62 }
63
64 bool
onlist(struct stringlist * listp,char * funcname)65 onlist(struct stringlist *listp, char *funcname)
66 {
67 struct stringlist *slp;
68
69 for (slp = listp->next; slp; slp = slp->next) {
70 if (strcmp(slp->string, funcname) == 0)
71 return (TRUE);
72
73 if (funcname[0] == '_' &&
74 strcmp(slp->string, &funcname[1]) == 0)
75 return (TRUE);
76 }
77 return (FALSE);
78 }
79