Skip to content
  1. Feb 28, 2010
    • Dan Gohman's avatar
      Implement XMM subregs. · bdd6405f
      Dan Gohman authored
      Extracting the low element of a vector is now done with EXTRACT_SUBREG,
      and the zero-extension performed by load movss is now modeled with
      SUBREG_TO_REG, and so on.
      
      Register-to-register movss and movsd are no longer considered copies;
      they are two-address instructions which insert a scalar into a vector.
      
      llvm-svn: 97354
      bdd6405f
    • Dan Gohman's avatar
      The mayHaveSideEffects flag is no longer used. · 8c5d683a
      Dan Gohman authored
      llvm-svn: 97348
      8c5d683a
  2. Feb 27, 2010
  3. Feb 26, 2010
  4. Feb 25, 2010
  5. Feb 24, 2010
  6. Feb 23, 2010
  7. Feb 22, 2010
  8. Feb 21, 2010
  9. Feb 19, 2010
    • Charles Davis's avatar
      Add support for the 'alignstack' attribute to the x86 backend. Fixes PR5254. · 7e477677
      Charles Davis authored
      Also, FileCheck'ize a test.
      
      llvm-svn: 96686
      7e477677
    • Bob Wilson's avatar
      Revert Anton's most recent EH patch (r96637), since it breaks a lot of · 336c0a1c
      Bob Wilson authored
      ARM and Thumb tests.
      
      llvm-svn: 96680
      336c0a1c
    • Duncan Sands's avatar
      Revert commits 96556 and 96640, because commit 96556 breaks the · d0bf6f64
      Duncan Sands authored
      dragonegg self-host build.  I reverted 96640 in order to revert
      96556 (96640 goes on top of 96556), but it also looks like with
      both of them applied the breakage happens even earlier.  The
      symptom of the 96556 miscompile is the following crash:
      
        llvm[3]: Compiling AlphaISelLowering.cpp for Release build
        cc1plus: /home/duncan/tmp/tmp/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp:4982: void llvm::SelectionDAG::ReplaceAllUsesWith(llvm::SDNode*, llvm::SDNode*, llvm::SelectionDAG::DAGUpdateListener*): Assertion `(!From->hasAnyUseOfValue(i) || From->getValueType(i) == To->getValueType(i)) && "Cannot use this version of ReplaceAllUsesWith!"' failed.
        Stack dump:
        0.	Running pass 'X86 DAG->DAG Instruction Selection' on function '@_ZN4llvm19AlphaTargetLowering14LowerOperationENS_7SDValueERNS_12SelectionDAGE'
        g++: Internal error: Aborted (program cc1plus)
      
      This occurs when building LLVM using LLVM built by LLVM (via
      dragonegg).  Probably LLVM has miscompiled itself, though it
      may have miscompiled GCC and/or dragonegg itself: at this point
      of the self-host build, all of GCC, LLVM and dragonegg were built
      using LLVM.  Unfortunately this kind of thing is extremely hard
      to debug, and while I did rummage around a bit I didn't find any
      smoking guns, aka obviously miscompiled code.
      
      Found by bisection.
      
      r96556 | evancheng | 2010-02-18 03:13:50 +0100 (Thu, 18 Feb 2010) | 5 lines
      
      Some dag combiner goodness:
      Transform br (xor (x, y)) -> br (x != y)
      Transform br (xor (xor (x,y), 1)) -> br (x == y)
      Also normalize (and (X, 1) == / != 1 -> (and (X, 1)) != / == 0 to match to "test on x86" and "tst on arm"
      
      r96640 | evancheng | 2010-02-19 01:34:39 +0100 (Fri, 19 Feb 2010) | 16 lines
      
      Transform (xor (setcc), (setcc)) == / != 1 to
      (xor (setcc), (setcc)) != / == 1.
      
      e.g. On x86_64
        %0 = icmp eq i32 %x, 0
        %1 = icmp eq i32 %y, 0
        %2 = xor i1 %1, %0
        br i1 %2, label %bb, label %return
      =>
      	testl   %edi, %edi
      	sete    %al
      	testl   %esi, %esi
      	sete    %cl
      	cmpb    %al, %cl
      	je      LBB1_2
      
      llvm-svn: 96672
      d0bf6f64
    • Anton Korobeynikov's avatar
      Use the same encoding for EH stuff uniformly on all MachO targets. · 9baeb020
      Anton Korobeynikov authored
      This hopefulyl should unbreak EH on PPC/Darwin.
      
      llvm-svn: 96637
      9baeb020
  10. Feb 18, 2010
  11. Feb 17, 2010
  12. Feb 16, 2010
    • Chris Lattner's avatar
      fix rdar://7653908, a crash on a case where we would fold a load · afac7dad
      Chris Lattner authored
      into a roundss intrinsic, producing a cyclic dag.  The root cause
      of this is badness handling ComplexPattern nodes in the old dagisel
      that I noticed through inspection.  Eliminate a copy of the of the
      code that handled ComplexPatterns by making EmitChildMatchCode call
      into EmitMatchCode.
      
      llvm-svn: 96408
      afac7dad
Loading