Initialize thrd in a new FrameNode ctor
[dyninst.git] / stackwalk / src / libstate.h
1 /*
2  * See the dyninst/COPYRIGHT file for copyright information.
3  * 
4  * We provide the Paradyn Tools (below described as "Paradyn")
5  * on an AS IS basis, and do not warrant its validity or performance.
6  * We reserve the right to update, modify, or discontinue this
7  * software at any time.  We shall have no obligation to supply such
8  * updates or modifications or any other form of support to you.
9  * 
10  * By your use of Paradyn, you understand and agree that we (or any
11  * other person or entity with proprietary rights in Paradyn) are
12  * under no obligation to provide either maintenance services,
13  * update services, notices of latent defects, or correction of
14  * defects for Paradyn.
15  * 
16  * This library is free software; you can redistribute it and/or
17  * modify it under the terms of the GNU Lesser General Public
18  * License as published by the Free Software Foundation; either
19  * version 2.1 of the License, or (at your option) any later version.
20  * 
21  * This library is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
24  * Lesser General Public License for more details.
25  * 
26  * You should have received a copy of the GNU Lesser General Public
27  * License along with this library; if not, write to the Free Software
28  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
29  */
30
31 #if !defined(LIBSTATE_H_)
32 #define LIBSTATE_H_
33
34 #include "common/h/ProcReader.h"
35 #include "common/h/SymReader.h"
36 #include "stackwalk/h/procstate.h"
37 #include "common/src/addrtranslate.h"
38 #include <set>
39
40 namespace Dyninst {
41 namespace Stackwalker {
42
43 class swkProcessReader : public ProcessReader {
44  private:
45    ProcessState *procstate;
46  public:
47    swkProcessReader(ProcessState *pstate, std::string executable_);
48    virtual bool start();
49    virtual bool ReadMem(Address inTraced, void *inSelf, unsigned amount);
50    virtual bool GetReg(Dyninst::MachRegister, Dyninst::MachRegisterVal&) { return false; }
51    virtual bool done();
52    virtual ~swkProcessReader();
53 };
54
55 class TrackLibState : public LibraryState {
56  private:
57    bool needs_update;
58    bool has_updated;
59    AddressTranslate *translate;
60    static SymbolReaderFactory *symfactory;
61    swkProcessReader procreader;
62    
63    bool updateLibs();
64    bool refresh();
65    std::vector<std::pair<LibAddrPair, unsigned> > arch_libs;
66
67    void getCurList(std::set<LibAddrPair> &list);
68  public:
69    TrackLibState(ProcessState *parent, std::string executable = "");
70    virtual bool getLibraryAtAddr(Address addr, LibAddrPair &olib);
71    virtual bool getLibraries(std::vector<LibAddrPair> &olibs, bool allow_refresh = true);
72    virtual bool getAOut(LibAddrPair &ao);
73    virtual void notifyOfUpdate();
74    virtual Address getLibTrapAddress();
75    virtual ~TrackLibState();
76 };
77
78 class StaticBinaryLibState : public LibraryState {
79    LibAddrPair the_exe;
80  public:
81    StaticBinaryLibState(ProcessState *parent, std::string executable = "");
82    ~StaticBinaryLibState();
83    virtual bool getLibraryAtAddr(Address addr, LibAddrPair &olib);
84    virtual bool getLibraries(std::vector<LibAddrPair> &olibs, bool allow_refresh = true);
85    virtual bool getLibc(LibAddrPair &lc);
86    virtual bool getLibthread(LibAddrPair &lt);
87    virtual bool getAOut(LibAddrPair &ao);
88    virtual void notifyOfUpdate();
89    virtual Address getLibTrapAddress();
90 };
91
92 SymbolReaderFactory *getDefaultSymbolReader();
93
94 class LibraryWrapper {
95   private:
96    std::map<std::string, SymReader *> file_map;
97   public:
98    static SymReader *testLibrary(std::string filename);
99    static SymReader *getLibrary(std::string filename);
100    static void registerLibrary(SymReader *reader, std::string filename);
101 };
102
103 }
104 }
105
106 #endif