diff options
author | Hemant Kulkarni <khemant@codeaurora.org> | 2016-02-02 21:41:49 +0000 |
---|---|---|
committer | Hemant Kulkarni <khemant@codeaurora.org> | 2016-02-02 21:41:49 +0000 |
commit | 782edae7d66601cf75d69ff971390cf09af627b4 (patch) | |
tree | 9cb9dbb4bf50d8119d30bcd64262f68013bc0ff4 /llvm | |
parent | f3eb90743ccb74d23ee2066109beb067c970eb45 (diff) | |
download | bcm5719-llvm-782edae7d66601cf75d69ff971390cf09af627b4.tar.gz bcm5719-llvm-782edae7d66601cf75d69ff971390cf09af627b4.zip |
Correct size calculations for ELF files
llvm-svn: 259578
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/test/tools/llvm-size/Inputs/1.o | bin | 0 -> 1576 bytes | |||
-rw-r--r-- | llvm/test/tools/llvm-size/basic.test | 26 | ||||
-rw-r--r-- | llvm/tools/llvm-size/llvm-size.cpp | 20 |
3 files changed, 46 insertions, 0 deletions
diff --git a/llvm/test/tools/llvm-size/Inputs/1.o b/llvm/test/tools/llvm-size/Inputs/1.o Binary files differnew file mode 100644 index 00000000000..ebcb20701b8 --- /dev/null +++ b/llvm/test/tools/llvm-size/Inputs/1.o diff --git a/llvm/test/tools/llvm-size/basic.test b/llvm/test/tools/llvm-size/basic.test index 8b2d66eef3c..09827af9c90 100644 --- a/llvm/test/tools/llvm-size/basic.test +++ b/llvm/test/tools/llvm-size/basic.test @@ -1,2 +1,28 @@ RUN: llvm-size %t.blah 2>&1 | FileCheck --check-prefix=ENOENT %s +#1.o source +#int x ; int y ; int z; +# +#int main () { +# x = 1; +# y = 1; +# z = 1; +# return x + y + z; +#} +#Compilation: clang -c -O0 +RUN: llvm-size -A %p/Inputs/1.o | FileCheck --check-prefix="SYSV" %s +RUN: llvm-size -B %p/Inputs/1.o | FileCheck --check-prefix="BSD" %s + ENOENT: {{.*}}llvm-size{{(\.EXE|\.exe)?}}: {{.*}}.blah: {{[Nn]}}o such file or directory +SYSV: {{[ -\(\)_A-Za-z0-9.\\/:]+}} : +SYSV-NEXT: section size addr +SYSV-NEXT: .text 67 0 +SYSV-NEXT: .data 0 0 +SYSV-NEXT: .bss 0 0 +SYSV-NEXT: .comment 46 0 +SYSV-NEXT: .note.GNU-stack 0 0 +SYSV-NEXT: .eh_frame 56 0 +SYSV-NEXT: Total 169 + +BSD: text data bss dec hex filename +BSD-NEXT: 67 56 0 123 7b {{[ -\(\)_A-Za-z0-9.\\/:]+}} + diff --git a/llvm/tools/llvm-size/llvm-size.cpp b/llvm/tools/llvm-size/llvm-size.cpp index e8f95573051..159afcf6c86 100644 --- a/llvm/tools/llvm-size/llvm-size.cpp +++ b/llvm/tools/llvm-size/llvm-size.cpp @@ -15,11 +15,13 @@ #include "llvm/ADT/APInt.h" #include "llvm/Object/Archive.h" +#include "llvm/Object/ELFObjectFile.h" #include "llvm/Object/MachO.h" #include "llvm/Object/MachOUniversal.h" #include "llvm/Object/ObjectFile.h" #include "llvm/Support/Casting.h" #include "llvm/Support/CommandLine.h" +#include "llvm/Support/ELF.h" #include "llvm/Support/FileSystem.h" #include "llvm/Support/Format.h" #include "llvm/Support/ManagedStatic.h" @@ -111,6 +113,20 @@ static const char *getRadixFmt() { return nullptr; } +/// @brief Remove unneeded ELF sections from calculation +static bool ConsiderForSize(ObjectFile *Obj, SectionRef Section) { + if (Obj->isELF()) { + switch (static_cast<ELFSectionRef>(Section).getType()) { + case ELF::SHT_NULL: + case ELF::SHT_SYMTAB: + case ELF::SHT_STRTAB: + case ELF::SHT_REL: + case ELF::SHT_RELA: + return false; + } + } + return true; +} /// @brief Print the size of each Mach-O segment and section in @p MachO. /// /// This is when used when @c OutputFormat is darwin and produces the same @@ -285,6 +301,8 @@ static void PrintObjectSectionSizes(ObjectFile *Obj) { std::size_t max_size_len = strlen("size"); std::size_t max_addr_len = strlen("addr"); for (const SectionRef &Section : Obj->sections()) { + if (!ConsiderForSize(Obj, Section)) + continue; uint64_t size = Section.getSize(); total += size; @@ -320,6 +338,8 @@ static void PrintObjectSectionSizes(ObjectFile *Obj) { // Print each section. for (const SectionRef &Section : Obj->sections()) { + if (!ConsiderForSize(Obj, Section)) + continue; StringRef name; if (error(Section.getName(name))) return; |