Update copyright to LGPL on all files
[dyninst.git] / dyninstAPI / src / trapMappings.h
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 #if !defined(trapMappings_h_)
33 #define trapMappings_h_
34
35 #define MIN_TRAP_TABLE_SIZE 256
36 #define INDEX_INVALID UINT_MAX
37
38 #include <vector>
39 #include <set>
40
41 class AddressSpace;
42 class int_variable;
43
44 class trampTrapMappings {
45  public:
46    typedef struct {
47       Address from_addr;
48       Address to_addr;
49       bool written;
50       bool mutatee_side;
51       unsigned cur_index;
52    } tramp_mapping_t;
53  private:
54
55    dyn_hash_map<Address, tramp_mapping_t> mapping;
56    std::set<tramp_mapping_t *> updated_mappings;
57
58    static void arrange_mapping(tramp_mapping_t &m, bool should_sort,
59                                std::vector<tramp_mapping_t*> &mappings_to_add,
60                                std::vector<tramp_mapping_t*> &mappings_to_update);
61
62    bool needs_updating;
63    AddressSpace *as;
64
65    const int_variable *trapTableUsed;
66    const int_variable *trapTableVersion;
67    const int_variable *trapTable;
68    const int_variable *trapTableSorted;
69
70    void writeToBuffer(unsigned char *buffer, unsigned long val, 
71                       unsigned addr_width);
72    void writeTrampVariable(const int_variable *var, unsigned long val);
73
74    unsigned long table_version;
75    unsigned long table_used;
76    unsigned long table_allocated;
77    unsigned long table_mutatee_size;
78    Address current_table;
79    Address table_header;
80    bool blockFlushes;
81    
82  public:
83    trampTrapMappings(AddressSpace *a);
84    void copyTrapMappings(trampTrapMappings *parent);
85    void clearTrapMappings();
86
87    void addTrapMapping(Address from, Address to, bool write_to_mutatee = false);
88    Address getTrapMapping(Address from);
89    bool definesTrapMapping(Address from);
90    bool needsUpdating();
91    void flush();
92    void allocateTable();
93    void shouldBlockFlushes(bool b) { blockFlushes = b; }
94
95    bool empty();
96
97    AddressSpace *proc() const;
98 };
99
100 #endif