merge checkpoint
[dyninst.git] / dyninstAPI / src / BPatch_instruction.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 #include "common/h/Types.h"
43
44 #include <stdlib.h>
45 #include <string.h>
46 #include <assert.h>
47 #include "BPatch.h"
48 #include "BPatch_instruction.h"
49 #include "BPatch_basicBlock.h"
50 #include "BPatch_libInfo.h"
51 #include "BPatch_process.h"
52 #include "arch.h"
53 #include "util.h"
54 #include "function.h"
55 #include "process.h"
56 #include "instPoint.h"
57
58 /**************************************************************************
59  * BPatch_instruction
60  *************************************************************************/
61
62 #if defined(arch_x86) || defined(arch_x86_64)
63 const unsigned int BPatch_instruction::nmaxacc_NP = 2;
64 #else
65 const unsigned int BPatch_instruction::nmaxacc_NP = 1;
66 #endif
67
68 BPatch_instruction::BPatch_instruction(instruction *insn,
69                                        Address addr_) : nacc(0), insn_(insn), addr(addr_)
70 {
71   isLoad = new bool[nmaxacc_NP];
72   isStore = new bool[nmaxacc_NP];
73   preFcn = new int[nmaxacc_NP];
74   condition = new int[nmaxacc_NP];
75   nonTemporal = new bool[nmaxacc_NP];
76
77   for (unsigned int i=0; i < nmaxacc_NP; i++) {
78     isLoad[i] = false;
79     isStore[i] = false;
80     preFcn[i] = -1;
81     condition[i] = -1;
82     nonTemporal[i] = false;
83   }
84
85 }
86
87 instruction *BPatch_instruction::insn() { return insn_; }
88
89 BPatch_instruction::~BPatch_instruction() {
90
91    delete[] isLoad;
92    delete[] isStore;
93    delete[] preFcn;
94    delete[] condition;
95    delete[] nonTemporal;
96 }
97
98 BPatch_basicBlock *BPatch_instruction::getParentInt()
99 {
100   return parent;
101 }
102
103 void *BPatch_instruction::getAddressInt()
104 {
105   return (void *)addr;
106 }
107 BPatch_point *BPatch_instruction::getInstPointInt()
108 {
109   //const unsigned char *insn_ptr = ((instruction *)instr)->ptr();
110   int_basicBlock *iblock = parent->iblock;
111   AddressSpace *proc = iblock->proc();
112   int_function *func = iblock->func();
113
114   assert(proc);
115   assert(func);
116
117   //BPatch_process *bpproc = (BPatch_process *)proc->up_ptr();
118   
119   BPatch_addressSpace *bpproc = (BPatch_addressSpace *)proc->up_ptr();
120   //  assert(bpproc); 
121   assert(bpproc);
122
123   // If it's in an uninstrumentable function, just return an error.
124   if ( !func || !((int_function*)func)->isInstrumentable()){
125     fprintf(stderr, "%s[%d]:  function is not instrumentable\n", FILE__, __LINE__);
126     return NULL;
127   }
128
129  /* See if there is an instPoint at this address */
130   instPoint *p = NULL;
131
132   if ((p = func->findInstPByAddr((Address)addr))) {
133     return bpproc->findOrCreateBPPoint(NULL, p, BPatch_locInstruction);
134   }
135
136   /* We don't have an instPoint for this address, so make one. */
137   instPoint *newInstP = instPoint::createArbitraryInstPoint((Address)addr, proc, func);
138   
139   if (!newInstP) {
140      fprintf(stderr, "%s[%d]:  createArbitraryInstPoint for %p failed\n", FILE__, __LINE__, (void *) addr);
141      return NULL;
142   }
143   BPatch_point *ret = bpproc->findOrCreateBPPoint(NULL, newInstP, BPatch_locInstruction);
144
145   if (!ret)
146     fprintf(stderr, "%s[%d]:  getInstPoint failing!\n", FILE__, __LINE__);
147   return ret;
148 }
149
150 std::string BPatch_register::nameInt() {
151     return name_;
152 }
153