mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
Revert "ARM: improve RTABI 4.2 conformance on Linux"
This reverts commit r215862 due to nightly failures. Will work on getting a reduced test case, but I wanted to get our bots green in the meantime. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216325 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f5aa254622
commit
8eb867e97d
@ -312,8 +312,8 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
|||||||
// Conversions between floating types.
|
// Conversions between floating types.
|
||||||
// RTABI chapter 4.1.2, Table 7
|
// RTABI chapter 4.1.2, Table 7
|
||||||
{ RTLIB::FPROUND_F64_F32, "__aeabi_d2f", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::FPROUND_F64_F32, "__aeabi_d2f", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::FPEXT_F32_F64, "__aeabi_f2d", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::FPROUND_F64_F16, "__aeabi_d2h", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::FPROUND_F64_F16, "__aeabi_d2h", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
|
{ RTLIB::FPEXT_F32_F64, "__aeabi_f2d", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
|
|
||||||
// Integer to floating-point conversions.
|
// Integer to floating-point conversions.
|
||||||
// RTABI chapter 4.1.2, Table 8
|
// RTABI chapter 4.1.2, Table 8
|
||||||
@ -328,31 +328,21 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
|||||||
|
|
||||||
// Long long helper functions
|
// Long long helper functions
|
||||||
// RTABI chapter 4.2, Table 9
|
// RTABI chapter 4.2, Table 9
|
||||||
{ RTLIB::MUL_I64, "__aeabi_lmul", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::MUL_I64, "__aeabi_lmul", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
// FIXME: __aeabi_ldivmod is SDIVREM not SDIV; we should custom lower this
|
{ RTLIB::SHL_I64, "__aeabi_llsl", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIV_I64, "__aeabi_ldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SRL_I64, "__aeabi_llsr", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIVREM_I64, "__aeabi_ldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SRA_I64, "__aeabi_lasr", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
// FIXME: __aeabi_uldivmod is UDIVREM not UDIV; we should custom lower this
|
|
||||||
{ RTLIB::UDIV_I64, "__aeabi_uldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::UDIVREM_I64, "__aeabi_uldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::SHL_I64, "__aeabi_llsl", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::SRL_I64, "__aeabi_llsr", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::SRA_I64, "__aeabi_lasr", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
|
|
||||||
// Integer division functions
|
// Integer division functions
|
||||||
// RTABI chapter 4.3.1
|
// RTABI chapter 4.3.1
|
||||||
{ RTLIB::SDIV_I8, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SDIV_I8, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIV_I16, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SDIV_I16, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIV_I32, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SDIV_I32, "__aeabi_idiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::UDIV_I8, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::SDIV_I64, "__aeabi_ldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::UDIV_I16, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::UDIV_I8, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::UDIV_I32, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::UDIV_I16, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIVREM_I8, "__aeabi_idivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::UDIV_I32, "__aeabi_uidiv", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIVREM_I16, "__aeabi_idivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
{ RTLIB::UDIV_I64, "__aeabi_uldivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
||||||
{ RTLIB::SDIVREM_I32, "__aeabi_idivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::UDIVREM_I8, "__aeabi_uidivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::UDIVREM_I16, "__aeabi_uidivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
{ RTLIB::UDIVREM_I32, "__aeabi_uidivmod", CallingConv::ARM_AAPCS, ISD::SETCC_INVALID },
|
|
||||||
|
|
||||||
// Memory operations
|
// Memory operations
|
||||||
// RTABI chapter 4.3.4
|
// RTABI chapter 4.3.4
|
||||||
@ -367,9 +357,6 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
|||||||
if (LC.Cond != ISD::SETCC_INVALID)
|
if (LC.Cond != ISD::SETCC_INVALID)
|
||||||
setCmpLibcallCC(LC.Op, LC.Cond);
|
setCmpLibcallCC(LC.Op, LC.Cond);
|
||||||
}
|
}
|
||||||
|
|
||||||
setOperationAction(ISD::SDIVREM, MVT::i32, Custom);
|
|
||||||
setOperationAction(ISD::UDIVREM, MVT::i32, Custom);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Subtarget->isTargetWindows()) {
|
if (Subtarget->isTargetWindows()) {
|
||||||
@ -721,9 +708,31 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: Also set divmod for SREM on EABI
|
// FIXME: Also set divmod for SREM on EABI
|
||||||
setOperationAction(ISD::SREM, MVT::i32, Expand);
|
setOperationAction(ISD::SREM, MVT::i32, Expand);
|
||||||
setOperationAction(ISD::UREM, MVT::i32, Expand);
|
setOperationAction(ISD::UREM, MVT::i32, Expand);
|
||||||
if (!Subtarget->isTargetAEABI()) {
|
// Register based DivRem for AEABI (RTABI 4.2)
|
||||||
|
if (Subtarget->isTargetAEABI()) {
|
||||||
|
setLibcallName(RTLIB::SDIVREM_I8, "__aeabi_idivmod");
|
||||||
|
setLibcallName(RTLIB::SDIVREM_I16, "__aeabi_idivmod");
|
||||||
|
setLibcallName(RTLIB::SDIVREM_I32, "__aeabi_idivmod");
|
||||||
|
setLibcallName(RTLIB::SDIVREM_I64, "__aeabi_ldivmod");
|
||||||
|
setLibcallName(RTLIB::UDIVREM_I8, "__aeabi_uidivmod");
|
||||||
|
setLibcallName(RTLIB::UDIVREM_I16, "__aeabi_uidivmod");
|
||||||
|
setLibcallName(RTLIB::UDIVREM_I32, "__aeabi_uidivmod");
|
||||||
|
setLibcallName(RTLIB::UDIVREM_I64, "__aeabi_uldivmod");
|
||||||
|
|
||||||
|
setLibcallCallingConv(RTLIB::SDIVREM_I8, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::SDIVREM_I16, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::SDIVREM_I32, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::SDIVREM_I64, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::UDIVREM_I8, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::UDIVREM_I16, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::UDIVREM_I32, CallingConv::ARM_AAPCS);
|
||||||
|
setLibcallCallingConv(RTLIB::UDIVREM_I64, CallingConv::ARM_AAPCS);
|
||||||
|
|
||||||
|
setOperationAction(ISD::SDIVREM, MVT::i32, Custom);
|
||||||
|
setOperationAction(ISD::UDIVREM, MVT::i32, Custom);
|
||||||
|
} else {
|
||||||
setOperationAction(ISD::SDIVREM, MVT::i32, Expand);
|
setOperationAction(ISD::SDIVREM, MVT::i32, Expand);
|
||||||
setOperationAction(ISD::UDIVREM, MVT::i32, Expand);
|
setOperationAction(ISD::UDIVREM, MVT::i32, Expand);
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,10 @@ entry:
|
|||||||
; EABI: __aeabi_idivmod
|
; EABI: __aeabi_idivmod
|
||||||
; EABI: mov [[div:r[0-9]+]], r0
|
; EABI: mov [[div:r[0-9]+]], r0
|
||||||
; EABI: mov [[rem:r[0-9]+]], r1
|
; EABI: mov [[rem:r[0-9]+]], r1
|
||||||
; GNU: __aeabi_idivmod
|
; GNU: __aeabi_idiv
|
||||||
|
; GNU: mov [[sum:r[0-9]+]], r0
|
||||||
|
; GNU: __modsi3
|
||||||
|
; GNU: add [[sum]]{{.*}}r0
|
||||||
; DARWIN: ___divsi3
|
; DARWIN: ___divsi3
|
||||||
; DARWIN: mov [[sum:r[0-9]+]], r0
|
; DARWIN: mov [[sum:r[0-9]+]], r0
|
||||||
; DARWIN: __modsi3
|
; DARWIN: __modsi3
|
||||||
@ -31,7 +34,7 @@ entry:
|
|||||||
%conv14 = trunc i32 %add13 to i16
|
%conv14 = trunc i32 %add13 to i16
|
||||||
; EABI: add r0{{.*}}r1
|
; EABI: add r0{{.*}}r1
|
||||||
; EABI: sxth r0, r0
|
; EABI: sxth r0, r0
|
||||||
; GNU: add r0{{.*}}
|
; GNU: add r0{{.*}}[[sum]]
|
||||||
; GNU: sxth r0, r0
|
; GNU: sxth r0, r0
|
||||||
; DARWIN: add r0{{.*}}[[sum]]
|
; DARWIN: add r0{{.*}}[[sum]]
|
||||||
; DARWIN: sxth r0, r0
|
; DARWIN: sxth r0, r0
|
||||||
@ -48,7 +51,10 @@ entry:
|
|||||||
; EABI: __aeabi_idivmod
|
; EABI: __aeabi_idivmod
|
||||||
; EABI: mov [[div:r[0-9]+]], r0
|
; EABI: mov [[div:r[0-9]+]], r0
|
||||||
; EABI: mov [[rem:r[0-9]+]], r1
|
; EABI: mov [[rem:r[0-9]+]], r1
|
||||||
; GNU: __aeabi_idivmod
|
; GNU: __aeabi_idiv
|
||||||
|
; GNU: mov [[sum:r[0-9]+]], r0
|
||||||
|
; GNU: __modsi3
|
||||||
|
; GNU: add [[sum]]{{.*}}r0
|
||||||
; DARWIN: ___divsi3
|
; DARWIN: ___divsi3
|
||||||
; DARWIN: mov [[sum:r[0-9]+]], r0
|
; DARWIN: mov [[sum:r[0-9]+]], r0
|
||||||
; DARWIN: __modsi3
|
; DARWIN: __modsi3
|
||||||
@ -60,7 +66,7 @@ entry:
|
|||||||
%add = add nsw i32 %rem, %div
|
%add = add nsw i32 %rem, %div
|
||||||
%add2 = add nsw i32 %add, %rem1
|
%add2 = add nsw i32 %add, %rem1
|
||||||
; EABI: add r0{{.*}}r1
|
; EABI: add r0{{.*}}r1
|
||||||
; GNU: add r0{{.*}}
|
; GNU: add r0{{.*}}[[sum]]
|
||||||
; DARWIN: add r0{{.*}}[[sum]]
|
; DARWIN: add r0{{.*}}[[sum]]
|
||||||
ret i32 %add2
|
ret i32 %add2
|
||||||
}
|
}
|
||||||
@ -73,7 +79,10 @@ entry:
|
|||||||
%div = udiv i32 %a, %b
|
%div = udiv i32 %a, %b
|
||||||
%rem = urem i32 %a, %b
|
%rem = urem i32 %a, %b
|
||||||
; EABI: __aeabi_uidivmod
|
; EABI: __aeabi_uidivmod
|
||||||
; GNU: __aeabi_uidivmod
|
; GNU: __aeabi_uidiv
|
||||||
|
; GNU: mov [[sum:r[0-9]+]], r0
|
||||||
|
; GNU: __umodsi3
|
||||||
|
; GNU: add [[sum]]{{.*}}r0
|
||||||
; DARWIN: ___udivsi3
|
; DARWIN: ___udivsi3
|
||||||
; DARWIN: mov [[sum:r[0-9]+]], r0
|
; DARWIN: mov [[sum:r[0-9]+]], r0
|
||||||
; DARWIN: __umodsi3
|
; DARWIN: __umodsi3
|
||||||
@ -85,7 +94,7 @@ entry:
|
|||||||
%add = add nuw i32 %rem, %div
|
%add = add nuw i32 %rem, %div
|
||||||
%add2 = add nuw i32 %add, %rem1
|
%add2 = add nuw i32 %add, %rem1
|
||||||
; EABI: add r0{{.*}}r1
|
; EABI: add r0{{.*}}r1
|
||||||
; GNU: add r0{{.*}}
|
; GNU: add r0{{.*}}[[sum]]
|
||||||
; DARWIN: add r0{{.*}}[[sum]]
|
; DARWIN: add r0{{.*}}[[sum]]
|
||||||
ret i32 %add2
|
ret i32 %add2
|
||||||
}
|
}
|
||||||
@ -122,13 +131,15 @@ entry:
|
|||||||
%div = sdiv i32 %a, %b
|
%div = sdiv i32 %a, %b
|
||||||
%rem = srem i32 %a, %b
|
%rem = srem i32 %a, %b
|
||||||
; EABI: __aeabi_idivmod
|
; EABI: __aeabi_idivmod
|
||||||
; GNU: __aeabi_idivmod
|
; GNU: __aeabi_idiv
|
||||||
|
; GNU: mov [[sum:r[0-9]+]], r0
|
||||||
|
; GNU: __modsi3
|
||||||
; DARWIN: ___divsi3
|
; DARWIN: ___divsi3
|
||||||
; DARWIN: mov [[sum:r[0-9]+]], r0
|
; DARWIN: mov [[sum:r[0-9]+]], r0
|
||||||
; DARWIN: __modsi3
|
; DARWIN: __modsi3
|
||||||
%add = add nsw i32 %rem, %div
|
%add = add nsw i32 %rem, %div
|
||||||
; EABI: add r0{{.*}}r1
|
; EABI: add r0{{.*}}r1
|
||||||
; GNU: add r0{{.*}}r1
|
; GNU: add r0{{.*}}[[sum]]
|
||||||
; DARWIN: add r0{{.*}}[[sum]]
|
; DARWIN: add r0{{.*}}[[sum]]
|
||||||
ret i32 %add
|
ret i32 %add
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user