Skip to content
  1. Nov 03, 2014
  2. Nov 02, 2014
    • Daniel Sanders's avatar
      Re-commit r221056 and others with fix, "[mips] Move F128 argument handling... · 23e98776
      Daniel Sanders authored
      Re-commit r221056 and others with fix, "[mips] Move F128 argument handling into MipsCCState as we did for returns. NFC."
      
      sret arguments can never originate from an f128 argument so we detect
      sret arguments and push false into OriginalArgWasF128.
      
      llvm-svn: 221102
      23e98776
    • Rafael Espindola's avatar
      Revert r221096 bringing back r221014 with a fix. · 778fcc77
      Rafael Espindola authored
      The issue was that linkAppendingVarProto does the full linking job, including
      deleting the old dst variable. The fix is just to call it and return early
      if we have a GV with appending linkage.
      
      original message:
      
          Refactor duplicated code in liking GlobalValues.
      
          There is quiet a bit of logic that is common to any GlobalValue but was
          duplicated for Functions, GlobalVariables and GlobalAliases.
      
          While at it, merge visibility even when comdats are used, fixing pr21415.
      
      llvm-svn: 221098
      778fcc77
    • Rafael Espindola's avatar
      [cmake] Pass -O3 when linking. · 8cb7876c
      Rafael Espindola authored
      Gold and bfd ld enable misc optimizations. lld ignores the option for now.
      
      llvm-svn: 221097
      8cb7876c
    • Chandler Carruth's avatar
      Revert r221014: "Refactor duplicated code in liking GlobalValues." · fd38af2d
      Chandler Carruth authored
      This commit introduces heap-use-after-free detected by ASan. Here is the output
      for one of several tests that detect it:
      
      ******************** TEST 'LLVM :: Linker/AppendingLinkage.ll' FAILED ********************
      Command Output (stderr):
      --
      =================================================================
      ==2122==ERROR: AddressSanitizer: heap-use-after-free on address 0x60c00000b9c8 at pc 0x0000005d05d1 bp 0x7fff64ed27c0 sp 0x7fff64ed27b8
      READ of size 4 at 0x60c00000b9c8 thread T0
          #0 0x5d05d0 in llvm::GlobalValue::setUnnamedAddr(bool) /usr/local/google/home/chandlerc/src/llvm/build/../include/llvm/IR/GlobalValue.h:115:35
          #1 0x69fff1 in (anonymous namespace)::ModuleLinker::linkGlobalValueProto(llvm::GlobalValue*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1041:5
          #2 0x697229 in (anonymous namespace)::ModuleLinker::run() /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1485:9
          #3 0x696542 in llvm::Linker::linkInModule(llvm::Module*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1621:10
          #4 0x4a2db7 in main /usr/local/google/home/chandlerc/src/llvm/build/../tools/llvm-link/llvm-link.cpp:116:9
          #5 0x7f4ae61e5ec4 in __libc_start_main /build/buildd/eglibc-2.19/csu/libc-start.c:287
          #6 0x41eb71 in _start (/usr/local/google/home/chandlerc/src/llvm/build/bin/llvm-link+0x41eb71)
      
      0x60c00000b9c8 is located 72 bytes inside of 128-byte region [0x60c00000b980,0x60c00000ba00)
      freed by thread T0 here:
          #0 0x4a1e6b in operator delete(void*) /usr/local/google/home/chandlerc/src/llvm/opt-build/../projects/compiler-rt/lib/asan/asan_new_delete.cc:94:3
          #1 0x5d1a7a in llvm::iplist<llvm::GlobalVariable, llvm::ilist_traits<llvm::GlobalVariable> >::erase(llvm::ilist_iterator<llvm::GlobalVariable>) /usr/local/google/home/chandlerc/src/llvm/build/../inclu
      de/llvm/ADT/ilist.h:466:5
          #2 0x5d1980 in llvm::GlobalVariable::eraseFromParent() /usr/local/google/home/chandlerc/src/llvm/build/../lib/IR/Globals.cpp:204:3
          #3 0x6a8a4d in (anonymous namespace)::ModuleLinker::linkAppendingVarProto(llvm::GlobalVariable*, llvm::GlobalVariable const*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.
      cpp:980:3
          #4 0x6a7403 in (anonymous namespace)::ModuleLinker::linkGlobalVariableProto(llvm::GlobalVariable const*, llvm::GlobalValue*, bool) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkMod
      ules.cpp:1074:11
          #5 0x69ff4e in (anonymous namespace)::ModuleLinker::linkGlobalValueProto(llvm::GlobalValue*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1028:13
          #6 0x697229 in (anonymous namespace)::ModuleLinker::run() /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1485:9
          #7 0x696542 in llvm::Linker::linkInModule(llvm::Module*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1621:10
          #8 0x4a2db7 in main /usr/local/google/home/chandlerc/src/llvm/build/../tools/llvm-link/llvm-link.cpp:116:9
          #9 0x7f4ae61e5ec4 in __libc_start_main /build/buildd/eglibc-2.19/csu/libc-start.c:287
      
      previously allocated by thread T0 here:
          #0 0x4a192b in operator new(unsigned long) /usr/local/google/home/chandlerc/src/llvm/opt-build/../projects/compiler-rt/lib/asan/asan_new_delete.cc:62:35
          #1 0x61d85c in llvm::User::operator new(unsigned long, unsigned int) /usr/local/google/home/chandlerc/src/llvm/build/../lib/IR/User.cpp:57:19
          #2 0x6a7525 in (anonymous namespace)::ModuleLinker::linkGlobalVariableProto(llvm::GlobalVariable const*, llvm::GlobalValue*, bool) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkMod
      ules.cpp:1100:3
          #3 0x69ff4e in (anonymous namespace)::ModuleLinker::linkGlobalValueProto(llvm::GlobalValue*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1028:13
          #4 0x697229 in (anonymous namespace)::ModuleLinker::run() /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1485:9
          #5 0x696542 in llvm::Linker::linkInModule(llvm::Module*) /usr/local/google/home/chandlerc/src/llvm/build/../lib/Linker/LinkModules.cpp:1621:10
          #6 0x4a2db7 in main /usr/local/google/home/chandlerc/src/llvm/build/../tools/llvm-link/llvm-link.cpp:116:9
          #7 0x7f4ae61e5ec4 in __libc_start_main /build/buildd/eglibc-2.19/csu/libc-start.c:287
      
      SUMMARY: AddressSanitizer: heap-use-after-free /usr/local/google/home/chandlerc/src/llvm/build/../include/llvm/IR/GlobalValue.h:115 llvm::GlobalValue::setUnnamedAddr(bool)
      Shadow bytes around the buggy address:
        0x0c187fff96e0: fa fa fa fa fa fa fa fa 00 00 00 00 00 00 00 00
        0x0c187fff96f0: 00 00 00 00 00 00 00 fa fa fa fa fa fa fa fa fa
        0x0c187fff9700: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fa
        0x0c187fff9710: fa fa fa fa fa fa fa fa 00 00 00 00 00 00 00 00
        0x0c187fff9720: 00 00 00 00 00 00 00 00 fa fa fa fa fa fa fa fa
      =>0x0c187fff9730: fd fd fd fd fd fd fd fd fd[fd]fd fd fd fd fd fd
        0x0c187fff9740: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
        0x0c187fff9750: fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa fa
        0x0c187fff9760: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
        0x0c187fff9770: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
        0x0c187fff9780: fd fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa
      Shadow byte legend (one shadow byte represents 8 application bytes):
        Addressable:           00
        Partially addressable: 01 02 03 04 05 06 07
        Heap left redzone:       fa
        Heap right redzone:      fb
        Freed heap region:       fd
        Stack left redzone:      f1
        Stack mid redzone:       f2
        Stack right redzone:     f3
        Stack partial redzone:   f4
        Stack after return:      f5
        Stack use after scope:   f8
        Global redzone:          f9
        Global init order:       f6
        Poisoned by user:        f7
        Container overflow:      fc
        Array cookie:            ac
        ASan internal:           fe
      ==2122==ABORTING
      
      llvm-svn: 221096
      fd38af2d
    • David Blaikie's avatar
      Formatting · 4aa49b20
      David Blaikie authored
      llvm-svn: 221095
      4aa49b20
    • David Blaikie's avatar
      Add DwarfUnit::isDwoUnit and use it to generalize string creation · cafd962d
      David Blaikie authored
      Currently we only need to emit skeleton strings into the CU header and
      we do this by explicitly calling "addLocalString". With gmlt-in-fission,
      we'll be emitting a bunch of other strings from other codepaths where
      it's not statically known that these strings will be local or not.
      
      Introduce a virtual function to indicate whether this unit is a DWO unit
      or not (I'm not sure if we have a good term for this, the
      opposite/alternative to 'skeleton' unit) and use that to generalize the
      string emission logic so that strings can be correctly emitted in both
      the skeleton and dwo unit when in split dwarf mode.
      
      And to demonstrate that this works, switch the existing special callers
      of addLocalString in the skeleton builder to addString - and they still
      work. Yay.
      
      llvm-svn: 221094
      cafd962d
    • David Blaikie's avatar
      Remove the last mention of LineTablesOnly from DwarfUnit, sinking it into DwarfCompileUnit · 279c451c
      David Blaikie authored
      This is a useful distinction/invariant/delination to make because
      LineTablesOnly mode is never relevant to type units, so it's clear that
      we're not doing weird line-tables-only-with-types by making this API
      choice.
      
      It also lays the foundations nicely for adding gmlt-like data to fission
      skeleton CUs while limiting the effects to CUs and not TUs.
      
      llvm-svn: 221093
      279c451c
    • David Blaikie's avatar
      3363a57c
    • Elena Demikhovsky's avatar
      Use Alias Analysis to hoist 2 loads from diamond to the common predecessor basic block. · 27152aea
      Elena Demikhovsky authored
      Alias Analysis allows to detect real barriers for load hoisting.
      
      Review in http://reviews.llvm.org/D5991
      
      llvm-svn: 221091
      27152aea
    • David Blaikie's avatar
      Sink DwarfUnit::addExpr into DwarfCompileUnit · 97802080
      David Blaikie authored
      llvm-svn: 221090
      97802080
    • David Blaikie's avatar
      Fix the build from the last commit · 8c485b5d
      David Blaikie authored
      llvm-svn: 221089
      8c485b5d
    • David Blaikie's avatar
      Sink DwarfUnit::applyVariableAttributes into DwarfCompileUnit · 02a6333b
      David Blaikie authored
      llvm-svn: 221088
      02a6333b
    • David Blaikie's avatar
      Sink DwarfUnit::addLocationList down into DwarfCompileUnit · 4bc0881a
      David Blaikie authored
      llvm-svn: 221087
      4bc0881a
    • David Blaikie's avatar
      Sink DwarfUnit::addComplexAddress down into DwarfCompileUnit · 77895fb2
      David Blaikie authored
      llvm-svn: 221086
      77895fb2
    • David Blaikie's avatar
      Push DwarfUnit::addAddress down into DwarfCompileUnit · f7435ee6
      David Blaikie authored
      llvm-svn: 221085
      f7435ee6
    • David Blaikie's avatar
    • David Blaikie's avatar
    • David Blaikie's avatar
      Add DwarfUnit::addGlobalType to match DwarfUnit::addGlobalName · 98cf1721
      David Blaikie authored
      (these will shortly become virtual, with a null implementation in
      DwarfUnit (since type units don't have accelerator tables in the current
      schema) and the current implementation down in DwarfCompileUnit, moving
      the actual maps there too)
      
      llvm-svn: 221082
      98cf1721
    • NAKAMURA Takumi's avatar
      Revert r221056 and others, "[mips] Move F128 argument handling into... · cd2996c3
      NAKAMURA Takumi authored
      Revert r221056 and others, "[mips] Move F128 argument handling into MipsCCState as we did for returns. NFC."
      
        r221056 "[mips] Move F128 argument handling into MipsCCState as we did for returns. NFC."
        r221058 "[mips] Fix unused variable warning introduced in r221056"
        r221059 "[mips] Move all ByVal handling into CCState and tablegen-erated code. NFC."
        r221061 "Renamed CCState members that appear to misspell 'Processed' as 'Proceed'. NFC."
      
      It cuased an undefined behavior in LLVM :: CodeGen/Mips/return-vector.ll.
      
      llvm-svn: 221081
      cd2996c3
    • David Blaikie's avatar
    • David Blaikie's avatar
    • David Blaikie's avatar
      Don't bother creating LabelBegin for .dwo units · b6726a9e
      David Blaikie authored
      This would help catch cases where we might otherwise try to reference a
      dwo CU label, which would be weird - because without relocations in the
      dwo file it's not generally meaningful to talk about the CU offsets
      there (or, if it is, we can do so in absolute terms without using a
      relocation to compute it).
      
      llvm-svn: 221078
      b6726a9e
    • Tim Northover's avatar
      Docs: update va_arg example with valid x86_64 va_list type. · ab60bb9b
      Tim Northover authored
      The given example was overflowing its alloca and segfaulting if actually run on
      x86, so it's a good idea to provide something that works there too.
      
      Patch by Ramkumar Ramachandra.
      
      llvm-svn: 221077
      ab60bb9b
    • David Blaikie's avatar
      Drop DwarfCompileUnit::getLocalLabel* in favor of just mapping through the skeleton explicitly. · 27e35f23
      David Blaikie authored
      Confusing to do this two different ways - I'm not too wedded to either
      one, but here goes.
      
      llvm-svn: 221076
      27e35f23
    • David Blaikie's avatar
    • Rafael Espindola's avatar
      Update test to use llvm-readobj. NFC. · e3cfb6c7
      Rafael Espindola authored
      llvm-svn: 221074
      e3cfb6c7
    • David Blaikie's avatar
      Sink dwarf unit length emission down into DwarfUnit::emitHeader · ae57e66e
      David Blaikie authored
      This allows the CU label to be emitted only for compile units, as
      they're the only ones that need it (so they can be referenced from
      pubnames)
      
      llvm-svn: 221072
      ae57e66e
Loading