• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2011, The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ELF_SECTION_SYM_TAB_HXX
18 #define ELF_SECTION_SYM_TAB_HXX
19 
20 #include "ELFSectionHeader.h"
21 #include "ELFSymbol.h"
22 #include "utils/rsl_assert.h"
23 
24 template <unsigned Bitwidth>
~ELFSectionSymTab()25 ELFSectionSymTab<Bitwidth>::~ELFSectionSymTab() {
26   for (size_t i = 0; i < table.size(); ++i) {
27     delete table[i];
28   }
29 }
30 
31 template <unsigned Bitwidth>
getFuncCount() const32 size_t ELFSectionSymTab<Bitwidth>::getFuncCount() const {
33   size_t result = 0;
34   for (size_t i = 0; i < table.size(); ++i) {
35     if (table[i] && table[i]->isConcreteFunc()) {
36       result++;
37     }
38   }
39   return result;
40 }
41 
42 template <unsigned Bitwidth>
getExternFuncCount() const43 inline size_t ELFSectionSymTab<Bitwidth>::getExternFuncCount() const {
44   size_t result = 0;
45   for (size_t i = 0; i < table.size(); ++i) {
46     if (table[i] && table[i]->isExternFunc()) {
47       result++;
48     }
49   }
50   return result;
51 }
52 
53 template <unsigned Bitwidth>
buildNameMap()54 inline void ELFSectionSymTab<Bitwidth>::buildNameMap() {
55   for (size_t i = 0; i < table.size(); ++i) {
56     ELFSymbolTy *symbol = table[i];
57     if ( symbol ) {
58       name_map[symbol->getName()] = symbol;
59     }
60   }
61 }
62 
63 template <unsigned Bitwidth>
64 inline ELFSymbol<Bitwidth> const *
getByName(std::string const & name) const65 ELFSectionSymTab<Bitwidth>::getByName(std::string const &name) const {
66   typename llvm::StringMap<ELFSymbolTy *>::const_iterator symbol =
67     name_map.find(name);
68   if (symbol == name_map.end()) {
69     return NULL;
70   }
71   return symbol->getValue();
72 }
73 
74 template <unsigned Bitwidth>
75 inline void
getFuncNameList(size_t size,char const ** list) const76 ELFSectionSymTab<Bitwidth>::getFuncNameList(size_t size,
77                                             char const **list) const {
78   for (size_t i = 0, j = 0; i < table.size() && j < size; ++i) {
79     if (table[i] && table[i]->isConcreteFunc()) {
80       list[j++] = table[i]->getName();
81     }
82   }
83 }
84 
85 template <unsigned Bitwidth>
86 template <typename Archiver>
87 ELFSectionSymTab<Bitwidth> *
read(Archiver & AR,ELFObjectTy * owner,ELFSectionHeaderTy const * sh)88 ELFSectionSymTab<Bitwidth>::read(Archiver &AR,
89                                  ELFObjectTy *owner,
90                                  ELFSectionHeaderTy const *sh) {
91 
92   std::unique_ptr<ELFSectionSymTabTy> st(new ELFSectionSymTabTy());
93 
94   // Assert that entry size will be the same as standard.
95   rsl_assert(sh->getEntrySize() == TypeTraits<ELFSymbolTy>::size);
96 
97   // Seek to the start of symbol table
98   AR.seek(sh->getOffset(), true);
99 
100   // Read all symbol table entry
101   size_t size = sh->getSize() / sh->getEntrySize();
102   for (size_t i = 0; i < size; ++i) {
103     st->table.push_back(ELFSymbolTy::read(AR, owner, i));
104   }
105 
106   if (!AR) {
107     // Unable to read the table.
108     return 0;
109   }
110 
111   return st.release();
112 }
113 
114 template <unsigned Bitwidth>
print() const115 void ELFSectionSymTab<Bitwidth>::print() const {
116   using namespace llvm;
117 
118   out() << '\n' << fillformat('=', 79) << '\n';
119   out().changeColor(raw_ostream::WHITE, true);
120   out() << "Symbol Table" << '\n';
121   out().resetColor();
122 
123   for (size_t i = 0; i < table.size(); ++i) {
124     table[i]->print();
125   }
126 
127   out() << fillformat('=', 79) << '\n';
128 }
129 
130 #endif // ELF_SECTION_SYM_TAB_HXX
131