Index: llvm/lib/Target/AArch64/AArch64ISelLowering.cpp =================================================================== --- llvm/lib/Target/AArch64/AArch64ISelLowering.cpp +++ llvm/lib/Target/AArch64/AArch64ISelLowering.cpp @@ -17320,6 +17320,8 @@ return; case ISD::FP_TO_UINT: case ISD::FP_TO_SINT: + case ISD::STRICT_FP_TO_SINT: + case ISD::STRICT_FP_TO_UINT: assert(N->getValueType(0) == MVT::i128 && "unexpected illegal conversion"); // Let normal code take care of it by not adding anything to Results. return; Index: llvm/test/CodeGen/AArch64/fptosi-strictfp.ll =================================================================== --- /dev/null +++ llvm/test/CodeGen/AArch64/fptosi-strictfp.ll @@ -0,0 +1,24 @@ +; RUN: llc < %s | FileCheck %s +target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128" +target triple = "aarch64-arm-none-eabi" + +define hidden void @test_fixtfti(fp128 %ld) local_unnamed_addr #0 { +entry: + %conv = call i128 @llvm.experimental.constrained.fptosi.i128.f128(fp128 %ld, metadata !"fpexcept.strict") #0 + ret void +} +; CHECK: bl __fixtfti + +declare i128 @llvm.experimental.constrained.fptosi.i128.f128(fp128, metadata) #1 + +define hidden void @test_fixtftu(fp128 %ld) local_unnamed_addr #0 { +entry: + %conv = call i128 @llvm.experimental.constrained.fptoui.i128.f128(fp128 %ld, metadata !"fpexcept.strict") #0 + ret void +} +; CHECK: bl __fixunstfti + +declare i128 @llvm.experimental.constrained.fptoui.i128.f128(fp128, metadata) #1 + +attributes #0 = { strictfp } +attributes #1 = { inaccessiblememonly mustprogress nofree nosync nounwind willreturn }