BPatch functions that block are now locked (on a finer grain than the rest of the...
[dyninst.git] / dyninstAPI / src / templates2.C
1 /*
2  * Copyright (c) 1996-2004 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42 // $Id: templates2.C,v 1.41 2005/02/25 07:04:47 jaw Exp $
43
44 #ifdef __XLC__
45 #include "common/h/Dictionary.h"
46 #else
47 #pragma implementation "Dictionary.h"
48 #include "common/src/Dictionary.C"
49 #endif
50
51 #include "common/h/String.h"
52
53 #include "dyninstAPI/src/symtab.h"
54 #include "dyninstAPI/src/process.h"
55 #include "dyninstAPI/src/inst.h"
56 #include "dyninstAPI/src/instP.h"
57 #include "dyninstAPI/src/dyninstP.h"
58 #include "dyninstAPI/src/ast.h"
59 #include "dyninstAPI/src/util.h"
60 #include "dyninstAPI/src/Object.h"
61 #include "dyninstAPI/src/sharedobject.h"
62 #include "dyninstAPI/src/syscalltrap.h"
63 #include "dyninstAPI/src/libState.h"
64
65 #include "dyninstAPI/src/FunctionExpansionRecord.h"
66 #include "dyninstAPI/src/signalhandler.h"
67
68 #if defined(BPATCH_LIBRARY)
69 #include "dyninstAPI/src/LineInformation.h"
70 #include "dyninstAPI/h/BPatch_Set.h"
71 #include "dyninstAPI/h/BPatch_type.h"
72
73 class BPatch_thread;
74 class BPatch_field;
75 class BPatch_variableExpr;
76
77
78 #ifndef OLD_LINE_INFO
79 template class  dictionary_hash <pdstring, FunctionInfo *>;
80 template class  pdvector< dictionary_hash <pdstring, FunctionInfo * >::entry >;
81 template class  dictionary_hash_iter <pdstring, FunctionInfo *>;
82
83 template class  dictionary_hash <pdstring, FileLineInformation *>;
84 template class  pdvector< dictionary_hash <pdstring, FileLineInformation * >::entry >;
85 template class  dictionary_hash_iter <pdstring, FileLineInformation *>;
86
87 template class pdvector<tuple *>;
88 template class std::map<unsigned short, pdvector<tuple *> *, std::less<unsigned short> >;
89 template class std::map<Address, pdvector<tuple *> *, std::less<Address> >;
90 #endif
91 #endif
92
93 #ifndef alpha_dec_osf4_0
94 // ld on Alpha complains about the vector<pdstring> class being
95 // multiply defined with the following line in.  Perhaps
96 // it automatically generates vector<pdstring> when it sees
97 // pair<pdstring, vector<pdstring> > in the line after.
98 //
99 // Ray Chen 6/18/2002
100 template class pdvector<pdstring>;
101 #endif
102 template class pdpair<pdstring, pdvector<pdstring> >;
103
104 template class pdvector<pdpair<pdstring, pdvector<pdstring> > >;
105 template class pdvector<pdvector<int_function * >* >;
106
107 template class  dictionary_hash_iter <Address, Symbol*>;
108 template class  dictionary_hash_iter <instPoint*, unsigned>;
109 template class  dictionary_hash_iter <pdstring, Symbol>;
110 template class  dictionary_hash_iter <pdstring, internalSym*>;
111 template class  dictionary_hash_iter <pdstring, pdmodule *>;
112 template class  dictionary_hash_iter <pdstring, int_function*>;
113 template class  dictionary_hash_iter <pdstring, unsigned>;
114 template class  dictionary_hash_iter <pdstring, pdvector<int_function*>*>;
115 template class  dictionary_hash_iter <unsigned, unsigned>;
116 template class  dictionary_hash_iter <unsigned, heapItem*>;
117 template class  dictionary_hash_iter <unsigned, int_function*>;
118 template class  dictionary_hash_iter <unsigned long, int_function*>;
119 template class  pdvector<shared_object *> ;
120
121
122 template class dictionary_hash<pdstring, libraryCallback *>;
123 template class pdvector<dictionary_hash <pdstring, libraryCallback *>::entry>;
124
125 template class pdvector<syscallTrap *>;
126
127 /* ***************************************************************************** */
128
129 //#ifdef BPATCH_LIBRARY
130 template class dictionary_hash <pdstring, Symbol>;
131 template class pdvector<dictionary_hash <pdstring, Symbol>::entry>;
132 template class pdvector<dictionary_hash<Address, BPatch_point *>::entry>;
133
134 template class dictionary_hash<pdstring, BPatch_type *>;
135 template class dictionary_hash<int, BPatch_type *>;
136 template class dictionary_hash<pdstring, BPatch_localVar *>;
137 template class dictionary_hash<int, BPatch_thread *>;
138 template class dictionary_hash<Address, BPatch_point *>;
139
140 template class dictionary_hash_iter<pdstring, BPatch_type *>;
141 template class pdvector<dictionary_hash <pdstring, BPatch_type *>::entry>;
142 template class dictionary_hash_iter<int, BPatch_type *>;
143 template class pdvector<dictionary_hash <int, BPatch_type *>::entry>;
144 template class dictionary_hash_iter<pdstring, BPatch_localVar *>;
145 template class pdvector<dictionary_hash <pdstring, BPatch_localVar *>::entry>;
146 template class dictionary_hash_iter<int, BPatch_thread *>;
147 template class pdvector<dictionary_hash <int, BPatch_thread *>::entry>;
148
149 template class pdvector<BPatch_localVar *>;
150 template class pdvector<BPatch_field *>;
151 //#endif
152
153 template class pdvector<procevent *>;
154
155 template class pdvector<pdpair<pdstring, pdvector<pdstring> *> >;
156 template class dictionary_hash <pdstring, pdvector<pdstring> *>;
157 template class pdvector<dictionary_hash <pdstring, pdvector<pdstring> *>::entry>;
158
159 template class pdvector<inferiorRPCtoDo>;
160 template class pdvector<inferiorRPCinProgress>;
161
162 template class pdvector<dictionary_hash <unsigned int, Address>::entry>;
163
164 class BPatch_basicBlock;
165
166 template class  dictionary_hash<Address,BPatch_basicBlock*>;
167 template class  pdvector<dictionary_hash<Address,BPatch_basicBlock*>::entry>;
168
169 #ifndef BPATCH_LIBRARY
170 class defInst;
171 template class pdvector<defInst *>;
172 #endif
173
174 #if defined( USES_DWARF_DEBUG )
175 #include <stack>
176 template class std::deque< long int >;
177 template class std::stack< long int >;
178 #include <map>
179 template class std::map< unsigned int, char * >;
180
181 template class dictionary_hash< pdstring, BPatch_typeCollection * >;
182 template class pdvector<dictionary_hash <pdstring, BPatch_typeCollection *>::entry>;
183 #endif
184
185 /* For use with regexes.  gcc 2.95.3 on alpha needs these to be made explicit. */
186 template class pdvector< pdpair< pdstring, int_function *> >;
187 template class pdvector< pdpair< pdstring, pdvector< int_function * > * > >;
188
189 #include "BPatch_asyncEventHandler.h"
190 /* From class BPatch_asyncEventHandler */
191 template class pdvector<process_record>;
192 template class pdvector<BPatchSnippetHandle *>;
193 template class pdvector<BPatch_function *>;
194 template class pdvector<BPatchThreadEventCallback>;
195 template class pdvector<BPatch_asyncEventRecord>;
196 template class pdvector<dyncall_cb_record>;
197 template class pdvector<thread_event_cb_record>;
198 template class pdvector<dyncall_cb_record *>;
199 template class pdvector<BPatch_eventMailbox::mb_callback_t>;
200
201 #if defined( arch_ia64 )
202 #include <list>
203 template class std::list< BPatch_basicBlock *>;
204 #endif /* defined( arch_ia64 ) */