summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSean Silva <silvas@purdue.edu>2013-06-19 00:11:59 +0000
committerSean Silva <silvas@purdue.edu>2013-06-19 00:11:59 +0000
commit5ba1225fb074f8035668637292d994d4c39757d1 (patch)
tree6e80c771ce271284279776d09b8a5ec22a119dce
parent70a3dc1bc2b16748a8a79d1d11d2b1603c38c032 (diff)
downloadllvm-5ba1225fb074f8035668637292d994d4c39757d1.tar.gz
llvm-5ba1225fb074f8035668637292d994d4c39757d1.tar.bz2
llvm-5ba1225fb074f8035668637292d994d4c39757d1.tar.xz
[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.h14
-rw-r--r--lib/Object/ELFYAML.cpp25
-rw-r--r--test/Object/yaml2obj-elf-symbol-basic.yaml4
-rw-r--r--tools/yaml2obj/yaml2elf.cpp1
4 files changed, 44 insertions, 0 deletions
diff --git a/include/llvm/Object/ELFYAML.h b/include/llvm/Object/ELFYAML.h
index d6ce525248..317848b1e9 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 32a759dc0b..9c7bf2ae04 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 e6a6cbc6d5..c7593b3159 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 3ddbe0afee..80d21e795d 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);
}