Skip to content
  1. Jul 09, 2013
  2. Jul 08, 2013
    • Manman Ren's avatar
      DebugInfo: remove unused helper function getDICompositeType. · 8bad86c8
      Manman Ren authored
      llvm-svn: 185876
      8bad86c8
    • Eric Christopher's avatar
      CEHCK->CHECK typo fix. · a95d3925
      Eric Christopher authored
      llvm-svn: 185875
      a95d3925
    • Eric Christopher's avatar
      Fix up whitespace. · 7ca38c6e
      Eric Christopher authored
      llvm-svn: 185874
      7ca38c6e
    • Fariborz Jahanian's avatar
      [Objective-C migrator] replace candidate user setter/getter with · bfaabe40
      Fariborz Jahanian authored
      their equivalent property declaration. wip.
      
      llvm-svn: 185873
      bfaabe40
    • Bill Wendling's avatar
      Stop emitting weak symbols into the "coal" sections. · 0176708e
      Bill Wendling authored
      The Mach-O linker has been able to support the weak-def bit on any symbol for
      quite a while now. The compiler however continued to place these symbols into a
      "coal" section, which required the linker to map them back to the base section
      name.
      
      Replace the sections like this:
      
        __TEXT/__textcoal_nt   instead use  __TEXT/__text
        __TEXT/__const_coal    instead use  __TEXT/__const
        __DATA/__datacoal_nt   instead use  __DATA/__data
      
      <rdar://problem/14265330>
      
      llvm-svn: 185872
      0176708e
    • Eric Christopher's avatar
      No ',' between programs. · 72ebead4
      Eric Christopher authored
      llvm-svn: 185867
      72ebead4
    • Eric Christopher's avatar
      Update comment to avoid mentioning DbgValues which is an instance · aba20dd6
      Eric Christopher authored
      variable later in the class.
      
      llvm-svn: 185866
      aba20dd6
    • Howard Hinnant's avatar
      War on tabs. · e0fe3d2e
      Howard Hinnant authored
      llvm-svn: 185865
      e0fe3d2e
    • Marshall Clow's avatar
      Implement n3668 - std::exchange · a7b0e5dd
      Marshall Clow authored
      llvm-svn: 185863
      a7b0e5dd
    • Manman Ren's avatar
      Revert r185852. · 9c5e9980
      Manman Ren authored
      llvm-svn: 185861
      9c5e9980
    • Matt Arsenault's avatar
      Find xdot or xdot.py. · fe56cc67
      Matt Arsenault authored
      Ubuntu installs this as xdot, so finding xdot.py would fail.
      
      llvm-svn: 185860
      fe56cc67
    • Matt Arsenault's avatar
      Allow llvm_find_program to find alternate names · 90962172
      Matt Arsenault authored
      llvm-svn: 185859
      90962172
    • Ulrich Weigand's avatar
      · 266db7fe
      Ulrich Weigand authored
      [PowerPC] Always use "assembler dialect" 1
      
      A setting in MCAsmInfo defines the "assembler dialect" to use.  This is used
      by common code to choose between alternatives in a multi-alternative GNU
      inline asm statement like the following:
      
        __asm__ ("{sfe|subfe} %0,%1,%2" : "=r" (out) : "r" (in1), "r" (in2));
      
      The meaning of these dialects is platform specific, and GCC defines those
      for PowerPC to use dialect 0 for old-style (POWER) mnemonics and 1 for
      new-style (PowerPC) mnemonics, like in the example above.
      
      To be compatible with inline asm used with GCC, LLVM ought to do the same.
      Specifically, this means we should always use assembler dialect 1 since
      old-style mnemonics really aren't supported on any current platform.
      
      However, the current LLVM back-end uses:
        AssemblerDialect = 1;           // New-Style mnemonics.
      in PPCMCAsmInfoDarwin, and
        AssemblerDialect = 0;           // Old-Style mnemonics.
      in PPCLinuxMCAsmInfo.
      
      The Linux setting really isn't correct, we should be using new-style
      mnemonics everywhere.  This is changed by this commit.
      
      Unfortunately, the setting of this variable is overloaded in the back-end
      to decide whether or not we are on a Darwin target.  This is done in
      PPCInstPrinter (the "SyntaxVariant" is initialized from the MCAsmInfo
      AssemblerDialect setting), and also in PPCMCExpr.  Setting AssemblerDialect
      to 1 for both Darwin and Linux no longer allows us to make this distinction.
      
      Instead, this patch uses the MCSubtargetInfo passed to createPPCMCInstPrinter
      to distinguish Darwin targets, and ignores the SyntaxVariant parameter.
      As to PPCMCExpr, this patch adds an explicit isDarwin argument that needs
      to be passed in by the caller when creating a target MCExpr.  (To do so
      this patch implicitly also reverts commit 184441.)
      
      llvm-svn: 185858
      266db7fe
    • Eli Friedman's avatar
      Fix Sema for compares with _Atomic vars. · e6d3395d
      Eli Friedman authored
      Use UsualArithmeticConversions unconditionally in analysis of
      comparisons and conditional operators: the method performs
      the usual arithmetic conversions if both sides are arithmetic, and
      usual unary conversions if they are not.  This is just a cleanup
      for conditional operators; for comparisons, it fixes the issue that
      we would try to check isArithmetic() on an atomic type.
      
      Also, fix GetExprRange() in SemaChecking.cpp so it deals with variables
      of atomic type correctly.
      
      Fixes PR15537.
      
      llvm-svn: 185857
      e6d3395d
    • Marshall Clow's avatar
      Implement n3545 for c++14 · f331327c
      Marshall Clow authored
      llvm-svn: 185856
      f331327c
    • Hal Finkel's avatar
      PPC: Mark vector CC action for SETO and SETONE as Expand · 21ada797
      Hal Finkel authored
      Another bug found by llvm-stress! This fixes hitting
        llvm_unreachable("Invalid integer vector compare condition");
      at the end of getVCmpInst in PPCISelDAGToDAG.
      
      llvm-svn: 185855
      21ada797
    • Benjamin Kramer's avatar
      IR headers moved to llvm/IR some aeons ago, update documentation. · 9f566a5a
      Benjamin Kramer authored
      llvm-svn: 185854
      9f566a5a
    • Joey Gouly's avatar
      Add a comment to this change, requested by Eric Christopher. · 392cdad2
      Joey Gouly authored
      llvm-svn: 185853
      392cdad2
    • Manman Ren's avatar
      StringRef: add DenseMapInfo for StringRef. · c6fe5bc7
      Manman Ren authored
      Remove the implementation in include/llvm/Support/YAMLTraits.h.
      Added a DenseMap type DITypeHashMap in DebugInfo.h:
        DenseMap<std::pair<StringRef, unsigned>, MDNode*>
      
      llvm-svn: 185852
      c6fe5bc7
    • Argyrios Kyrtzidis's avatar
      [ADT/NullablePtr] Allow implicit conversion of NullablePtr<OtherT> ->... · a70ad5fb
      Argyrios Kyrtzidis authored
      [ADT/NullablePtr] Allow implicit conversion of NullablePtr<OtherT> -> NullablePtr<T> if OtherT is derived from T.
      
      llvm-svn: 185851
      a70ad5fb
    • Reid Kleckner's avatar
      Reland "Use Clang's __has_* macros in Compiler.h ..." with fixes · 3f6688eb
      Reid Kleckner authored
      This reverts r185841 and relands r185831 without using
      __has_attribute(const).
      
      Clang prior to r161767 (between 3.1 and 3.2) does not accept
      __has_attribute(const) due to rdar://10253857.  __const and __const__
      are both keyword aliases of const, so they don't work either.
      
      I was able to repro the buildbot failure using clang 3.1 and this patch
      fixes it.  Various important versions of XCode use clang 2.9-ish, so
      this workaround is necessary.
      
      llvm-svn: 185850
      3f6688eb
    • Howard Hinnant's avatar
      Windows port for __codecvt_utf8<wchar_t>. · 271426e6
      Howard Hinnant authored
      llvm-svn: 185849
      271426e6
    • Stephen Lin's avatar
      Update docs to say that a FunctionPass should not inspect other functions than... · 095fee30
      Stephen Lin authored
      Update docs to say that a FunctionPass should not inspect other functions than the one being processed.
      Please let me know if you disagree with this assessment (no one has yet, after asking on llvm-commits and LLVMDev) and I will revert.
      
      llvm-svn: 185848
      095fee30
    • Manman Ren's avatar
      Debug Info: clean up usage of Verify. · 7504ed42
      Manman Ren authored
      No functionality change. It should suffice to check the type of a debug info
      metadata, instead of calling Verify.
      
      llvm-svn: 185847
      7504ed42
    • Jim Grosbach's avatar
      ARM: Improve codegen for generic vselect. · 24e102a9
      Jim Grosbach authored
      Fall back to by-element insert rather than building it up on the stack.
      
      rdar://14351991
      
      llvm-svn: 185846
      24e102a9
    • Michael Sartain's avatar
      Use target DisplaySource if available so we can get mixed source and assembly. · 4b2967ff
      Michael Sartain authored
      This fixes "disassemble -m -n __printf".
      
      llvm-svn: 185845
      4b2967ff
    • David Blaikie's avatar
      DebugInfo: Correct comment & re-format a nearby loop · ce1960f9
      David Blaikie authored
      llvm-svn: 185844
      ce1960f9
    • Shuxin Yang's avatar
      Fix a SCEV update problem. · efc4c01e
      Shuxin Yang authored
       The symptom is seg-fault, and the root cause is that a SCEV contains a SCEVUnknown
      which has null-pointer to a llvm::Value.
      
       This is how the problem take place:
       ===================================
        1). In the pristine input IR, there are two relevant instrutions Op1 and Op2, 
           Op1's corresponding SCEV (denoted as SCEV(op1)) is a SCEVUnknown, and
           SCEV(Op2) contains SCEV(Op1).  None of these instructions are dead.
      
           Op1 : V1 = ...
           ...
           Op2 : V2 = ... // directly or indirectly (data-flow) depends on Op1
          
        2) Optimizer (LSR in my case) generates an instruction holding the equivalent
           value of Op1, making Op1 dead. 
           Op1': V1' = ...
           Op1: V1 = ... ; now dead)
           Op2 : V2 = ... //Now deps on Op1', but the SCEV(Op2) still contains SCEV(Op1)
      
        3) Op1 is deleted, and call-back function is called to reset 
           SCEV(Op1) to indicate it is invalid. However, SCEV(Op2) is not 
           invalidated as well.
      
        4) Following pass get the cached, invalid SCEV(Op2), and try to manipulate it,
           and cause segfault. 
      
       The fix:
       ========
       It seems there is no clean yet inexpensive fix. I write to dev-list
      soliciting good solution, unforunately no ack. So, I decide to fix this 
      problem in a brute-force way:
      
        When ScalarEvolution::getSCEV is called, check if the cached SCEV 
      contains a invalid SCEVUnknow, if yes, remove the cached SCEV, and
      re-evaluate the SCEV from scratch.
      
        I compile buch of big *.c and *.cpp, fortunately, I don't see any increase
      in compile time.
      
       Misc:
      =====
       The reduced test-case has 2357 lines of code+other-stuff, too big to commit.
      
       rdar://14283433
      
      llvm-svn: 185843
      efc4c01e
Loading