db_sym.h revision 1.3 1 1.1 cgd /*
2 1.1 cgd * Mach Operating System
3 1.1 cgd * Copyright (c) 1991,1990 Carnegie Mellon University
4 1.1 cgd * All Rights Reserved.
5 1.1 cgd *
6 1.1 cgd * Permission to use, copy, modify and distribute this software and its
7 1.1 cgd * documentation is hereby granted, provided that both the copyright
8 1.1 cgd * notice and this permission notice appear in all copies of the
9 1.1 cgd * software, derivative works or modified versions, and any portions
10 1.1 cgd * thereof, and that both notices appear in supporting documentation.
11 1.1 cgd *
12 1.1 cgd * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS
13 1.1 cgd * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
14 1.1 cgd * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
15 1.1 cgd *
16 1.1 cgd * Carnegie Mellon requests users of this software to return to
17 1.1 cgd *
18 1.1 cgd * Software Distribution Coordinator or Software.Distribution (at) CS.CMU.EDU
19 1.1 cgd * School of Computer Science
20 1.1 cgd * Carnegie Mellon University
21 1.1 cgd * Pittsburgh PA 15213-3890
22 1.1 cgd *
23 1.1 cgd * any improvements or extensions that they make and grant Carnegie the
24 1.1 cgd * rights to redistribute these changes.
25 1.1 cgd */
26 1.1 cgd /*
27 1.3 brezak * $Id: db_sym.h,v 1.3 1993/07/22 13:03:01 brezak Exp $
28 1.2 cgd *
29 1.1 cgd * HISTORY
30 1.1 cgd * $Log: db_sym.h,v $
31 1.3 brezak * Revision 1.3 1993/07/22 13:03:01 brezak
32 1.3 brezak * Allow adding more than one symbol table at runtime. For LKM.
33 1.3 brezak *
34 1.2 cgd * Revision 1.2 1993/05/20 03:39:32 cgd
35 1.2 cgd * add explicit rcs id
36 1.2 cgd *
37 1.1 cgd * Revision 1.1.1.1 1993/03/21 09:46:27 cgd
38 1.1 cgd * initial import of 386bsd-0.1 sources
39 1.1 cgd *
40 1.1 cgd * Revision 1.1 1992/03/25 21:45:29 pace
41 1.1 cgd * Initial revision
42 1.1 cgd *
43 1.1 cgd * Revision 2.3 91/02/05 17:07:12 mrt
44 1.1 cgd * Changed to new Mach copyright
45 1.1 cgd * [91/01/31 16:19:27 mrt]
46 1.1 cgd *
47 1.1 cgd * Revision 2.2 90/08/27 21:52:39 dbg
48 1.1 cgd * Changed type of db_sym_t to char * - it's a better type for an
49 1.1 cgd * opaque pointer.
50 1.1 cgd * [90/08/22 dbg]
51 1.1 cgd *
52 1.1 cgd * Created.
53 1.1 cgd * [90/08/19 af]
54 1.1 cgd *
55 1.1 cgd */
56 1.1 cgd /*
57 1.1 cgd * Author: Alessandro Forin, Carnegie Mellon University
58 1.1 cgd * Date: 8/90
59 1.1 cgd */
60 1.1 cgd
61 1.1 cgd /*
62 1.1 cgd * This module can handle multiple symbol tables
63 1.1 cgd */
64 1.1 cgd typedef struct {
65 1.1 cgd char *name; /* symtab name */
66 1.1 cgd char *start; /* symtab location */
67 1.1 cgd char *end;
68 1.1 cgd char *private; /* optional machdep pointer */
69 1.1 cgd } db_symtab_t;
70 1.1 cgd
71 1.1 cgd extern db_symtab_t *db_last_symtab; /* where last symbol was found */
72 1.1 cgd
73 1.1 cgd /*
74 1.1 cgd * Symbol representation is specific to the symtab style:
75 1.1 cgd * BSD compilers use dbx' nlist, other compilers might use
76 1.1 cgd * a different one
77 1.1 cgd */
78 1.1 cgd typedef char * db_sym_t; /* opaque handle on symbols */
79 1.1 cgd #define DB_SYM_NULL ((db_sym_t)0)
80 1.1 cgd
81 1.1 cgd /*
82 1.1 cgd * Non-stripped symbol tables will have duplicates, for instance
83 1.1 cgd * the same string could match a parameter name, a local var, a
84 1.1 cgd * global var, etc.
85 1.1 cgd * We are most concern with the following matches.
86 1.1 cgd */
87 1.1 cgd typedef int db_strategy_t; /* search strategy */
88 1.1 cgd
89 1.1 cgd #define DB_STGY_ANY 0 /* anything goes */
90 1.1 cgd #define DB_STGY_XTRN 1 /* only external symbols */
91 1.1 cgd #define DB_STGY_PROC 2 /* only procedures */
92 1.1 cgd
93 1.1 cgd extern boolean_t db_qualify_ambiguous_names;
94 1.1 cgd /* if TRUE, check across symbol tables
95 1.1 cgd * for multiple occurrences of a name.
96 1.1 cgd * Might slow down quite a bit */
97 1.1 cgd
98 1.3 brezak /*
99 1.1 cgd * Functions exported by the symtable module
100 1.3 brezak */
101 1.3 brezak extern int db_add_symbol_table();
102 1.3 brezak /* extend the list of symbol tables */
103 1.1 cgd
104 1.1 cgd extern void db_del_symbol_table(/* char * */);
105 1.1 cgd /* remove a symbol table from list */
106 1.1 cgd
107 1.1 cgd extern int db_value_of_name(/* char*, db_expr_t* */);
108 1.1 cgd /* find symbol value given name */
109 1.1 cgd
110 1.1 cgd extern db_sym_t db_search_symbol(/* db_expr_t, db_strategy_t, int* */);
111 1.1 cgd /* find symbol given value */
112 1.1 cgd
113 1.1 cgd extern void db_symbol_values(/* db_sym_t, char**, db_expr_t* */);
114 1.1 cgd /* return name and value of symbol */
115 1.1 cgd
116 1.1 cgd #define db_find_sym_and_offset(val,namep,offp) \
117 1.1 cgd db_symbol_values(db_search_symbol(val,DB_STGY_ANY,offp),namep,0)
118 1.1 cgd /* find name&value given approx val */
119 1.1 cgd
120 1.1 cgd #define db_find_xtrn_sym_and_offset(val,namep,offp) \
121 1.1 cgd db_symbol_values(db_search_symbol(val,DB_STGY_XTRN,offp),namep,0)
122 1.1 cgd /* ditto, but no locals */
123 1.1 cgd
124 1.1 cgd extern int db_eqname(/* char*, char*, char */);
125 1.1 cgd /* strcmp, modulo leading char */
126
127 extern void db_printsym(/* db_expr_t, db_strategy_t */);
128 /* print closest symbol to a value */
129