Update copyright to LGPL on all files
[dyninst.git] / dyninstAPI / src / BPatch_instruction.C
1 /*
2  * Copyright (c) 1996-2009 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  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31
32 #include "common/h/Types.h"
33
34 #include <stdlib.h>
35 #include <string.h>
36 #include <assert.h>
37 #include "BPatch.h"
38 #include "BPatch_instruction.h"
39 #include "BPatch_basicBlock.h"
40 #include "BPatch_libInfo.h"
41 #include "BPatch_process.h"
42 #include "arch.h"
43 #include "util.h"
44 #include "function.h"
45 #include "process.h"
46 #include "instPoint.h"
47
48 /**************************************************************************
49  * BPatch_instruction
50  *************************************************************************/
51
52 #if defined(arch_x86) || defined(arch_x86_64)
53 const unsigned int BPatch_instruction::nmaxacc_NP = 2;
54 #else
55 const unsigned int BPatch_instruction::nmaxacc_NP = 1;
56 #endif
57
58 BPatch_instruction::BPatch_instruction(instruction *insn,
59                                        Address addr_) : nacc(0), insn_(insn), addr(addr_)
60 {
61   isLoad = new bool[nmaxacc_NP];
62   isStore = new bool[nmaxacc_NP];
63   preFcn = new int[nmaxacc_NP];
64   condition = new int[nmaxacc_NP];
65   nonTemporal = new bool[nmaxacc_NP];
66
67   for (unsigned int i=0; i < nmaxacc_NP; i++) {
68     isLoad[i] = false;
69     isStore[i] = false;
70     preFcn[i] = -1;
71     condition[i] = -1;
72     nonTemporal[i] = false;
73   }
74
75 }
76
77 instruction *BPatch_instruction::insn() { return insn_; }
78
79 BPatch_instruction::~BPatch_instruction() {
80
81    delete[] isLoad;
82    delete[] isStore;
83    delete[] preFcn;
84    delete[] condition;
85    delete[] nonTemporal;
86 }
87
88 BPatch_basicBlock *BPatch_instruction::getParentInt()
89 {
90   return parent;
91 }
92
93 void *BPatch_instruction::getAddressInt()
94 {
95   return (void *)addr;
96 }
97 BPatch_point *BPatch_instruction::getInstPointInt()
98 {
99   //const unsigned char *insn_ptr = ((instruction *)instr)->ptr();
100   int_basicBlock *iblock = parent->iblock;
101   AddressSpace *proc = iblock->proc();
102   int_function *func = iblock->func();
103
104   assert(proc);
105   assert(func);
106
107   //BPatch_process *bpproc = (BPatch_process *)proc->up_ptr();
108   
109   BPatch_addressSpace *bpproc = (BPatch_addressSpace *)proc->up_ptr();
110   //  assert(bpproc); 
111   assert(bpproc);
112
113   // If it's in an uninstrumentable function, just return an error.
114   if ( !func || !((int_function*)func)->isInstrumentable()){
115     fprintf(stderr, "%s[%d]:  function is not instrumentable\n", FILE__, __LINE__);
116     return NULL;
117   }
118
119  /* See if there is an instPoint at this address */
120   instPoint *p = NULL;
121
122   if ((p = func->findInstPByAddr((Address)addr))) {
123     return bpproc->findOrCreateBPPoint(NULL, p, BPatch_locInstruction);
124   }
125
126   /* We don't have an instPoint for this address, so make one. */
127   instPoint *newInstP = instPoint::createArbitraryInstPoint((Address)addr, proc, func);
128   
129   if (!newInstP) {
130      fprintf(stderr, "%s[%d]:  createArbitraryInstPoint for %p failed\n", FILE__, __LINE__, (void *) addr);
131      return NULL;
132   }
133   BPatch_point *ret = bpproc->findOrCreateBPPoint(NULL, newInstP, BPatch_locInstruction);
134
135   if (!ret)
136     fprintf(stderr, "%s[%d]:  getInstPoint failing!\n", FILE__, __LINE__);
137   return ret;
138 }
139
140 std::string BPatch_register::nameInt() {
141     return name_;
142 }
143