summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorHemant Kulkarni <khemant@codeaurora.org>2016-02-02 21:41:49 +0000
committerHemant Kulkarni <khemant@codeaurora.org>2016-02-02 21:41:49 +0000
commit782edae7d66601cf75d69ff971390cf09af627b4 (patch)
tree9cb9dbb4bf50d8119d30bcd64262f68013bc0ff4 /llvm
parentf3eb90743ccb74d23ee2066109beb067c970eb45 (diff)
downloadbcm5719-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.obin0 -> 1576 bytes
-rw-r--r--llvm/test/tools/llvm-size/basic.test26
-rw-r--r--llvm/tools/llvm-size/llvm-size.cpp20
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
new file mode 100644
index 00000000000..ebcb20701b8
--- /dev/null
+++ b/llvm/test/tools/llvm-size/Inputs/1.o
Binary files differ
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;
OpenPOWER on IntegriCloud