mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-12 15:30:46 +00:00
CodeGen: use MSVC division on windows itanium
Windows itanium is identical to MSVC when dealing with everything but C++. Lower the math routines into msvcrt rather than compiler-rt. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@284175 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b0c1779a79
commit
6ec5391920
@ -114,7 +114,8 @@ X86TargetLowering::X86TargetLowering(const X86TargetMachine &TM,
|
||||
addBypassSlowDiv(64, 16);
|
||||
}
|
||||
|
||||
if (Subtarget.isTargetKnownWindowsMSVC()) {
|
||||
if (Subtarget.isTargetKnownWindowsMSVC() ||
|
||||
Subtarget.isTargetWindowsItanium()) {
|
||||
// Setup Windows compiler runtime calls.
|
||||
setLibcallName(RTLIB::SDIV_I64, "_alldiv");
|
||||
setLibcallName(RTLIB::UDIV_I64, "_aulldiv");
|
||||
|
38
test/CodeGen/X86/divide-windows-itanium.ll
Normal file
38
test/CodeGen/X86/divide-windows-itanium.ll
Normal file
@ -0,0 +1,38 @@
|
||||
; RUN: llc -mtriple i686-windows-itanium -filetype asm -o - %s | FileCheck %s
|
||||
|
||||
define i64 @f(i64 %i, i64 %j) {
|
||||
%1 = sdiv i64 %i, %j
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK-LABEL: _f:
|
||||
; CHECK-NOT: calll ___divdi3
|
||||
; CHECK: calll __alldiv
|
||||
|
||||
define i64 @g(i64 %i, i64 %j) {
|
||||
%1 = udiv i64 %i, %j
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK-LABEL: _g:
|
||||
; CHECK-NOT: calll ___udivdi3
|
||||
; CHECK: calll __aulldiv
|
||||
|
||||
define i64 @h(i64 %i, i64 %j) {
|
||||
%1 = srem i64 %i, %j
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK-LABEL: _h:
|
||||
; CHECK-NOT: calll ___moddi3
|
||||
; CHECK: calll __allrem
|
||||
|
||||
define i64 @i(i64 %i, i64 %j) {
|
||||
%1 = urem i64 %i, %j
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK-LABEL: _i:
|
||||
; CHECK-NOT: calll ___umoddi3
|
||||
; CHECK: calll __aullrem
|
||||
|
Loading…
x
Reference in New Issue
Block a user