| Commit message (Collapse) | Author | Age | Files | Lines | |
|---|---|---|---|---|---|
| * | GlobalISel: Implement fewerElementsVector for phi | Matt Arsenault | 2019-02-28 | 1 | -0/+1 |
| | | | | | llvm-svn: 355048 | ||||
| * | GlobalISel: Implement moreElementsVector for phi | Matt Arsenault | 2019-02-28 | 1 | -0/+1 |
| | | | | | llvm-svn: 355047 | ||||
| * | AMDGPU/GlobalISel: Fix bit ops for non-power-of-2 sizes | Matt Arsenault | 2019-02-25 | 1 | -0/+2 |
| | | | | | llvm-svn: 354825 | ||||
| * | AMDGPU/GlobalISel: Clamp max implicit_def elements | Matt Arsenault | 2019-02-25 | 1 | -1/+2 |
| | | | | | llvm-svn: 354818 | ||||
| * | AMDGPU/GlobalISel: Make phis legal | Matt Arsenault | 2019-02-21 | 1 | -0/+13 |
| | | | | | llvm-svn: 354592 | ||||
| * | AMDGPU/GlobalISel: Fix bit count ops for non-power-of-2 types | Matt Arsenault | 2019-02-21 | 1 | -1/+3 |
| | | | | | llvm-svn: 354587 | ||||
| * | GlobalISel: Fix fewerElementsVector for ctlz with different result type | Matt Arsenault | 2019-02-20 | 1 | -2/+2 |
| | | | | | | | Also complete the set of related operations. llvm-svn: 354480 | ||||
| * | GlobalISel: Implement moreElementsVector for g_insert results | Matt Arsenault | 2019-02-20 | 1 | -14/+24 |
| | | | | | llvm-svn: 354477 | ||||
| * | GlobalISel: Implement moreElementsVector for select | Matt Arsenault | 2019-02-19 | 1 | -18/+9 |
| | | | | | llvm-svn: 354354 | ||||
| * | GlobalISel: Implement moreElementsVector for G_EXTRACT source | Matt Arsenault | 2019-02-19 | 1 | -0/+1 |
| | | | | | llvm-svn: 354348 | ||||
| * | GlobalISel: Implement moreElementsVector for bit ops | Matt Arsenault | 2019-02-19 | 1 | -0/+20 |
| | | | | | llvm-svn: 354345 | ||||
| * | GlobalISel: Implement widenScalar for g_extract scalar results | Matt Arsenault | 2019-02-18 | 1 | -2/+3 |
| | | | | | llvm-svn: 354293 | ||||
| * | GlobalISel: Add alignment to LegalityQuery MMOs | Matt Arsenault | 2019-02-14 | 1 | -9/+10 |
| | | | | | | | | This allows targets to specify the minimum alignment required for the load/store. llvm-svn: 354071 | ||||
| * | AMDGPU/GlobalISel: Fix RegBankSelect for GEP. | Matt Arsenault | 2019-02-14 | 1 | -22/+14 |
| | | | | | | | | | | | This is basically a pointer typed add, so shouldn't be any different. This was assuming everything was an SGPR, which is not true. Also cleanup legality for GEP. I don't seem to be seeing the problem the hack marking s64 as a legal pointer type the comment mentions. llvm-svn: 354067 | ||||
| * | AMDGPU/GlobalISel: Only make f16 constants legal on f16 targets | Matt Arsenault | 2019-02-12 | 1 | -2/+9 |
| | | | | | | | We could deal with it, but there's no real point. llvm-svn: 353845 | ||||
| * | GlobalISel: Implement moreElementsVector for implicit_def | Matt Arsenault | 2019-02-11 | 1 | -1/+19 |
| | | | | | llvm-svn: 353754 | ||||
| * | GlobalISel: Add G_FCANONICALIZE instruction | Matt Arsenault | 2019-02-11 | 1 | -1/+1 |
| | | | | | llvm-svn: 353719 | ||||
| * | AMDGPU/GlobalISel: Fix shift legalization for non-power-of-2 | Matt Arsenault | 2019-02-08 | 1 | -0/+2 |
| | | | | | | | | | clampScalar doesn't do anything for non-power-of-2 in range. There should probably be a combination rule to reduce the number of matching rules. llvm-svn: 353526 | ||||
| * | AMDGPU/GlobalISel: Fix non-power-of-2 implicit_def | Matt Arsenault | 2019-02-08 | 1 | -1/+2 |
| | | | | | llvm-svn: 353522 | ||||
| * | AMDGPU/GlobalISel: Don't use a copy in addrspacecast lowering | Matt Arsenault | 2019-02-08 | 1 | -1/+1 |
| | | | | | llvm-svn: 353516 | ||||
| * | AMDGPU/GlobalISel: Legalize addrspacecast | Matt Arsenault | 2019-02-08 | 1 | -0/+177 |
| | | | | | | | | Use a placeholder constant for now on targets that need the load from the queue ptr. llvm-svn: 353497 | ||||
| * | GlobalISel: Implement narrowScalar for shift main type | Matt Arsenault | 2019-02-07 | 1 | -3/+9 |
| | | | | | | | | | | | | | | | | This is pretty much directly ported from SelectionDAG. Doesn't include the shift by non-constant but known bits version, since there isn't a globalisel version of computeKnownBits yet. This shows a disadvantage of targets not specifically which type should be used for the shift amount. If type 0 is legalized before type 1, the operations on the shift amount type use the wider type (which are also less likely to legalize). This can be avoided by targets specifying legalization actions on type 1 earlier than for type 0. llvm-svn: 353455 | ||||
| * | AMDGPU/GlobalISel: Restrict g_implicit_def legality | Matt Arsenault | 2019-02-07 | 1 | -8/+15 |
| | | | | | llvm-svn: 353452 | ||||
| * | AMDGPU/GlobalISel: Legalize fsqrt | Matt Arsenault | 2019-02-07 | 1 | -0/+12 |
| | | | | | llvm-svn: 353438 | ||||
| * | AMDGPU/GlobalISel: Legalize some f16 operations | Matt Arsenault | 2019-02-07 | 1 | -4/+16 |
| | | | | | llvm-svn: 353436 | ||||
| * | GlobalISel: Implement fewerElementsVector for shifts | Matt Arsenault | 2019-02-07 | 1 | -2/+7 |
| | | | | | | | | | | Introduce a new function which handles instructions with multiple type indices, but have the same number of vector elements. Also legalize v2s16 shifts when applicable. llvm-svn: 353432 | ||||
| * | GlobalISel: Try to make legalize rules more useful for vectors | Matt Arsenault | 2019-02-07 | 1 | -18/+7 |
| | | | | | | | | Mostly keep the existing functions on scalars, but add versions which also operate based on the vector element size. llvm-svn: 353430 | ||||
| * | AMDGPU/GlobalISel: Legalize select for v4s16 | Matt Arsenault | 2019-02-04 | 1 | -3/+3 |
| | | | | | | | | Also add some more select tests to help show future legalization changes. llvm-svn: 353045 | ||||
| * | [AMDGPU] Fix -Wunused-variable after rL352978 | Fangrui Song | 2019-02-03 | 1 | -1/+0 |
| | | | | | llvm-svn: 352982 | ||||
| * | GlobalISel: Implement widenScalar for G_UNMERGE_VALUES | Matt Arsenault | 2019-02-03 | 1 | -1/+2 |
| | | | | | | | | | | For the scalar case only. Also move the similar G_MERGE_VALUES handling to a separate function and cleanup to make them look more similar. llvm-svn: 352979 | ||||
| * | GlobalISel: Implement widenScalar for G_EXTRACT vector sources | Matt Arsenault | 2019-02-02 | 1 | -0/+18 |
| | | | | | | | Handle the basic element extract case. llvm-svn: 352978 | ||||
| * | AMDGPU/GlobalISel: Avoid reporting illegal extloads as legal | Matt Arsenault | 2019-02-02 | 1 | -1/+1 |
| | | | | | | | This avoids breaking a test in a future commit. llvm-svn: 352977 | ||||
| * | AMDGPU/GlobalISel: Legalize icmp for pointer types | Matt Arsenault | 2019-02-02 | 1 | -1/+10 |
| | | | | | llvm-svn: 352976 | ||||
| * | AMDGPU/GlobalISel: Legalize constant for pointer types | Matt Arsenault | 2019-02-02 | 1 | -3/+4 |
| | | | | | llvm-svn: 352975 | ||||
| * | AMDGPU/GlobalISel: Legalize select for pointer types | Matt Arsenault | 2019-02-02 | 1 | -4/+12 |
| | | | | | llvm-svn: 352974 | ||||
| * | GlobalISel: Legalization for inttoptr/ptrtoint | Matt Arsenault | 2019-02-02 | 1 | -6/+44 |
| | | | | | llvm-svn: 352973 | ||||
| * | GlobalISel: Handle odd splits in fewerElementsVector for load/store | Matt Arsenault | 2019-01-31 | 1 | -1/+2 |
| | | | | | llvm-svn: 352720 | ||||
| * | GlobalISel: Implement narrowScalar for bswap | Matt Arsenault | 2019-01-31 | 1 | -1/+5 |
| | | | | | llvm-svn: 352719 | ||||
| * | GlobalISel: Allow bitcount ops to have different result type | Matt Arsenault | 2019-01-31 | 1 | -5/+10 |
| | | | | | | | For AMDGPU the result is always 32-bit for 64-bit inputs. llvm-svn: 352717 | ||||
| * | GlobalISel: Implement fewerElementsVector for select | Matt Arsenault | 2019-01-30 | 1 | -1/+20 |
| | | | | | llvm-svn: 352601 | ||||
| * | AMDGPU/GlobalISel: Fix clamping shifts with 16-bit insts | Matt Arsenault | 2019-01-30 | 1 | -2/+3 |
| | | | | | llvm-svn: 352599 | ||||
| * | GlobalISel: Support narrowScalar for uneven loads | Matt Arsenault | 2019-01-30 | 1 | -0/+8 |
| | | | | | llvm-svn: 352594 | ||||
| * | GlobalISel: Partially implement widenScalar for MERGE_VALUES | Matt Arsenault | 2019-01-29 | 1 | -7/+8 |
| | | | | | llvm-svn: 352560 | ||||
| * | GlobalISel: Fix narrowScalar for load/store with different mem size | Matt Arsenault | 2019-01-29 | 1 | -2/+22 |
| | | | | | | | | | | | This was ignoring the memory size, and producing multiple loads/stores if the operand size was different from the memory size. I assume this is the intent of not having an explicit G_ANYEXTLOAD (although I think that would probably be better). llvm-svn: 352523 | ||||
| * | GlobalISel: Implement narrowScalar for mul | Matt Arsenault | 2019-01-27 | 1 | -0/+1 |
| | | | | | llvm-svn: 352300 | ||||
| * | GlobalISel: fewerElementsVector for intrinsic_trunc/intrinsic_round | Matt Arsenault | 2019-01-27 | 1 | -1/+2 |
| | | | | | llvm-svn: 352298 | ||||
| * | AMDGPU/GlobalISel: Use scalarize instead of clampMaxNumElements | Matt Arsenault | 2019-01-26 | 1 | -2/+1 |
| | | | | | llvm-svn: 352297 | ||||
| * | AMDGPU/GlobalISel: Legalize more bit ops | Matt Arsenault | 2019-01-26 | 1 | -4/+7 |
| | | | | | llvm-svn: 352295 | ||||
| * | AMDGPU/GlobalISel: Widen small uaddo/usubo | Matt Arsenault | 2019-01-26 | 1 | -1/+2 |
| | | | | | llvm-svn: 352294 | ||||
| * | AMDGPU/GlobalISel: Remove leftover setAction | Matt Arsenault | 2019-01-25 | 1 | -11/+8 |
| | | | | | | | Also move G_GEP actions together. llvm-svn: 352168 | ||||

