Infrastructure for SW CallTrees and group operations
[dyninst.git] / stackwalk / src / procstate.C
1 /*
2  * Copyright (c) 1996-2011 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 "stackwalk/h/swk_errors.h"
33 #include "stackwalk/h/procstate.h"
34 #include "stackwalk/src/libstate.h"
35 #include "common/h/headers.h"
36 #include <assert.h>
37 #include <string>
38 #include <vector>
39
40 using namespace Dyninst;
41 using namespace Dyninst::Stackwalker;
42 using namespace std;
43
44 class DefaultLibState : public LibraryState
45 {
46 public:
47    DefaultLibState(ProcessState *parent) : 
48       LibraryState(parent) 
49    {
50    }
51
52    virtual bool getLibraryAtAddr(Address, LibAddrPair &) {
53       return false;
54    }
55
56    virtual bool getLibraries(std::vector<LibAddrPair> &) {
57       return false;
58    }
59
60    virtual void notifyOfUpdate() {
61    }
62
63    virtual Address getLibTrapAddress() {
64       return 0x0;
65    }
66
67    ~DefaultLibState() { 
68    }
69 };
70
71 std::map<Dyninst::PID, ProcessState *> ProcessState::proc_map;
72
73 ProcessState::ProcessState(Dyninst::PID pid_, std::string executable_path_) :
74    library_tracker(NULL),
75    executable_path(executable_path_)
76 {
77    std::map<PID, ProcessState *>::iterator i = proc_map.find(pid_);
78    if (i != proc_map.end())
79    {
80       sw_printf("[%s:%u] - Already attached to debuggee %d\n",
81                 __FILE__, __LINE__, pid_);
82       setLastError(err_badparam, "Attach requested to already " \
83                    "attached process");
84       return;
85    }
86    setPid(pid_);
87 }
88
89 void ProcessState::setPid(Dyninst::PID pid_)
90 {
91    pid = pid_;
92    proc_map[pid] = this;
93 }
94
95 Dyninst::PID ProcessState::getProcessId() 
96 {
97    return pid;
98 }
99
100 bool ProcessState::preStackwalk(Dyninst::THR_ID)
101 {
102    return true;
103 }
104
105 bool ProcessState::postStackwalk(Dyninst::THR_ID)
106 {
107    return true;
108 }
109
110 void ProcessState::setDefaultLibraryTracker()
111 {
112   if (library_tracker) return;
113
114   std::string execp("");
115   ProcDebug *pd = dynamic_cast<ProcDebug *>(this);
116   if (!library_tracker) {
117      if (pd) 
118         execp = pd->getExecutablePath();
119      library_tracker = new TrackLibState(this, execp);
120   }
121 }
122
123 Walker *ProcessState::getWalker() const
124 {
125    return walker;
126 }
127
128 ProcessState::~ProcessState()
129 {
130    if (library_tracker)
131       delete library_tracker;
132    proc_map.erase(pid);
133 }
134
135 unsigned ProcSelf::getAddressWidth()
136 {
137    return sizeof(void *);
138 }
139
140 bool ProcSelf::isFirstParty()
141 {
142   return true;
143 }
144
145 ProcSelf::~ProcSelf()
146 {
147 }
148
149 LibraryState::LibraryState(ProcessState *parent) :
150    procstate(parent)
151 {
152 }
153
154 LibraryState::~LibraryState()
155 {
156 }
157
158 LibraryState *ProcessState::getLibraryTracker()
159 {
160    return library_tracker;
161 }
162