@@ -2473,9 +2473,13 @@ bool X86FastISel::X86SelectFPExtOrFPTrunc(const Instruction *I,
2473
2473
bool X86FastISel::X86SelectFPExt (const Instruction *I) {
2474
2474
if (X86ScalarSSEf64 && I->getType ()->isDoubleTy () &&
2475
2475
I->getOperand (0 )->getType ()->isFloatTy ()) {
2476
+ bool HasAVX512 = Subtarget->hasAVX512 ();
2476
2477
// fpext from float to double.
2477
- unsigned Opc = Subtarget->hasAVX () ? X86::VCVTSS2SDrr : X86::CVTSS2SDrr;
2478
- return X86SelectFPExtOrFPTrunc (I, Opc, &X86::FR64RegClass);
2478
+ unsigned Opc =
2479
+ HasAVX512 ? X86::VCVTSS2SDZrr
2480
+ : Subtarget->hasAVX () ? X86::VCVTSS2SDrr : X86::CVTSS2SDrr;
2481
+ return X86SelectFPExtOrFPTrunc (
2482
+ I, Opc, HasAVX512 ? &X86::FR64XRegClass : &X86::FR64RegClass);
2479
2483
}
2480
2484
2481
2485
return false ;
@@ -2484,9 +2488,13 @@ bool X86FastISel::X86SelectFPExt(const Instruction *I) {
2484
2488
bool X86FastISel::X86SelectFPTrunc (const Instruction *I) {
2485
2489
if (X86ScalarSSEf64 && I->getType ()->isFloatTy () &&
2486
2490
I->getOperand (0 )->getType ()->isDoubleTy ()) {
2491
+ bool HasAVX512 = Subtarget->hasAVX512 ();
2487
2492
// fptrunc from double to float.
2488
- unsigned Opc = Subtarget->hasAVX () ? X86::VCVTSD2SSrr : X86::CVTSD2SSrr;
2489
- return X86SelectFPExtOrFPTrunc (I, Opc, &X86::FR32RegClass);
2493
+ unsigned Opc =
2494
+ HasAVX512 ? X86::VCVTSD2SSZrr
2495
+ : Subtarget->hasAVX () ? X86::VCVTSD2SSrr : X86::CVTSD2SSrr;
2496
+ return X86SelectFPExtOrFPTrunc (
2497
+ I, Opc, HasAVX512 ? &X86::FR32XRegClass : &X86::FR32RegClass);
2490
2498
}
2491
2499
2492
2500
return false ;
0 commit comments