Skip to content
  1. Jul 15, 2015
    • Chaoren Lin's avatar
      Remove shell-specific code from TestLoadUnload Makefile. · 00d4fe43
      Chaoren Lin authored
      Reviewers: clayborg, sivachandra
      
      Subscribers: lldb-commits
      
      Differential Revision: http://reviews.llvm.org/D11202
      
      llvm-svn: 242332
      00d4fe43
    • Hans Wennborg's avatar
      Switch the release script to build with CMake by default (PR21561) · 0caeee07
      Hans Wennborg authored
      It retains the possibility to use the autoconf build with a
      command-line option ('-use-autoconf'), and uses that by default on Darwin since
      compiler-rt requires it on that platform.
      
      This commit also removes the "Release-64" flavour and related logic. The script
      would previously do two builds unless the '-no-64bit' flag was passed, but on
      my machine and from those I asked this always ended up producing two 64-bit builds,
      causing much confusion.
      
      It also removes the -build-triple option, which caused the --build= flag to
      get passed to ./configure. This was presumably intended for cross-compiling,
      but none of the release testers use it. If someone does want to pass it,
      they can use '-configure-flags --build=foo' instead.
      
      Differential Revision: http://reviews.llvm.org/D10715
      
      llvm-svn: 242331
      0caeee07
    • Rafael Espindola's avatar
      Handle the error of trying to convert a regular archive to a thin one. · 449208d9
      Rafael Espindola authored
      While at it, test that we can add to a thin archive.
      
      llvm-svn: 242330
      449208d9
    • Yaron Keren's avatar
      47bfc19f
    • Gabor Horvath's avatar
      [Static Analyzer] Do not fail silently, when the analyzer is invoked from... · a61bb64d
      Gabor Horvath authored
      [Static Analyzer] Do not fail silently, when the analyzer is invoked from tooling lib, an analyzer plugin is loaded, but the runtime linker fails to link.
      
      llvm-svn: 242326
      a61bb64d
    • Yaron Keren's avatar
      b0b4132b
    • Cong Hou's avatar
    • Yaron Keren's avatar
      Erase REQUIRES: shell-preserves-root from more tests, see r242312. · b1db6e88
      Yaron Keren authored
      llvm-svn: 242321
      b1db6e88
    • Tobias Edler von Koch's avatar
      Analyze recursive PHI nodes in BasicAA · d8ce16b1
      Tobias Edler von Koch authored
      Summary:
      This patch allows phi nodes like
        %x = phi [ %incptr, ... ] [ %var, ... ]
        %incptr = getelementptr %x, 1
      to be analyzed by BasicAliasAnalysis.
      
      In aliasPHI, we can detect incoming values that are recursive GEPs with a
      constant offset. Instead of trying to analyze a recursive GEP (and failing), 
      we now ignore it and instead set the size of the memory referenced by
      the PHINode to UnknownSize. This represents all the possible memory
      locations the pointer represented by the PHINode could be advanced to
      by the GEP.
      
      For now, this new behavior is turned off by default to allow debugging of
      performance degradations seen with SPEC/x86 and Hexagon benchmarks.
      The flag -basicaa-recphi turns it on.
      
      
      Reviewers: hfinkel, sanjoy
      
      Subscribers: tobiasvk_caf, sanjoy, llvm-commits
      
      Differential Revision: http://reviews.llvm.org/D10368
      
      llvm-svn: 242320
      d8ce16b1
    • Chaoren Lin's avatar
      Use accept instead of accept4 for Android. · e271658e
      Chaoren Lin authored
      Summary:
      The accept4 syscall is missing on older ARM Android kernels, and the accept()
      call is implemented with the accept4 syscall, so we'll need to call the accept
      syscall directly.
      
      Reviewers: vharron, tberghammer, labath
      
      Subscribers: ovyalov, chaoren, labath, tberghammer, aemerson, lldb-commits
      
      Differential Revision: http://reviews.llvm.org/D10887
      
      llvm-svn: 242319
      e271658e
    • Chaoren Lin's avatar
      Default to linking lldb-server statically for Android. · f7ee0870
      Chaoren Lin authored
      Reviewers: vharron, tberghammer
      
      Subscribers: chaoren, labath, tberghammer, lldb-commits
      
      Differential Revision: http://reviews.llvm.org/D10858
      
      llvm-svn: 242318
      f7ee0870
    • James Dennett's avatar
      Allow any comment to be a trailing comment when -fparse-all-comments is on. · 2def1e8a
      James Dennett authored
      This helps with freeform documentation styles, where otherwise code like
        enum class E {
          E1,  // D1
          E2   // D2
        };
      would result in D1 being associated with E2. To properly associate E1
      with D1 and E2 with D2, this patch allows all raw comments C such that
      C.isParseAllComments() to participate in trailing comment checks inside
      getRawCommentForDeclNoCache. This takes care of linking the intended
      documentation with the intended decls. There remains an issue with code
      like:
        foo();  // DN
        int x;
      To prevent DN from being associated with x, this patch adds a new test
      on preceding-line comments C (where C.isParseAllComments() and also
      C's kind is RCK_OrdinaryBCPL or RCK_OrdinaryC) that checks whether C
      is the first non-whitespace thing on C's starting line.
      
      Patch from Luke Zarko <zarko@google.com>, D11069 reviewed by rsmith.
      
      llvm-svn: 242317
      2def1e8a
    • Birunthan Mohanathas's avatar
      525579d4
    • Evgeniy Stepanov's avatar
      -disable-llvm-optzns in one clang test. · 9d09d8a9
      Evgeniy Stepanov authored
      The intent is to test Clang codegen at -O1, and not the LLVM
      optimization pipeline.
      
      llvm-svn: 242315
      9d09d8a9
    • Yaron Keren's avatar
      Actually requiring shell disables the test on Windows whereas · 6129262d
      Yaron Keren authored
      previously requiring shell-preserves-root did not, so do not 
      require anything.
      
      llvm-svn: 242314
      6129262d
    • Bill Schmidt's avatar
      [PPC64] Update tests for vec_sld · f4aa8fe4
      Bill Schmidt authored
      Revision 224297 modified the behavior of vec_sld for little endian so
      that LLVM will generate the correct corresponding vsldoi instruction.
      I neglected to update the existing tests, which continued to pass
      because they were not specific enough.  This patch adds enough
      specificity to the tests to make them useful for BE and LE testing of
      vec_sld.
      
      llvm-svn: 242313
      f4aa8fe4
    • Yaron Keren's avatar
      Since r179283, internal shell is default on windows and so shell-preserves-root · fc9bc49b
      Yaron Keren authored
      is true on MSYS bash although this requires: used to disable tests on MSYS bash.
      
      Nevertheless, all tests requiring shell-preserves-root do pass except for
      Driver/darwin-sdkroot.c. It will require a patch, either by disabling it on 
      Windows or by fixing shell-preserves-root to really be true only on MSYS
      and making darwin-sdkroot.c its only user.
      
      In any case, all other tests requiring shell-preserves-root do not really require
      it so I'm replacing REQUIRES: shell-preserves-root with REQUIRES: shell in two
      tests first.
      
      llvm-svn: 242312
      fc9bc49b
    • Bruno Cardoso Lopes's avatar
      Revert "Refactor optimizeUncoalescable logic" · 9b39693a
      Bruno Cardoso Lopes authored
      Likely broke compilation on ARM:
      
      http://lab.llvm.org:8011/builders/clang-native-arm-lnt/builds/13054
      
      This reverts commit 0b7824464fbe3d3f386e2d4aef6a431422709e53.
      
      llvm-svn: 242311
      9b39693a
    • Bruno Cardoso Lopes's avatar
      Revert "Look through PHIs to find additional register sources" · ad61f342
      Bruno Cardoso Lopes authored
      Likely broke compilation on ARM:
      
      http://lab.llvm.org:8011/builders/clang-native-arm-lnt/builds/13054
      
      This reverts commit 131ce4a838c081516cbfed039fc986b33e3979d6.
      
      llvm-svn: 242310
      ad61f342
    • Reid Kleckner's avatar
      Run clang-format on Tools.h, the indentation is inconsistent · bac59a18
      Reid Kleckner authored
      llvm-svn: 242309
      bac59a18
    • Cong Hou's avatar
      Test commit. · 0881fc11
      Cong Hou authored
      This is a test commit (one blank line deleted).
      
      llvm-svn: 242308
      0881fc11
    • David Majnemer's avatar
      [Targets] Define __BOOL_DEFINED for Windows targets in C++ mode · c19475a8
      David Majnemer authored
      MSVC 4.2 didn't have bool as a builtin type but MSVC 5.0 does.  When
      they added it, they added a macro (__BOOL_DEFINED) which allows build
      scripts and the like to know if they should provide their own bool.
      
      Clang always supports bool as a builtin type in C++ mode.
      
      llvm-svn: 242307
      c19475a8
    • Dawn Perchik's avatar
      Fix -data-info-line when source includes column number. · a3ff7032
      Dawn Perchik authored
      This fixes an off-by-one bug in CMICmdCmdDataInfoLine::Acknowledge.  Given:
          LineEntry: \[0x0000000100000f37-0x0000000100000f45\): /path/to/file:123:1
      -data-info-line would report the line as 12, omitting the last digit.
      
      Reviewed by: ki.stfu, abidh
      Subscribers: lldb-commits
      Differential Revision: http://reviews.llvm.org/D11209
      
      llvm-svn: 242306
      a3ff7032
    • Pavel Labath's avatar
      [NativeProcessLinux] Integrate MainLoop · 827965c3
      Pavel Labath authored
      Summary:
      This commit integrates MainLoop into NativeProcessLinux. By registering a SIGCHLD handler with
      the llgs main loop, we can get rid of the special monitor thread in NPL, which saves as a lot of
      thread ping-pong when responding to client requests (e.g. qThreadInfo processing time has been
      reduced by about 40%). It also makes the code simpler, IMHO.
      
      Reviewers: ovyalov, clayborg, tberghammer, chaoren
      
      Subscribers: lldb-commits
      
      Differential Revision: http://reviews.llvm.org/D11150
      
      llvm-svn: 242305
      827965c3
    • Rafael Espindola's avatar
      Delete declared but not implemented functions. · 2e668b2d
      Rafael Espindola authored
      llvm-svn: 242304
      2e668b2d
    • Aaron Ballman's avatar
    • Adrian Prantl's avatar
      Debug Info: Add basic support for external types references. · ee5feafc
      Adrian Prantl authored
      This is a necessary prerequisite for bootstrapping the emission
      of debug info inside modules.
      
      - Adds a FlagExternalTypeRef to DICompositeType.
        External types must have a unique identifier.
      - External type references are emitted using a forward declaration
        with a DW_AT_signature([DW_FORM_ref_sig8]) based on the UID.
      
      http://reviews.llvm.org/D9612
      
      llvm-svn: 242302
      ee5feafc
    • Jonathan Peyton's avatar
      Re-indent the CMake refactor to two-space indention · 5b4acbd6
      Jonathan Peyton authored
      I apologize for this nasty commit, but I somehow overlooked Chandler's
      comment to re-indent these files to two space indention.  I know this
      is a horrible commit, but I figured if it was done quickly after the 
      first one, not too many conflicts would arise.
      
      Again, I'm sorry and won't do this again.
      
      llvm-svn: 242301
      5b4acbd6
    • Pete Cooper's avatar
      Add missing load/store flags to thumb2 instructions. · 21ca199c
      Pete Cooper authored
      These were the cause of a verifier error when building 7zip with
      -verify-machineinstrs.  Running 'make check' with the verifier
      triggered the same error on the test here so i've updated the test
      to run the verifier on one of its runs instead of adding a new one.
      
      While looking at this code, there was a stale comment that these
      instructions were only used for disassembly.  This probably used to
      be the case, but they are now used in the 'ARM load / store optimization pass' too.
      
      llvm-svn: 242300
      21ca199c
    • Daniel Jasper's avatar
      clang-format: Fix column layout with a comment in the last line. · 00fb2a11
      Daniel Jasper authored
      Before:
        int aaaaa[] = {
            1, 2,
            3, // comment
            4, 5,
            6  // comment
        };
      
      After:
        int aaaaa[] = {
            1, 2, 3, // comment
            4, 5, 6  // comment
        };
      
      llvm-svn: 242299
      00fb2a11
    • Jonathan Peyton's avatar
      Large Refactor of CMake build system · 2e013352
      Jonathan Peyton authored
      This commit improves numerous functionalities of the OpenMP CMake build 
      system to be more conducive with LLVM's build system and build philosophies.
      The CMake build system, as it was before this commit, was not up to LLVM's 
      standards and did not implement the configuration stage like most CMake based
      build systems offer (check for compiler flags, libraries, etc.) In order to
      improve it dramatically in a short period of time, a large refactoring had 
      to be done.
      The main changes done with this commit are as follows:
      
      * Compiler flag checks - The flags are no longer grabbed from compiler specific
        directories.  They are checked for availability in config-ix.cmake and added
        accordingly inside LibompHandleFlags.cmake.
      * Feature checks were added in config-ix.cmake.  For example, the standard CMake
        module FindThreads is probed for the threading model to use inside the OpenMP
        library.
      * OS detection - There is no longer a LIBOMP_OS variable, OS-specifc build logic
        is wrapped around the WIN32 and APPLE macros with !(WIN32 OR APPLE) meaning 
        a Unix flavor of some sort.
      * Got rid of vestigial functions/macros/variables
      * Added new libomp_append() function which is used everywhere to conditionally
        or undconditionally append to a list
      * All targets have the libomp prefix so as not to interfere with any other
        project
      * LibompCheckLinkerFlag.cmake module was added which checks for linker flags
        specifically for building shared libraries.
      * LibompCheckFortranFlag.cmake module was added which checks for fortran flag
        availability.
      * Removed most of the cruft from the translation between the perl+Makefile based
        build system and this one.  The remaining components that they share are
        perl scripts which I'm in the process of removing.
      
      There is still more left to do.  The perl scripts still need to be removed, and
      a config.h.in file (or similarly named) needs to be added with #cmakedefine lines
      in it.  But this is a much better first step than the previous system.
      
      Differential Revision: http://reviews.llvm.org/D10656
      
      llvm-svn: 242298
      2e013352
    • Bill Schmidt's avatar
      [PPC64LE] Fix vec_sld semantics for little endian · 8da737a1
      Bill Schmidt authored
      The vec_sld interface provides access to the vsldoi instruction.
      Unlike most of the vec_* interfaces, we do not attempt to change the
      generated code for vec_sld based on the endian mode.  It is too
      difficult to correctly infer the desired semantics because of
      different element types, and the corrected instruction sequence is
      expensive, involving loading a permute control vector and performing a
      generalized permute.
      
      For GCC, this was implemented as "Don't touch the vec_sld"
      implementation.  When it came time for the LLVM implementation, I did
      the same thing.  However, this was hasty and incorrect.  In LLVM's
      version of altivec.h, vec_sld was previously defined in terms of the
      vec_perm interface.  Because vec_perm semantics are adjusted for
      little endian, this means that leaving vec_sld untouched causes it to
      generate something different for LE than for BE.  Not good.
      
      This patch adjusts the form of vec_perm that is used for vec_sld and
      vec_vsldoi, effectively undoing the modifications so that the same
      vsldoi instruction will be generated for both BE and LE.
      
      There is an accompanying back-end patch to take care of some small
      ripple effects caused by these changes.
      
      llvm-svn: 242297
      8da737a1
    • Bill Schmidt's avatar
      [PPC64LE] Fix vec_sld semantics for little endian · 1e77bb12
      Bill Schmidt authored
      The vec_sld interface provides access to the vsldoi instruction.
      Unlike most of the vec_* interfaces, we do not attempt to change the
      generated code for vec_sld based on the endian mode.  It is too
      difficult to correctly infer the desired semantics because of
      different element types, and the corrected instruction sequence is
      expensive, involving loading a permute control vector and performing a
      generalized permute.
      
      For GCC, this was implemented as "Don't touch the vec_sld"
      implementation.  When it came time for the LLVM implementation, I did
      the same thing.  However, this was hasty and incorrect.  In LLVM's
      version of altivec.h, vec_sld was previously defined in terms of the
      vec_perm interface.  Because vec_perm semantics are adjusted for
      little endian, this means that leaving vec_sld untouched causes it to
      generate something different for LE than for BE.  Not good.
      
      This back-end patch accompanies the changes to altivec.h that change
      vec_sld's behavior for little endian.  Those changes mean that we see
      slightly different code in the back end when trying to recognize a
      VSLDOI instruction in isVSLDOIShuffleMask.  In particular, a
      ShuffleKind of 1 (where the two inputs are identical) must now be
      treated the same way as a ShuffleKind of 2 (little endian with
      different inputs) when little endian mode is in force.  This is
      because ShuffleKind of 1 is defined using big-endian numbering.
      
      This has a ripple effect on LowerBUILD_VECTOR, where we create our own
      internal VSLDOI instructions.  Because these are a ShuffleKind of 1,
      they will now have their shift amounts subtracted from 16 when
      recognizing the shuffle mask.  To avoid problems we have to subtract
      them from 16 again before creating the VSLDOI instructions.
      
      There are a couple of other uses of BuildVSLDOI, but these do not need
      to be modified because the shift amount is 8, which is unchanged when
      subtracted from 16.
      
      llvm-svn: 242296
      1e77bb12
    • Bruno Cardoso Lopes's avatar
      Look through PHIs to find additional register sources · fadd4fef
      Bruno Cardoso Lopes authored
      - Teaches the ValueTracker in the PeepholeOptimizer to look through PHI
      instructions.
      - Add findNextSourceAndRewritePHI method to lookup into multiple sources
      returnted by the ValueTracker and rewrite PHIs with new sources.
      
      With these changes we can find more register sources and rewrite more
      copies to allow coaslescing of bitcast instructions. Hence, we eliminate
      unnecessary VR64 <-> GR64 copies in x86, but it could be extended to
      other archs by marking "isBitcast" on target specific instructions. The
      x86 example follows:
      
      A:
        psllq %mm1, %mm0
        movd  %mm0, %r9
        jmp C
      
      B:
        por %mm1, %mm0
        movd  %mm0, %r9
        jmp C
      
      C:
        movd  %r9, %mm0
        pshufw  $238, %mm0, %mm0
      
      Becomes:
      
      A:
        psllq %mm1, %mm0
        jmp C
      
      B:
        por %mm1, %mm0
        jmp C
      
      C:
        pshufw  $238, %mm0, %mm0
      
      Differential Revision: http://reviews.llvm.org/D11197
      
      rdar://problem/20404526
      
      llvm-svn: 242295
      fadd4fef
    • Bruno Cardoso Lopes's avatar
      Refactor optimizeUncoalescable logic · bd68a095
      Bruno Cardoso Lopes authored
      - Create a new CopyRewriter for Uncoalescable copy-like instructions
      - Change the ValueTracker to return a ValueTrackerResult
      
      This makes optimizeUncoalescable looks more like optimizeCoalescable and
      use the CopyRewritter infrastructure.
      
      This is also the preparation for looking up into PHI nodes in the
      ValueTracker.
      
      Differential Revision: http://reviews.llvm.org/D11195
      
      llvm-svn: 242294
      bd68a095
    • Rafael Espindola's avatar
      Set comdat when an available_externally thunk is converted to linkonce_odr. · 6bedf4a7
      Rafael Espindola authored
      Fixes pr24130.
      
      llvm-svn: 242293
      6bedf4a7
    • Yaron Keren's avatar
      Add support for armv7-windows-gnu targets to the clang front end. · 321249cb
      Yaron Keren authored
      http://reviews.llvm.org/D11071
      
      Patch by Martell Malone
      Reviewed by Reid Kleckner
      
      llvm-svn: 242292
      321249cb
    • Andrew Wilkins's avatar
      [llgo] update libgo-llgo.so version to match libtool_VERSION · e5a7b93e
      Andrew Wilkins authored
      Summary:
      libtool_VERSION was changed in gofrontend a while ago,
      but CMakeLists.txt in llgo wasn't updated, and so the
      install target fails. Not sure how this went unnoticed
      for so long.
      
      Reviewers: pcc
      
      Subscribers: llvm-commits
      
      Differential Revision: http://reviews.llvm.org/D11118
      
      llvm-svn: 242291
      e5a7b93e
    • Andrew Wilkins's avatar
      [llgo] set function personality with SetPersonality · fec95af7
      Andrew Wilkins authored
      Summary:
      If a function requires a landing pad, set the personality function.
      
      Requires D11116.
      
      Reviewers: pcc
      
      Subscribers: llvm-commits
      
      Differential Revision: http://reviews.llvm.org/D11117
      
      llvm-svn: 242290
      fec95af7
    • Andrew Wilkins's avatar
      Expose setPersonalityFn to Go · 02ee3efb
      Andrew Wilkins authored
      Summary:
      Add Value.SetPersonality to the Go bindings. The Go
      bindings' Builder.CreateLandingPad has been updated,
      removing the obsolete personality argument.
      
      Background
      
      The personality attribute was removed from LandingPadInst
      in r239940, and llvm::Function::setPersonalityFn introduced.
      
      There was no corresponding change to either the C API or
      Go bindings. The Go bindings were broken until r239940, but
      that change was just to ignore the personality argument.
      This broke llgo.
      
      Reviewers: majnemer, pcc
      
      Subscribers: deadalnix, llvm-commits, axw
      
      Differential Revision: http://reviews.llvm.org/D11116
      
      llvm-svn: 242289
      02ee3efb
Loading