[llvm] r260285 - Revert "Correct size calculations for ELF files"

Rafael Espindola via llvm-commits llvm-commits at lists.llvm.org
Tue Feb 9 13:30:10 PST 2016


Author: rafael
Date: Tue Feb  9 15:30:10 2016
New Revision: 260285

URL: http://llvm.org/viewvc/llvm-project?rev=260285&view=rev
Log:
Revert "Correct size calculations for ELF files"

This reverts commit r259578.

There are enough issues with this small patch that it is better to
revert and then commit a fixed version (will be committed shortly).

Removed:
    llvm/trunk/test/tools/llvm-size/Inputs/1.o
Modified:
    llvm/trunk/test/tools/llvm-size/basic.test
    llvm/trunk/tools/llvm-size/llvm-size.cpp

Removed: llvm/trunk/test/tools/llvm-size/Inputs/1.o
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/llvm-size/Inputs/1.o?rev=260284&view=auto
==============================================================================
Binary files llvm/trunk/test/tools/llvm-size/Inputs/1.o (original) and llvm/trunk/test/tools/llvm-size/Inputs/1.o (removed) differ

Modified: llvm/trunk/test/tools/llvm-size/basic.test
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/llvm-size/basic.test?rev=260285&r1=260284&r2=260285&view=diff
==============================================================================
--- llvm/trunk/test/tools/llvm-size/basic.test (original)
+++ llvm/trunk/test/tools/llvm-size/basic.test Tue Feb  9 15:30:10 2016
@@ -1,28 +1,2 @@
 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.\\/:]+}}
-

Modified: llvm/trunk/tools/llvm-size/llvm-size.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-size/llvm-size.cpp?rev=260285&r1=260284&r2=260285&view=diff
==============================================================================
--- llvm/trunk/tools/llvm-size/llvm-size.cpp (original)
+++ llvm/trunk/tools/llvm-size/llvm-size.cpp Tue Feb  9 15:30:10 2016
@@ -15,13 +15,11 @@
 
 #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"
@@ -113,20 +111,6 @@ 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
@@ -303,8 +287,6 @@ static void PrintObjectSectionSizes(Obje
     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;
 
@@ -340,8 +322,6 @@ static void PrintObjectSectionSizes(Obje
 
     // Print each section.
     for (const SectionRef &Section : Obj->sections()) {
-      if (!ConsiderForSize(Obj, Section))
-        continue;
       StringRef name;
       if (error(Section.getName(name)))
         return;




More information about the llvm-commits mailing list