diff options
author | Sean Silva <silvas@purdue.edu> | 2013-06-19 00:11:59 +0000 |
---|---|---|
committer | Sean Silva <silvas@purdue.edu> | 2013-06-19 00:11:59 +0000 |
commit | 5ba1225fb074f8035668637292d994d4c39757d1 (patch) | |
tree | 6e80c771ce271284279776d09b8a5ec22a119dce | |
parent | 70a3dc1bc2b16748a8a79d1d11d2b1603c38c032 (diff) | |
download | external_llvm-5ba1225fb074f8035668637292d994d4c39757d1.zip external_llvm-5ba1225fb074f8035668637292d994d4c39757d1.tar.gz external_llvm-5ba1225fb074f8035668637292d994d4c39757d1.tar.bz2 |
[yaml2obj][ELF] Support st_info through `Binding` and `Type` YAML keys.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184263 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Object/ELFYAML.h | 14 | ||||
-rw-r--r-- | lib/Object/ELFYAML.cpp | 25 | ||||
-rw-r--r-- | test/Object/yaml2obj-elf-symbol-basic.yaml | 4 | ||||
-rw-r--r-- | tools/yaml2obj/yaml2elf.cpp | 1 |
4 files changed, 44 insertions, 0 deletions
diff --git a/include/llvm/Object/ELFYAML.h b/include/llvm/Object/ELFYAML.h index d6ce525..317848b 100644 --- a/include/llvm/Object/ELFYAML.h +++ b/include/llvm/Object/ELFYAML.h @@ -39,6 +39,8 @@ LLVM_YAML_STRONG_TYPEDEF(uint8_t, ELF_ELFDATA) LLVM_YAML_STRONG_TYPEDEF(uint32_t, ELF_SHT) // Just use 64, since it can hold 32-bit values too. LLVM_YAML_STRONG_TYPEDEF(uint64_t, ELF_SHF) +LLVM_YAML_STRONG_TYPEDEF(uint8_t, ELF_STB) +LLVM_YAML_STRONG_TYPEDEF(uint8_t, ELF_STT) // For now, hardcode 64 bits everywhere that 32 or 64 would be needed // since 64-bit can hold 32-bit values too. @@ -51,6 +53,8 @@ struct FileHeader { }; struct Symbol { StringRef Name; + ELF_STB Binding; + ELF_STT Type; }; struct Section { StringRef Name; @@ -108,6 +112,16 @@ struct ScalarBitSetTraits<ELFYAML::ELF_SHF> { }; template <> +struct ScalarEnumerationTraits<ELFYAML::ELF_STB> { + static void enumeration(IO &IO, ELFYAML::ELF_STB &Value); +}; + +template <> +struct ScalarEnumerationTraits<ELFYAML::ELF_STT> { + static void enumeration(IO &IO, ELFYAML::ELF_STT &Value); +}; + +template <> struct MappingTraits<ELFYAML::FileHeader> { static void mapping(IO &IO, ELFYAML::FileHeader &FileHdr); }; diff --git a/lib/Object/ELFYAML.cpp b/lib/Object/ELFYAML.cpp index 32a759d..9c7bf2a 100644 --- a/lib/Object/ELFYAML.cpp +++ b/lib/Object/ELFYAML.cpp @@ -251,6 +251,29 @@ void ScalarBitSetTraits<ELFYAML::ELF_SHF>::bitset(IO &IO, #undef BCase } +void ScalarEnumerationTraits<ELFYAML::ELF_STB>::enumeration( + IO &IO, ELFYAML::ELF_STB &Value) { +#define ECase(X) IO.enumCase(Value, #X, ELF::X); + ECase(STB_LOCAL) + ECase(STB_GLOBAL) + ECase(STB_WEAK) +#undef ECase +} + +void ScalarEnumerationTraits<ELFYAML::ELF_STT>::enumeration( + IO &IO, ELFYAML::ELF_STT &Value) { +#define ECase(X) IO.enumCase(Value, #X, ELF::X); + ECase(STT_NOTYPE) + ECase(STT_OBJECT) + ECase(STT_FUNC) + ECase(STT_SECTION) + ECase(STT_FILE) + ECase(STT_COMMON) + ECase(STT_TLS) + ECase(STT_GNU_IFUNC) +#undef ECase +} + void MappingTraits<ELFYAML::FileHeader>::mapping(IO &IO, ELFYAML::FileHeader &FileHdr) { IO.mapRequired("Class", FileHdr.Class); @@ -262,6 +285,8 @@ void MappingTraits<ELFYAML::FileHeader>::mapping(IO &IO, void MappingTraits<ELFYAML::Symbol>::mapping(IO &IO, ELFYAML::Symbol &Symbol) { IO.mapOptional("Name", Symbol.Name, StringRef()); + IO.mapOptional("Binding", Symbol.Binding, ELFYAML::ELF_STB(0)); + IO.mapOptional("Type", Symbol.Type, ELFYAML::ELF_STT(0)); } void MappingTraits<ELFYAML::Section>::mapping(IO &IO, diff --git a/test/Object/yaml2obj-elf-symbol-basic.yaml b/test/Object/yaml2obj-elf-symbol-basic.yaml index e6a6cbc..c7593b3 100644 --- a/test/Object/yaml2obj-elf-symbol-basic.yaml +++ b/test/Object/yaml2obj-elf-symbol-basic.yaml @@ -13,9 +13,13 @@ Sections: Type: SHT_SYMTAB Symbols: - Name: main + Binding: STB_GLOBAL + Type: STT_FUNC # CHECK: Symbols [ # CHECK-NEXT: Symbol { # CHECK-NEXT: Name: (0) # CHECK: Symbol { # CHECK-NEXT: Name: main +# CHECK: Binding: Global +# CHECK-NEXT: Type: Function diff --git a/tools/yaml2obj/yaml2elf.cpp b/tools/yaml2obj/yaml2elf.cpp index 3ddbe0a..80d21e7 100644 --- a/tools/yaml2obj/yaml2elf.cpp +++ b/tools/yaml2obj/yaml2elf.cpp @@ -166,6 +166,7 @@ static void handleSymtabSectionHeader( zero(Symbol); if (!Sym.Name.empty()) Symbol.st_name = StrTab.addString(Sym.Name); + Symbol.setBindingAndType(Sym.Binding, Sym.Type); Syms.push_back(Symbol); } |