diff options
| author | Craig Topper <craig.topper@gmail.com> | 2016-12-18 04:17:00 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2016-12-18 04:17:00 +0000 |
| commit | 2baef8f466447d8621be9e8bfbb6b14e7baba2a4 (patch) | |
| tree | db027155ffed0449bb7ce354864a7c5a3b143db3 /llvm/lib/Target | |
| parent | 1d3dcb0602df7a1f641bd02352c72e16c0c76485 (diff) | |
| download | bcm5719-llvm-2baef8f466447d8621be9e8bfbb6b14e7baba2a4.tar.gz bcm5719-llvm-2baef8f466447d8621be9e8bfbb6b14e7baba2a4.zip | |
[AVX-512] Make sure VLX is also enabled before using EVEX encoded logic ops for scalars. I missed this in r290049.
llvm-svn: 290055
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrAVX512.td | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrSSE.td | 2 |
2 files changed, 2 insertions, 2 deletions
diff --git a/llvm/lib/Target/X86/X86InstrAVX512.td b/llvm/lib/Target/X86/X86InstrAVX512.td index ac226e6c6ff..03ba06d1f6d 100644 --- a/llvm/lib/Target/X86/X86InstrAVX512.td +++ b/llvm/lib/Target/X86/X86InstrAVX512.td @@ -4559,7 +4559,7 @@ defm : avx512_fp_logical_lowering_sizes<"VPOR", or>; defm : avx512_fp_logical_lowering_sizes<"VPXOR", xor>; defm : avx512_fp_logical_lowering_sizes<"VPANDN", X86andnp>; -let Predicates = [HasDQI] in { +let Predicates = [HasVLX,HasDQI] in { // Use packed logical operations for scalar ops. def : Pat<(f64 (X86fand FR64X:$src1, FR64X:$src2)), (COPY_TO_REGCLASS (VANDPDZ128rr diff --git a/llvm/lib/Target/X86/X86InstrSSE.td b/llvm/lib/Target/X86/X86InstrSSE.td index 6f344fcd7d6..734c8a8f747 100644 --- a/llvm/lib/Target/X86/X86InstrSSE.td +++ b/llvm/lib/Target/X86/X86InstrSSE.td @@ -2932,7 +2932,7 @@ let Predicates = [HasAVX, NoVLX_Or_NoDQI] in { (VANDNPDYrm VR256:$src1, addr:$src2)>; } -let Predicates = [HasAVX, NoDQI] in { +let Predicates = [HasAVX, NoVLX_Or_NoDQI] in { // Use packed logical operations for scalar ops. def : Pat<(f64 (X86fand FR64:$src1, FR64:$src2)), (COPY_TO_REGCLASS (VANDPDrr |

