OSDN Git Service

[X86] Don't zero the upper bits of the k-register before extracting a single bit...
authorCraig Topper <craig.topper@intel.com>
Thu, 14 Dec 2017 18:35:25 +0000 (18:35 +0000)
committerCraig Topper <craig.topper@intel.com>
Thu, 14 Dec 2017 18:35:25 +0000 (18:35 +0000)
commitf74c3ebbfb48f6b54de0a19947cdefc583a83de1
treebdb6ae93544f34d369e0fa7f041f9d603ba71074
parent7c66ebefee4b3150cc90512e301eebf676737ea1
[X86] Don't zero the upper bits of the k-register before extracting a single bit from a vXi1.

This doesn't match the semantics of the extract_vector_elt operation. Nothing downstream knows the bits were zeroed so they still get masked or sign extended after the extrat anyway.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@320723 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/X86/X86ISelLowering.cpp
test/CodeGen/X86/avx512-insert-extract.ll
test/CodeGen/X86/avx512-intrinsics-upgrade.ll
test/CodeGen/X86/avx512-mask-op.ll
test/CodeGen/X86/avx512-schedule.ll
test/CodeGen/X86/avx512dq-intrinsics-upgrade.ll
test/CodeGen/X86/avx512vl-vec-masked-cmp.ll
test/CodeGen/X86/masked_gather_scatter.ll
test/CodeGen/X86/pr33349.ll