1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple thumbv7-windows-itanium -filetype asm -o - %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple thumbv7-windows-msvc -filetype asm -o - %s | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workerdefine arm_aapcs_vfpcc i32 @sdiv32(i32 %divisor, i32 %divident) { 5*9880d681SAndroid Build Coastguard Workerentry: 6*9880d681SAndroid Build Coastguard Worker %div = sdiv i32 %divident, %divisor 7*9880d681SAndroid Build Coastguard Worker ret i32 %div 8*9880d681SAndroid Build Coastguard Worker} 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: sdiv32: 11*9880d681SAndroid Build Coastguard Worker; CHECK: cbz r0 12*9880d681SAndroid Build Coastguard Worker; CHECK: b 13*9880d681SAndroid Build Coastguard Worker; CHECK: udf.w #249 14*9880d681SAndroid Build Coastguard Worker; CHECK: bl __rt_sdiv 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdefine arm_aapcs_vfpcc i32 @udiv32(i32 %divisor, i32 %divident) { 17*9880d681SAndroid Build Coastguard Workerentry: 18*9880d681SAndroid Build Coastguard Worker %div = udiv i32 %divident, %divisor 19*9880d681SAndroid Build Coastguard Worker ret i32 %div 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: udiv32: 23*9880d681SAndroid Build Coastguard Worker; CHECK: cbz r0 24*9880d681SAndroid Build Coastguard Worker; CHECK: b 25*9880d681SAndroid Build Coastguard Worker; CHECK: udf.w #249 26*9880d681SAndroid Build Coastguard Worker; CHECK: bl __rt_udiv 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Workerdefine arm_aapcs_vfpcc i64 @sdiv64(i64 %divisor, i64 %divident) { 29*9880d681SAndroid Build Coastguard Workerentry: 30*9880d681SAndroid Build Coastguard Worker %div = sdiv i64 %divident, %divisor 31*9880d681SAndroid Build Coastguard Worker ret i64 %div 32*9880d681SAndroid Build Coastguard Worker} 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: sdiv64: 35*9880d681SAndroid Build Coastguard Worker; CHECK: orr.w r4, r0, r1 36*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: cbz r4 37*9880d681SAndroid Build Coastguard Worker; CHECK: b 38*9880d681SAndroid Build Coastguard Worker; CHECK: udf.w #249 39*9880d681SAndroid Build Coastguard Worker; CHECK: bl __rt_sdiv64 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Workerdefine arm_aapcs_vfpcc i64 @udiv64(i64 %divisor, i64 %divident) { 42*9880d681SAndroid Build Coastguard Workerentry: 43*9880d681SAndroid Build Coastguard Worker %div = udiv i64 %divident, %divisor 44*9880d681SAndroid Build Coastguard Worker ret i64 %div 45*9880d681SAndroid Build Coastguard Worker} 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: udiv64: 48*9880d681SAndroid Build Coastguard Worker; CHECK: orr.w r4, r0, r1 49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: cbz r4 50*9880d681SAndroid Build Coastguard Worker; CHECK: b 51*9880d681SAndroid Build Coastguard Worker; CHECK: udf.w #249 52*9880d681SAndroid Build Coastguard Worker; CHECK: bl __rt_udiv64 53*9880d681SAndroid Build Coastguard Worker 54