Use ELF function index to distinguish generated functions.
We replaced LLVMLongName and LLVMStubName with ElfFuncName,
and we are using the simple name: Art0, Art1, ..., ArtN,
as the function name of every generated functions. This
gives us 3 benefits:
1. We can avoid the ambiguous function name returned by
LLVMLongName() in some special situation.
2. We don't need to have the art::Method object during
the executable linking procedure. Besides, this will
make bootstrapping easier.
3. Reduce the size of the ELF executable, since we don't
have to save a long function name, which usually contains
more than 30 characters.
Change-Id: Ib698062b272458e847ad5545d7acf33a4dc9eb85
diff --git a/src/compiled_method.h b/src/compiled_method.h
index b98df39..2920256 100644
--- a/src/compiled_method.h
+++ b/src/compiled_method.h
@@ -50,7 +50,9 @@
const uint32_t fp_spill_mask);
// Constructs a CompiledMethod for the LLVM compiler.
- CompiledMethod(InstructionSet instruction_set, size_t elf_idx);
+ CompiledMethod(InstructionSet instruction_set,
+ const uint16_t elf_idx,
+ const uint16_t elf_func_idx);
~CompiledMethod();
@@ -79,12 +81,18 @@
static const void* CodePointer(const void* code_pointer,
InstructionSet instruction_set);
- size_t GetElfIndex() const {
+ uint16_t GetElfIndex() const {
+ DCHECK(IsExecutableInElf());
return elf_idx_;
}
+ uint16_t GetElfFuncIndex() const {
+ DCHECK(IsExecutableInElf());
+ return elf_func_idx_;
+ }
+
bool IsExecutableInElf() const {
- return (elf_idx_ != static_cast<size_t>(-1));
+ return (elf_idx_ != static_cast<uint16_t>(-1u));
}
private:
@@ -98,30 +106,38 @@
std::vector<uint16_t> vmap_table_;
std::vector<uint8_t> gc_map_;
// For LLVM
- size_t elf_idx_;
+ uint16_t elf_idx_;
+ uint16_t elf_func_idx_;
};
class CompiledInvokeStub {
public:
explicit CompiledInvokeStub(std::vector<uint8_t>& code);
#if defined(ART_USE_LLVM_COMPILER)
- explicit CompiledInvokeStub(size_t elf_idx);
+ explicit CompiledInvokeStub(uint16_t elf_idx, uint16_t elf_func_idx);
#endif
~CompiledInvokeStub();
const std::vector<uint8_t>& GetCode() const;
- size_t GetElfIndex() const {
+ uint16_t GetElfIndex() const {
+ DCHECK(IsExecutableInElf());
return elf_idx_;
}
+ uint16_t GetElfFuncIndex() const {
+ DCHECK(IsExecutableInElf());
+ return elf_func_idx_;
+ }
+
bool IsExecutableInElf() const {
- return (elf_idx_ != static_cast<size_t>(-1));
+ return (elf_idx_ != static_cast<uint16_t>(-1u));
}
private:
std::vector<uint8_t> code_;
- size_t elf_idx_;
+ uint16_t elf_idx_;
+ uint16_t elf_func_idx_;
};
} // namespace art