2017-11-18 02:14:09 +08:00
|
|
|
//===- SymbolTable.h --------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2017-11-18 02:14:09 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLD_WASM_SYMBOL_TABLE_H
|
|
|
|
#define LLD_WASM_SYMBOL_TABLE_H
|
|
|
|
|
|
|
|
#include "InputFiles.h"
|
2018-05-31 02:07:52 +08:00
|
|
|
#include "LTO.h"
|
2017-11-18 02:14:09 +08:00
|
|
|
#include "Symbols.h"
|
2018-11-27 09:08:16 +08:00
|
|
|
#include "lld/Common/LLVM.h"
|
2017-11-18 02:14:09 +08:00
|
|
|
#include "llvm/ADT/CachedHashString.h"
|
2018-03-14 23:45:11 +08:00
|
|
|
#include "llvm/ADT/DenseSet.h"
|
2017-11-18 02:14:09 +08:00
|
|
|
|
|
|
|
namespace lld {
|
|
|
|
namespace wasm {
|
|
|
|
|
|
|
|
class InputSegment;
|
|
|
|
|
|
|
|
// SymbolTable is a bucket of all known symbols, including defined,
|
|
|
|
// undefined, or lazy symbols (the last one is symbols in archive
|
|
|
|
// files whose archive members are not yet loaded).
|
|
|
|
//
|
|
|
|
// We put all symbols of all files to a SymbolTable, and the
|
|
|
|
// SymbolTable selects the "best" symbols if there are name
|
|
|
|
// conflicts. For example, obviously, a defined symbol is better than
|
|
|
|
// an undefined symbol. Or, if there's a conflict between a lazy and a
|
|
|
|
// undefined, it'll read an archive member to read a real definition
|
|
|
|
// to replace the lazy symbol. The logic is implemented in the
|
|
|
|
// add*() functions, which are called by input files as they are parsed.
|
|
|
|
// There is one add* function per symbol type.
|
|
|
|
class SymbolTable {
|
|
|
|
public:
|
2019-07-11 13:40:30 +08:00
|
|
|
void wrap(Symbol *sym, Symbol *real, Symbol *wrap);
|
2019-05-24 22:14:25 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
void addFile(InputFile *file);
|
2017-11-18 02:14:09 +08:00
|
|
|
|
2019-05-24 22:14:25 +08:00
|
|
|
void addCombinedLTOObject();
|
2017-11-18 02:14:09 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
ArrayRef<Symbol *> getSymbols() const { return symVector; }
|
2019-02-06 10:35:18 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
Symbol *find(StringRef name);
|
2017-11-18 02:14:09 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
void replace(StringRef name, Symbol* sym);
|
2019-02-21 07:19:31 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
void trace(StringRef name);
|
2019-02-06 10:35:18 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
Symbol *addDefinedFunction(StringRef name, uint32_t flags, InputFile *file,
|
|
|
|
InputFunction *function);
|
|
|
|
Symbol *addDefinedData(StringRef name, uint32_t flags, InputFile *file,
|
|
|
|
InputSegment *segment, uint32_t address,
|
|
|
|
uint32_t size);
|
|
|
|
Symbol *addDefinedGlobal(StringRef name, uint32_t flags, InputFile *file,
|
|
|
|
InputGlobal *g);
|
|
|
|
Symbol *addDefinedEvent(StringRef name, uint32_t flags, InputFile *file,
|
|
|
|
InputEvent *e);
|
2018-02-28 08:09:22 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
Symbol *addUndefinedFunction(StringRef name, StringRef importName,
|
|
|
|
StringRef importModule, uint32_t flags,
|
|
|
|
InputFile *file, const WasmSignature *signature,
|
|
|
|
bool isCalledDirectly);
|
|
|
|
Symbol *addUndefinedData(StringRef name, uint32_t flags, InputFile *file);
|
|
|
|
Symbol *addUndefinedGlobal(StringRef name, StringRef importName,
|
|
|
|
StringRef importModule, uint32_t flags,
|
|
|
|
InputFile *file, const WasmGlobalType *type);
|
2018-02-28 08:09:22 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
void addLazy(ArchiveFile *f, const llvm::object::Archive::Symbol *sym);
|
2018-03-02 07:29:05 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
bool addComdat(StringRef name);
|
2017-11-18 02:14:09 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
DefinedData *addSyntheticDataSymbol(StringRef name, uint32_t flags);
|
|
|
|
DefinedGlobal *addSyntheticGlobal(StringRef name, uint32_t flags,
|
|
|
|
InputGlobal *global);
|
|
|
|
DefinedFunction *addSyntheticFunction(StringRef name, uint32_t flags,
|
|
|
|
InputFunction *function);
|
|
|
|
DefinedData *addOptionalDataSymbol(StringRef name, uint32_t value = 0,
|
|
|
|
uint32_t flags = 0);
|
2018-02-23 13:08:53 +08:00
|
|
|
|
2019-02-21 07:19:31 +08:00
|
|
|
void handleSymbolVariants();
|
2019-02-08 06:42:16 +08:00
|
|
|
void handleWeakUndefines();
|
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
std::vector<ObjFile *> objectFiles;
|
|
|
|
std::vector<SharedFile *> sharedFiles;
|
|
|
|
std::vector<BitcodeFile *> bitcodeFiles;
|
|
|
|
std::vector<InputFunction *> syntheticFunctions;
|
|
|
|
std::vector<InputGlobal *> syntheticGlobals;
|
2019-05-24 22:14:25 +08:00
|
|
|
|
2017-11-18 02:14:09 +08:00
|
|
|
private:
|
2019-07-11 13:40:30 +08:00
|
|
|
std::pair<Symbol *, bool> insert(StringRef name, const InputFile *file);
|
|
|
|
std::pair<Symbol *, bool> insertName(StringRef name);
|
2017-11-18 02:14:09 +08:00
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
bool getFunctionVariant(Symbol* sym, const WasmSignature *sig,
|
|
|
|
const InputFile *file, Symbol **out);
|
|
|
|
InputFunction *replaceWithUnreachable(Symbol *sym, const WasmSignature &sig,
|
|
|
|
StringRef debugName);
|
2019-02-08 06:42:16 +08:00
|
|
|
|
2019-02-06 10:35:18 +08:00
|
|
|
// Maps symbol names to index into the SymVector. -1 means that symbols
|
|
|
|
// is to not yet in the vector but it should have tracing enabled if it is
|
|
|
|
// ever added.
|
2019-07-11 13:40:30 +08:00
|
|
|
llvm::DenseMap<llvm::CachedHashStringRef, int> symMap;
|
|
|
|
std::vector<Symbol *> symVector;
|
2018-03-02 07:29:05 +08:00
|
|
|
|
2019-02-21 07:19:31 +08:00
|
|
|
// For certain symbols types, e.g. function symbols, we allow for muliple
|
|
|
|
// variants of the same symbol with different signatures.
|
2019-07-11 13:40:30 +08:00
|
|
|
llvm::DenseMap<llvm::CachedHashStringRef, std::vector<Symbol *>> symVariants;
|
2019-02-21 07:19:31 +08:00
|
|
|
|
2019-05-16 00:03:28 +08:00
|
|
|
// Comdat groups define "link once" sections. If two comdat groups have the
|
|
|
|
// same name, only one of them is linked, and the other is ignored. This set
|
|
|
|
// is used to uniquify them.
|
2019-07-11 13:40:30 +08:00
|
|
|
llvm::DenseSet<llvm::CachedHashStringRef> comdatGroups;
|
2018-05-31 02:07:52 +08:00
|
|
|
|
|
|
|
// For LTO.
|
2019-07-11 13:40:30 +08:00
|
|
|
std::unique_ptr<BitcodeCompiler> lto;
|
2017-11-18 02:14:09 +08:00
|
|
|
};
|
|
|
|
|
2019-07-11 13:40:30 +08:00
|
|
|
extern SymbolTable *symtab;
|
2017-11-18 02:14:09 +08:00
|
|
|
|
|
|
|
} // namespace wasm
|
|
|
|
} // namespace lld
|
|
|
|
|
|
|
|
#endif
|