Skip to content
  1. Jul 11, 2014
  2. Jul 10, 2014
    • Andrea Di Biagio's avatar
      Extend the test coverage in combine-vec-shuffle-2.ll adding some negative tests. · 2f6d821b
      Andrea Di Biagio authored
      Add test cases where we don't expect to trigger the combine optimizations
      introduced at revision 212748.
      
      No functional change intended.
      
      llvm-svn: 212756
      2f6d821b
    • Matt Arsenault's avatar
      Revert "Revert r212640, "Add trunc (select c, a, b) -> select c (trunc a), (trunc b) combine."" · 3332b706
      Matt Arsenault authored
      Don't try to convert the select condition type.
      
      llvm-svn: 212750
      3332b706
    • Andrea Di Biagio's avatar
      [DAG] Further improve the logic in DAGCombiner that folds a pair of shuffles... · b2921c7c
      Andrea Di Biagio authored
      [DAG] Further improve the logic in DAGCombiner that folds a pair of shuffles into a single shuffle if the resulting mask is legal.
      
      This patch teaches the DAGCombiner how to fold shuffles according to the
      following new rules:
        1. shuffle(shuffle(x, y), undef) -> x
        2. shuffle(shuffle(x, y), undef) -> y
        3. shuffle(shuffle(x, y), undef) -> shuffle(x, undef)
        4. shuffle(shuffle(x, y), undef) -> shuffle(y, undef)
      
      The backend avoids to combine shuffles according to rules 3. and 4. if
      the resulting shuffle does not have a legal mask. This is to avoid introducing
      illegal shuffles that are potentially expanded into a sub-optimal sequence of
      target specific dag nodes during vector legalization.
      
      Added test case combine-vec-shuffle-2.ll to verify that we correctly triggers
      the new rules when combining shuffles.
      
      llvm-svn: 212748
      b2921c7c
    • Akira Hatanaka's avatar
      [X86] Mark pseudo instruction TEST8ri_NOEREX as hasSIdeEffects=0. · 7cc27649
      Akira Hatanaka authored
      Also, add a case clause in X86InstrInfo::shouldScheduleAdjacent to enable
      macro-fusion.
      
      <rdar://problem/15680770>
      
      llvm-svn: 212747
      7cc27649
    • Eric Christopher's avatar
      Add the CSR company and the Kalimba DSP processor to Triple. · 54fe1b26
      Eric Christopher authored
      Patch by Matthew Gardiner with fixes by me.
      
      llvm-svn: 212745
      54fe1b26
    • Eric Christopher's avatar
      Make it possible for the Subtarget to change between function · 22405e4b
      Eric Christopher authored
      passes in the mips back end. This, unfortunately, required a
      bit of churn in the various predicates to use a pointer rather
      than a reference.
      
      llvm-svn: 212744
      22405e4b
    • Duncan P. N. Exon Smith's avatar
      InstCombine: Fix a crash in Descale for multiply-by-zero · 04934b0f
      Duncan P. N. Exon Smith authored
      Fix a crash in `InstCombiner::Descale()` when a multiply-by-zero gets
      created as an argument to a GEP partway through an iteration, causing
      -instcombine to optimize the GEP before the multiply.
      
      rdar://problem/17615671
      
      llvm-svn: 212742
      04934b0f
    • David Majnemer's avatar
      IR: Aliases don't belong to an explicit comdat · ed33243e
      David Majnemer authored
      Aliases inherit their comdat from their aliasee, they don't have an
      explicit comdat.
      
      This fixes PR20279.
      
      llvm-svn: 212732
      ed33243e
    • Hal Finkel's avatar
      Feeding isSafeToSpeculativelyExecute its DataLayout pointer (in Sink) · 511fea7a
      Hal Finkel authored
      This is the one remaining place I see where passing
      isSafeToSpeculativelyExecute a DataLayout pointer might matter (at least for
      loads) -- I think I got the others in r212720. Most of the other remaining
      callers of isSafeToSpeculativelyExecute only use it for call sites (or
      otherwise exclude loads).
      
      llvm-svn: 212730
      511fea7a
    • David Majnemer's avatar
      Mips: Silence a -Wcovered-switch-default · 99ef2365
      David Majnemer authored
      Remove a default label which covered no enumerators, replace it with a
      llvm_unreachable.
      
      No functionality changed.
      
      llvm-svn: 212729
      99ef2365
    • Zoran Jovanovic's avatar
      [mips] Added FPXX modeless calling convention. · 255d00dc
      Zoran Jovanovic authored
      Differential Revision: http://reviews.llvm.org/D4293
      
      llvm-svn: 212726
      255d00dc
    • Arnaud A. de Grandmaison's avatar
      [AArch64] Add logical alias instructions to MC AsmParser · f6432311
      Arnaud A. de Grandmaison authored
      This patch teaches the AsmParser to accept some logical+immediate
      instructions and convert them as shown:
      
        bic  Rd, Rn, #imm  ->  and Rd, Rn, #~imm
        bics Rd, Rn, #imm  ->  ands Rd, Rn, #~imm
        orn  Rd, Rn, #imm  ->  orr Rd, Rn, #~imm
        eon  Rd, Rn, #imm  ->  eor Rd, Rn, #~imm
      
      Those instructions are an alternate syntax available to assembly coders,
      and are needed in order to support code already compiling with some other
      assemblers. For example, the bic construct is used by the linux kernel.
      
      llvm-svn: 212722
      f6432311
    • Hal Finkel's avatar
      Feeding isSafeToSpeculativelyExecute its DataLayout pointer · a995f926
      Hal Finkel authored
      isSafeToSpeculativelyExecute can optionally take a DataLayout pointer. In the
      past, this was mainly used to make better decisions regarding divisions known
      not to trap, and so was not all that important for users concerned with "cheap"
      instructions. However, now it also helps look through bitcasts for
      dereferencable loads, and will also be important if/when we add a
      dereferencable pointer attribute.
      
      This is some initial work to feed a DataLayout pointer through to callers of
      isSafeToSpeculativelyExecute, generally where one was already available.
      
      llvm-svn: 212720
      a995f926
    • Tim Northover's avatar
      AArch64: correctly fast-isel i8 & i16 multiplies · fee2adef
      Tim Northover authored
      We were asking for a register for type i8 or i16 which caused an assert.
      
      rdar://problem/17620015
      
      llvm-svn: 212718
      fee2adef
    • Daniel Sanders's avatar
      [mips] Add support for -modd-spreg/-mno-odd-spreg · 7e527423
      Daniel Sanders authored
      Summary:
      When -mno-odd-spreg is in effect, 32-bit floating point values are not
      permitted in odd FPU registers. The option also prohibits 32-bit and 64-bit
      floating point comparison results from being written to odd registers.
      
      This option has three purposes:
      * It allows support for certain MIPS implementations such as loongson-3a that
        do not allow the use of odd registers for single precision arithmetic.
      * When using -mfpxx, -mno-odd-spreg is the default and this allows us to
        statically check that code is compliant with the O32 FPXX ABI since mtc1/mfc1
        instructions to/from odd registers are guaranteed not to appear for any
        reason. Once this has been established, the user can then re-enable
        -modd-spreg to regain the use of all 32 single-precision registers.
      * When using -mfp64 and -mno-odd-spreg together, an O32 extension named
        O32 FP64A is used as the ABI. This is intended to provide almost all
        functionality of an FR=1 processor but can also be executed on a FR=0 core
        with the assistance of a hardware compatibility mode which emulates FR=0
        behaviour on an FR=1 processor.
      
      * Added '.module oddspreg' and '.module nooddspreg' each of which update
        the .MIPS.abiflags section appropriately
      * Moved setFpABI() call inside emitDirectiveModuleFP() so that the caller
        doesn't have to remember to do it.
      * MipsABIFlags now calculates the flags1 and flags2 member on demand rather
        than trying to maintain them in the same format they will be emitted in.
      
      There is one portion of the -mfp64 and -mno-odd-spreg combination that is not
      implemented yet. Moves to/from odd-numbered double-precision registers must not
      use mtc1. I will fix this in a follow-up.
      
      Differential Revision: http://reviews.llvm.org/D4383
      
      llvm-svn: 212717
      7e527423
    • Zinovy Nis's avatar
      [x32] Add AsmBackend for X32 which uses ELF32 with x86_64 (the author is Pavel Chupin). · cad431c1
      Zinovy Nis authored
      This is minimal change for backend required to have "hello world" compiled and working on x32 target (x86_64-linux-gnux32). More patches for x32 will follow.
      
      Differential Revision: http://reviews.llvm.org/D4181
      
      llvm-svn: 212716
      cad431c1
    • Chandler Carruth's avatar
      [x86,SDAG] Introduce any- and sign-extend-vector-inreg nodes analogous · 0b666e06
      Chandler Carruth authored
      to the zero-extend-vector-inreg node introduced previously for the same
      purpose: manage the type legalization of widened extend operations,
      especially to support the experimental widening mode for x86.
      
      I'm adding both because sign-extend is expanded in terms of any-extend
      with shifts to propagate the sign bit. This removes the last
      fundamental scalarization from vec_cast2.ll (a test case that hit many
      really bad edge cases for widening legalization), although the trunc
      tests in that file still appear scalarized because the the shuffle
      legalization is scalarizing. Funny thing, I've been working on that.
      
      Some initial experiments with this and SSE2 scenarios is showing
      moderately good behavior already for sign extension. Still some work to
      do on the shuffle combining on X86 before we're generating optimal
      sequences, but avoiding scalarization is a huge step forward.
      
      llvm-svn: 212714
      0b666e06
    • Richard Sandiford's avatar
      [SystemZ] Use SystemZCallingConv.td to define callee-saved registers · 02bb0ec3
      Richard Sandiford authored
          
      Just a clean-up.  No behavioral change intended.
      
      llvm-svn: 212711
      02bb0ec3
    • NAKAMURA Takumi's avatar
      SpecialCaseList.h: Fix -Wdocumentation with \code. · 76d7e08a
      NAKAMURA Takumi authored
      llvm-svn: 212710
      76d7e08a
    • NAKAMURA Takumi's avatar
      e808b28e
Loading