Initial Check-in
[dyninst.git] / dyninstAPI / src / parRegion.h
1 /*
2  * Copyright (c) 1996-2006 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
43 #ifndef PARREGION_H
44 #define PARREGION_H
45
46 #include "common/h/String.h"
47 #include "common/h/Vector.h"
48 #include "common/h/Types.h"
49 #include "common/h/Pair.h"
50 #include "codeRange.h"
51 #include "arch.h" // instruction
52 #include "dyninstAPI/h/BPatch_Set.h"
53 #include "dyninstAPI/h/BPatch_parRegion.h"
54 #include "common/h/Dictionary.h"
55 #include <map>
56
57 class process;
58 class mapped_module;
59 class mapped_object;
60
61 class pdmodule;
62 class InstrucIter;
63 class image_func;
64
65 /*
66 typedef enum{
67   OMP_NONE, OMP_PARALLEL, OMP_DO_FOR,OMP_DO_FOR_LOOP_BODY, OMP_SECTIONS, OMP_SINGLE, 
68     OMP_PAR_DO, OMP_PAR_SECTIONS, OMP_MASTER, OMP_CRITICAL,
69     OMP_BARRIER, OMP_ATOMIC, OMP_FLUSH, OMP_ORDERED
70     } parRegType;
71 */
72
73 struct ltstr
74 {
75   bool operator()(const char* s1, const char* s2) const
76   {
77     return strcmp(s1, s2) < 0;
78   }
79 };
80
81
82 class image_parRegion : public codeRange {
83  public:
84   image_parRegion(image_func * imageFunc);
85   image_parRegion(Address firstOffset, image_func * imageFunc);
86  
87   Address firstInsnOffset() const { return firstInsnOffset_; }
88
89   void setLastInsn(Address last) { lastInsnOffset_ = last;}
90   Address lastInsnOffset() const { return lastInsnOffset_; }
91   Address getSize() const { return lastInsnOffset_ - firstInsnOffset_; }
92
93   Address get_address_cr() const {return firstInsnOffset_; }
94   unsigned int get_size_cr() const {return 0;}
95
96   parRegType getRegionType(){return regionType;}
97
98   void setRegionType(parRegType rt); 
99
100   image_func * getAssociatedFunc();
101
102   void setParentFunc(image_func * parentFunc){parentIf_ = parentFunc;}
103   image_func * getParentFunc(){return parentIf_;}
104
105   void setClause(const char * key, int value);
106   int getClause(const char * key);
107
108   void setClauseLoc(const char * key, Address value);
109   Address getClauseLoc(const char * key);
110   
111   void printDetails();
112
113   void decodeClauses(int bitmap);
114
115  private:
116   image_func *regionIf_;
117   image_func *parentIf_;
118   Address firstInsnOffset_;
119   Address lastInsnOffset_;
120   parRegType regionType;
121   std::map<const char*, int, ltstr> clauses;
122   std::map<const char*, Address, ltstr> clause_locations;
123 };
124
125
126 class int_parRegion {
127  public:
128   int_parRegion(image_parRegion *ip, Address baseAddr, int_function * );
129   ~int_parRegion();
130
131   Address firstInsnAddr() {return addr_;}
132   Address endAddr() {return endAddr_;}
133
134   const image_parRegion * imagePar() const { return ip_; }
135   
136   void printDetails() { ip_->printDetails(); }
137
138   const int_function * intFunc() { return intFunc_;}
139
140   int getClause(const char * key);
141   Address getClauseLoc(const char * key);
142
143   int replaceOMPParameter(const char * key, int value);
144
145   Address addr_; /* Absolute address of start of region */
146   Address endAddr_; /* Address of end of region */
147
148   int_function * intFunc_;
149
150   image_parRegion *ip_;
151 };
152
153
154
155
156 #endif /*PARREGION_H */