ELF section header contains links to the other sections containing data.
[dyninst.git] / symtabAPI / src / emitElf.h
1 /*
2  * Copyright (c) 1996-2007 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(_emit_Elf_h_)
33 #define _emit_Elf_h_
34
35 #include "Object.h"
36
37 namespace Dyninst{
38 namespace SymtabAPI{
39
40 class emitElf{
41   public:
42     emitElf(Elf_X &oldElfHandle_, bool isStripped_ = false, int BSSexpandflag = false, void (*)(const char *) = log_msg);
43     ~emitElf();
44     bool createSymbolTables(Symtab *obj, vector<Symbol *>&allSymbols, std::vector<relocationEntry> &relocation_table, std::vector<relocationEntry> &fbt);
45     bool driver(Symtab *obj, std::string fName);
46  
47   private:
48     Elf_X oldElfHandle;
49     Elf *newElf;
50     Elf *oldElf;
51     
52     //New Section & Program Headers
53     Elf32_Ehdr *newEhdr;
54     Elf32_Ehdr *oldEhdr;
55     
56     Elf32_Phdr *newPhdr;
57     Elf32_Phdr *oldPhdr;
58
59     //important data sections in the
60     //new Elf that need updated
61     Elf_Data *textData;
62     Elf_Data *symStrData;
63     Elf_Data *dynStrData;
64     char *olddynStrData;
65     Elf_Data *symTabData;
66     Elf_Data *hashData;
67     Elf_Data *dynsymData;
68     Elf_Data *dynData;
69     Elf_Data *rodata;
70     Elf_Data *dataData;
71     
72     Elf32_Shdr *textSh;
73     Elf32_Shdr *rodataSh;
74     
75     std::vector<Region *>nonLoadableSecs;
76     std::vector<Region *> newSecs;
77 #if !defined(os_solaris)
78     std::map<unsigned, std::vector<Elf32_Dyn *> > dynamicSecData;
79     std::vector<std::string> DT_NEEDEDEntries;
80     std::vector<std::string> unversionedNeededEntries;
81 #endif
82
83     // Symbol version table data
84     std::map<std::string, std::map<std::string, unsigned> >verneedEntries;    //verneed entries
85     std::map<std::string, unsigned> verdefEntries;                            //verdef entries
86     std::map<unsigned, std::vector<std::string> > verdauxEntries;
87     std::map<std::string, unsigned> versionNames;
88     std::vector<Elf32_Half> versionSymTable;
89     int curVersionNum, verneednum, verdefnum;
90
91     // Needed when adding a new segment
92     Elf32_Off newSegmentStart;
93     Elf32_Shdr *firstNewLoadSec;// initialize to NULL
94  
95     //text & data segment ends
96     Elf32_Off dataSegEnd, textSegEnd;
97     Elf32_Off dynSegOff, dynSegAddr;
98     unsigned dynSegSize;
99
100     //Section Names for all sections
101     vector<std::string> secNames;
102     unsigned secNameIndex;
103
104     //flags
105     // Expand NOBITS sections within the object file to their size
106     bool BSSExpandFlag;
107     bool addNewSegmentFlag;
108     
109     bool isStripped;
110
111     void (*err_func_)(const char*);
112
113     bool createElfSymbol(Symbol *symbol, std::vector<std::string> &symbolstrs, unsigned &symbolNamesLength, vector<Elf32_Sym *> &symbols, bool dynSymFlag = false);
114     void findSegmentEnds();
115     void renameSection(const std::string &oldStr, const std::string &newStr, bool renameAll=true);
116     void fixPhdrs(unsigned &, unsigned &);
117     bool addSectionHeaderTable(Elf32_Shdr *shdr);
118     bool createNonLoadableSections(Elf32_Shdr *& shdr);
119     bool createLoadableSections( Elf32_Shdr *shdr, unsigned &loadSecTotalSize, unsigned &, dyn_hash_map<std::string,  unsigned>& newIndexMapping);
120     void createRelocationSections(Symtab *obj, std::vector<relocationEntry> &relocation_table, std::vector<relocationEntry> &fbt, dyn_hash_map<std::string, unsigned> &dynSymNameMapping);
121
122     void updateSymbols(Elf_Data* symtabData,Elf_Data* strData, unsigned long loadSecsSize);
123
124 #if !defined(os_solaris)
125     void updateDynamic(unsigned tag, Elf32_Addr val);
126     void createSymbolVersions(Symtab *obj, Elf32_Half *&symVers, char*&verneedSecData, unsigned &verneedSecSize, char *&verdefSecData, unsigned &verdefSecSize, unsigned &dynSymbolNamesLength, std::vector<std::string> &dynStrs);
127     void createHashSection(Elf32_Word *&hashsecData, unsigned &hashsecSize, std::vector<Symbol *>&dynSymbols);
128     void createDynamicSection(void *dynData, unsigned size, Elf32_Dyn *&dynsecData, unsigned &dynsecSize, unsigned &dynSymbolNamesLength, std::vector<std::string> &dynStrs);
129 #endif 
130
131     void log_elferror(void (*err_func)(const char *), const char* msg);
132 };
133
134 } // namespace SymtabAPI
135 } // namespace Dyninst
136
137 #endif