Update copyright
[dyninst.git] / dyninstAPI_RT / src / RTstatic_ctors_dtors-x86.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 #if defined(DYNINST_RT_STATIC_LIB)
33 void (*DYNINSTctors_addr)(void);
34 void (*DYNINSTdtors_addr)(void);
35
36 #if defined(MUTATEE64)
37 static const unsigned long long CTOR_LIST_TERM = 0x0000000000000000ULL;
38 static const unsigned long long CTOR_LIST_START = 0xffffffffffffffffULL;
39 static const unsigned long long DTOR_LIST_TERM = 0x0000000000000000ULL;
40 static const unsigned long long DTOR_LIST_START = 0xffffffffffffffffULL;
41 #else
42 static const unsigned CTOR_LIST_TERM = 0x00000000;
43 static const unsigned CTOR_LIST_START = 0xffffffff;
44 static const unsigned DTOR_LIST_TERM = 0x00000000;
45 static const unsigned DTOR_LIST_START = 0xffffffff;
46 #endif
47
48 extern void DYNINSTBaseInit();
49
50 /*
51  * When rewritting a static binary, .ctors and .dtors sections of
52  * instrumentation code needs to be combined with the existing .ctors
53  * and .dtors sections of the static binary.
54  *
55  * The following functions process the .ctors and .dtors sections
56  * that have been rewritten. The rewriter will relocate the 
57  * address of DYNINSTctors_addr and DYNINSTdtors_addr to point to
58  * new .ctors and .dtors sections.
59  */
60
61 void DYNINSTglobal_ctors_handler() {
62     void (**ctors_array)(void) = &DYNINSTctors_addr;
63
64     // Find end of function pointer list
65     void (**tmp_ptr)(void) = ctors_array;
66     unsigned size = 0;
67     while( *tmp_ptr != ( (void(*)(void))CTOR_LIST_TERM ) ) {
68         size++;
69         tmp_ptr++;
70     }
71
72     // Constructors are called in the reverse order that they are listed
73     tmp_ptr = &ctors_array[size-1]; // skip list end
74     while( *tmp_ptr != ( (void(*)(void))CTOR_LIST_START ) ) {
75         (*tmp_ptr)();
76         tmp_ptr--;
77     }
78
79     // This ensures that instrumentation cannot execute until all global
80     // constructors have run
81     DYNINSTBaseInit();
82 }
83
84 void DYNINSTglobal_dtors_handler() {
85     void (**dtors_array)(void) = &DYNINSTdtors_addr;
86
87     // Destructors are called in the forward order that they are listed
88     void (**tmp_ptr)(void) = &dtors_array[1]; // skip list start
89     while( *tmp_ptr != ( (void(*)(void))DTOR_LIST_TERM ) ) {
90         (*tmp_ptr)();
91         tmp_ptr++;
92     }
93 }
94
95 #endif