]> granicus.if.org Git - llvm/commit
AMDGPU: Add a fast path for icmp.i1(src, false, NE)
authorMarek Olsak <marek.olsak@amd.com>
Tue, 15 Jan 2019 02:13:18 +0000 (02:13 +0000)
committerMarek Olsak <marek.olsak@amd.com>
Tue, 15 Jan 2019 02:13:18 +0000 (02:13 +0000)
commit68fa6767b40f89e38ae321490f5fecfde2ae13ca
tree097c0217b2ac570cb75e687737180c89bbed633b
parent548b0e2a26dcfc7173c72345092bf7a91c2ff2cd
AMDGPU: Add a fast path for icmp.i1(src, false, NE)

Summary:
This allows moving the condition from the intrinsic to the standard ICmp
opcode, so that LLVM can do simplifications on it. The icmp.i1 intrinsic
is an identity for retrieving the SGPR mask.

And we can also get the mask from and i1, or i1, xor i1.

Reviewers: arsenm, nhaehnle

Subscribers: kzhuravl, jvesely, wdng, yaxunl, dstuttard, tpr, t-tye, llvm-commits

Differential Revision: https://reviews.llvm.org/D52060

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@351150 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/AMDGPU/SIISelLowering.cpp
lib/Target/AMDGPU/SIInstructions.td
lib/Transforms/InstCombine/InstCombineCalls.cpp
test/CodeGen/AMDGPU/llvm.amdgcn.icmp.ll
test/Transforms/InstCombine/AMDGPU/amdgcn-intrinsics.ll