annotate usr/src/cmd/sgs/librtld_db/demo/common/callstack.c @ 12939:a27c46eb192b

6972234 sgs demo's could use some cleanup
author Rod Evans <Rod.Evans@Sun.COM>
date Tue, 27 Jul 2010 22:49:34 -0700
parents usr/src/cmd/sgs/librtld_db/rdb_demo/common/callstack.c@79e3159504fa
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
1 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
2 * CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
3 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
4 * The contents of this file are subject to the terms of the
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
5 * Common Development and Distribution License (the "License").
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
6 * You may not use this file except in compliance with the License.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
7 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
9 * or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
10 * See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
11 * and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
12 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
13 * When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
15 * If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
16 * fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
17 * information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
18 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
19 * CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
20 */
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
21
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
22 /*
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
23 * Copyright (c) 1995, 2010, Oracle and/or its affiliates. All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
24 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
25
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
26 #include <stdio.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
27 #include <unistd.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
28 #include <string.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
29 #include <sys/types.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
30 #include <sys/reg.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
31 #include <sys/frame.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
32 #include <sys/stack.h>
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
33 #include <sys/machelf.h>
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
34 #include <procfs.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
35
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
36 #include "rdb.h"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
37
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
38 #ifndef STACK_BIAS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
39 #define STACK_BIAS 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
40 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
41
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
42 static int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
43 get_frame(struct ps_prochandle *ph, psaddr_t fp, struct frame *frm)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
44 {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
45 #if defined(_LP64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
46 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
47 * Use special structures to read a 32-bit process
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
48 * from a 64-bit process.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
49 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
50 if (ph->pp_dmodel == PR_MODEL_ILP32) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
51 struct frame32 frm32;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
52
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
53 if (ps_pread(ph, (psaddr_t)fp, (char *)&frm32,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
54 sizeof (struct frame32)) != PS_OK) {
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
55 (void) printf("stack trace: bad frame pointer: 0x%lx\n",
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
56 fp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
57 return (-1);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
58 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
59
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
60 frm->fr_savpc = (long)frm32.fr_savpc;
3731
79e3159504fa 6523787 dlopen() handle gets mistakenly orphaned - results in access to freed memory
rie
parents: 1618
diff changeset
61 #if defined(__sparcv9)
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
62 frm->fr_savfp = (struct frame *)(uintptr_t)frm32.fr_savfp;
3731
79e3159504fa 6523787 dlopen() handle gets mistakenly orphaned - results in access to freed memory
rie
parents: 1618
diff changeset
63 #elif defined(__amd64)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
64 frm->fr_savfp = (long)frm32.fr_savfp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
65 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
66 return (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
67 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
68 #endif /* defined(_LP64) */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
69
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
70 if (ps_pread(ph, (psaddr_t)fp + STACK_BIAS, (char *)frm,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
71 sizeof (struct frame)) != PS_OK) {
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
72 (void) printf("stack trace: bad frame pointer: 0x%lx\n", fp);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
73 return (-1);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
74 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
75 return (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
76 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
77
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
78 /*
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
79 * Relatively architecture neutral routine to display the callstack.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
80 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
81 void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
82 CallStack(struct ps_prochandle *ph)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
83 {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
84 pstatus_t pstatus;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
85 greg_t fp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
86 struct frame frm;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
87 char *symstr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
88
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
89 if (pread(ph->pp_statusfd, &pstatus, sizeof (pstatus), 0) == -1)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
90 perr("cs: reading status");
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
91
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
92 symstr = print_address_ps(ph, (ulong_t)pstatus.pr_lwp.pr_reg[R_PC],
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
93 FLG_PAP_SONAME);
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
94 (void) printf(" 0x%08x:%-17s\n", EC_WORD(pstatus.pr_lwp.pr_reg[R_PC]),
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
95 symstr);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
96
3731
79e3159504fa 6523787 dlopen() handle gets mistakenly orphaned - results in access to freed memory
rie
parents: 1618
diff changeset
97 fp = pstatus.pr_lwp.pr_reg[R_FP];
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
98
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
99 while (fp) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
100 if (get_frame(ph, (psaddr_t)fp, &frm) == -1)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
101 return;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
102 if (frm.fr_savpc) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
103 symstr = print_address_ps(ph, (ulong_t)frm.fr_savpc,
12939
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
104 FLG_PAP_SONAME);
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
105 (void) printf(" 0x%08x:%-17s\n", EC_WORD(frm.fr_savpc),
a27c46eb192b 6972234 sgs demo's could use some cleanup
Rod Evans <Rod.Evans@Sun.COM>
parents: 3731
diff changeset
106 symstr);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
107 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
108 fp = (greg_t)frm.fr_savfp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
109 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
110 }