mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-27 11:55:49 +00:00
[X86] Teach getSetCCResultType to handle more than just SimpleVTs when looking at larger than 512-bit vectors.
Which VTs are considered simple is determined by the superset of the legal types of all targets in LLVM. If we're looking at VTs that are going to be split down to 512-bits we should allow any VT not just simple ones since the simple list changes over time as new targets are added. llvm-svn: 319110
This commit is contained in:
parent
6163329caa
commit
256cc48df6
@ -1716,25 +1716,22 @@ EVT X86TargetLowering::getSetCCResultType(const DataLayout &DL,
|
|||||||
if (!VT.isVector())
|
if (!VT.isVector())
|
||||||
return MVT::i8;
|
return MVT::i8;
|
||||||
|
|
||||||
|
if (VT.getSizeInBits() >= 512) {
|
||||||
|
EVT EltVT = VT.getVectorElementType();
|
||||||
|
const unsigned NumElts = VT.getVectorNumElements();
|
||||||
|
if (Subtarget.hasAVX512())
|
||||||
|
if (EltVT == MVT::i32 || EltVT == MVT::i64 ||
|
||||||
|
EltVT == MVT::f32 || EltVT == MVT::f64)
|
||||||
|
return EVT::getVectorVT(Context, MVT::i1, NumElts);
|
||||||
|
if (Subtarget.hasBWI())
|
||||||
|
if (EltVT == MVT::i8 || EltVT == MVT::i16)
|
||||||
|
return EVT::getVectorVT(Context, MVT::i1, NumElts);
|
||||||
|
}
|
||||||
|
|
||||||
if (VT.isSimple()) {
|
if (VT.isSimple()) {
|
||||||
MVT VVT = VT.getSimpleVT();
|
MVT VVT = VT.getSimpleVT();
|
||||||
const unsigned NumElts = VVT.getVectorNumElements();
|
const unsigned NumElts = VVT.getVectorNumElements();
|
||||||
MVT EltVT = VVT.getVectorElementType();
|
MVT EltVT = VVT.getVectorElementType();
|
||||||
if (VVT.getSizeInBits() >= 512) {
|
|
||||||
if (Subtarget.hasAVX512())
|
|
||||||
if (EltVT == MVT::i32 || EltVT == MVT::i64 ||
|
|
||||||
EltVT == MVT::f32 || EltVT == MVT::f64)
|
|
||||||
switch(NumElts) {
|
|
||||||
case 8: return MVT::v8i1;
|
|
||||||
case 16: return MVT::v16i1;
|
|
||||||
}
|
|
||||||
if (Subtarget.hasBWI())
|
|
||||||
if (EltVT == MVT::i8 || EltVT == MVT::i16)
|
|
||||||
switch(NumElts) {
|
|
||||||
case 32: return MVT::v32i1;
|
|
||||||
case 64: return MVT::v64i1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Subtarget.hasBWI() && Subtarget.hasVLX())
|
if (Subtarget.hasBWI() && Subtarget.hasVLX())
|
||||||
return MVT::getVectorVT(MVT::i1, NumElts);
|
return MVT::getVectorVT(MVT::i1, NumElts);
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user