diff options
| author | Craig Topper <craig.topper@gmail.com> | 2016-04-17 22:49:46 +0000 | 
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2016-04-17 22:49:46 +0000 | 
| commit | 221e1c2b1ffab2d403ea85eed3c4f69658054ec3 (patch) | |
| tree | 48f0c8d26b8a639868ef0ba8c5dabe2b719ef0c5 /llvm/lib/Target/X86/X86ISelLowering.cpp | |
| parent | fb9871b49587c2ad6b5125741aa7a78e03a512b7 (diff) | |
| download | bcm5719-llvm-221e1c2b1ffab2d403ea85eed3c4f69658054ec3.tar.gz bcm5719-llvm-221e1c2b1ffab2d403ea85eed3c4f69658054ec3.zip | |
[X86] Be explicit about calls to setOperationAction for AVX2 and AVX512 rather than just looping over all vector types and conditinally matching them. NFC
llvm-svn: 266577
Diffstat (limited to 'llvm/lib/Target/X86/X86ISelLowering.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 87 | 
1 files changed, 42 insertions, 45 deletions
| diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index a69c029f83c..a9e5f1fdf44 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -1159,21 +1159,22 @@ X86TargetLowering::X86TargetLowering(const X86TargetMachine &TM,        setOperationAction(ISD::SRA, VT, Custom);      } -    // Custom lower several nodes for 256-bit types. -    for (MVT VT : MVT::vector_valuetypes()) { -      if (VT.getScalarSizeInBits() >= 32) { -        setOperationAction(ISD::MLOAD,  VT, Legal); -        setOperationAction(ISD::MSTORE, VT, Legal); -      } -      // Extract subvector is special because the value type -      // (result) is 128-bit but the source is 256-bit wide. -      if (VT.is128BitVector()) { -        setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Custom); -      } -      // Do not attempt to custom lower other non-256-bit vectors -      if (!VT.is256BitVector()) -        continue; +    for (auto VT : { MVT::v4i32, MVT::v8i32, MVT::v2i64, MVT::v4i64, +                     MVT::v4f32, MVT::v8f32, MVT::v2f64, MVT::v4f64 }) { +      setOperationAction(ISD::MLOAD,  VT, Legal); +      setOperationAction(ISD::MSTORE, VT, Legal); +    } + +    // Extract subvector is special because the value type +    // (result) is 128-bit but the source is 256-bit wide. +    for (auto VT : { MVT::v16i8, MVT::v8i16, MVT::v4i32, MVT::v2i64, +                     MVT::v4f32, MVT::v2f64 }) { +      setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Custom); +    } +    // Custom lower several nodes for 256-bit types. +    for (MVT VT : { MVT::v32i8, MVT::v16i16, MVT::v8i32, MVT::v4i64, +                    MVT::v8f32, MVT::v4f64 }) {        setOperationAction(ISD::BUILD_VECTOR,       VT, Custom);        setOperationAction(ISD::VECTOR_SHUFFLE,     VT, Custom);        setOperationAction(ISD::VSELECT,            VT, Custom); @@ -1446,37 +1447,33 @@ X86TargetLowering::X86TargetLowering(const X86TargetMachine &TM,        setOperationAction(ISD::MUL,             MVT::v8i64, Legal);      }      // Custom lower several nodes. -    for (MVT VT : MVT::vector_valuetypes()) { -      unsigned EltSize = VT.getVectorElementType().getSizeInBits(); -      if ((VT.is128BitVector() || VT.is256BitVector()) && EltSize >= 32) { -        setOperationAction(ISD::MGATHER,  VT, Custom); -        setOperationAction(ISD::MSCATTER, VT, Custom); -      } -      // Extract subvector is special because the value type -      // (result) is 256/128-bit but the source is 512-bit wide. -      if (VT.is128BitVector() || VT.is256BitVector()) { -        setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Custom); -      } -      if (VT.getVectorElementType() == MVT::i1) -        setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Legal); - -      // Do not attempt to custom lower other non-512-bit vectors -      if (!VT.is512BitVector()) -        continue; - -      if (EltSize >= 32) { -        setOperationAction(ISD::VECTOR_SHUFFLE,      VT, Custom); -        setOperationAction(ISD::INSERT_VECTOR_ELT,   VT, Custom); -        setOperationAction(ISD::BUILD_VECTOR,        VT, Custom); -        setOperationAction(ISD::VSELECT,             VT, Legal); -        setOperationAction(ISD::EXTRACT_VECTOR_ELT,  VT, Custom); -        setOperationAction(ISD::SCALAR_TO_VECTOR,    VT, Custom); -        setOperationAction(ISD::INSERT_SUBVECTOR,    VT, Custom); -        setOperationAction(ISD::MLOAD,               VT, Legal); -        setOperationAction(ISD::MSTORE,              VT, Legal); -        setOperationAction(ISD::MGATHER,  VT, Legal); -        setOperationAction(ISD::MSCATTER, VT, Custom); -      } +    for (auto VT : { MVT::v4i32, MVT::v8i32, MVT::v2i64, MVT::v4i64, +                     MVT::v4f32, MVT::v8f32, MVT::v2f64, MVT::v4f64 }) { +      setOperationAction(ISD::MGATHER,  VT, Custom); +      setOperationAction(ISD::MSCATTER, VT, Custom); +    } +    // Extract subvector is special because the value type +    // (result) is 256-bit but the source is 512-bit wide. +    // 128-bit was made Custom under AVX1. +    for (auto VT : { MVT::v32i8, MVT::v16i16, MVT::v8i32, MVT::v4i64, +                     MVT::v8f32, MVT::v4f64 }) +      setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Custom); +    for (auto VT : { MVT::v2i1, MVT::v4i1, MVT::v8i1, +                     MVT::v16i1, MVT::v32i1, MVT::v64i1 }) +      setOperationAction(ISD::EXTRACT_SUBVECTOR, VT, Legal); + +    for (auto VT : { MVT::v16i32, MVT::v8i64, MVT::v16f32, MVT::v8f64 }) { +      setOperationAction(ISD::VECTOR_SHUFFLE,      VT, Custom); +      setOperationAction(ISD::INSERT_VECTOR_ELT,   VT, Custom); +      setOperationAction(ISD::BUILD_VECTOR,        VT, Custom); +      setOperationAction(ISD::VSELECT,             VT, Legal); +      setOperationAction(ISD::EXTRACT_VECTOR_ELT,  VT, Custom); +      setOperationAction(ISD::SCALAR_TO_VECTOR,    VT, Custom); +      setOperationAction(ISD::INSERT_SUBVECTOR,    VT, Custom); +      setOperationAction(ISD::MLOAD,               VT, Legal); +      setOperationAction(ISD::MSTORE,              VT, Legal); +      setOperationAction(ISD::MGATHER,             VT, Legal); +      setOperationAction(ISD::MSCATTER,            VT, Custom);      }      for (auto VT : { MVT::v64i8, MVT::v32i16, MVT::v16i32 }) {        setOperationPromotedToType(ISD::SELECT, VT, MVT::v8i64); | 

