1*9880d681SAndroid Build Coastguard Worker; RUN: opt -S -instcombine < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workerdeclare float @llvm.round.f32(float) #0 4*9880d681SAndroid Build Coastguard Workerdeclare double @llvm.round.f64(double) #0 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_01 7*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float 1.000000e+00 8*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_01() #0 { 9*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float 1.25) #0 10*9880d681SAndroid Build Coastguard Worker ret float %x 11*9880d681SAndroid Build Coastguard Worker} 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_02 14*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float -1.000000e+00 15*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_02() #0 { 16*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float -1.25) #0 17*9880d681SAndroid Build Coastguard Worker ret float %x 18*9880d681SAndroid Build Coastguard Worker} 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_03 21*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float 2.000000e+00 22*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_03() #0 { 23*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float 1.5) #0 24*9880d681SAndroid Build Coastguard Worker ret float %x 25*9880d681SAndroid Build Coastguard Worker} 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_04 28*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float -2.000000e+00 29*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_04() #0 { 30*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float -1.5) #0 31*9880d681SAndroid Build Coastguard Worker ret float %x 32*9880d681SAndroid Build Coastguard Worker} 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_05 35*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float 3.000000e+00 36*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_05() #0 { 37*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float 2.75) #0 38*9880d681SAndroid Build Coastguard Worker ret float %x 39*9880d681SAndroid Build Coastguard Worker} 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f32_06 42*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret float -3.000000e+00 43*9880d681SAndroid Build Coastguard Workerdefine float @constant_fold_round_f32_06() #0 { 44*9880d681SAndroid Build Coastguard Worker %x = call float @llvm.round.f32(float -2.75) #0 45*9880d681SAndroid Build Coastguard Worker ret float %x 46*9880d681SAndroid Build Coastguard Worker} 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_01 49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double 1.000000e+00 50*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_01() #0 { 51*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double 1.3) #0 52*9880d681SAndroid Build Coastguard Worker ret double %x 53*9880d681SAndroid Build Coastguard Worker} 54*9880d681SAndroid Build Coastguard Worker 55*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_02 56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double -1.000000e+00 57*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_02() #0 { 58*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double -1.3) #0 59*9880d681SAndroid Build Coastguard Worker ret double %x 60*9880d681SAndroid Build Coastguard Worker} 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_03 63*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double 2.000000e+00 64*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_03() #0 { 65*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double 1.5) #0 66*9880d681SAndroid Build Coastguard Worker ret double %x 67*9880d681SAndroid Build Coastguard Worker} 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_04 70*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double -2.000000e+00 71*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_04() #0 { 72*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double -1.5) #0 73*9880d681SAndroid Build Coastguard Worker ret double %x 74*9880d681SAndroid Build Coastguard Worker} 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_05 77*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double 3.000000e+00 78*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_05() #0 { 79*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double 2.7) #0 80*9880d681SAndroid Build Coastguard Worker ret double %x 81*9880d681SAndroid Build Coastguard Worker} 82*9880d681SAndroid Build Coastguard Worker 83*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @constant_fold_round_f64_06 84*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret double -3.000000e+00 85*9880d681SAndroid Build Coastguard Workerdefine double @constant_fold_round_f64_06() #0 { 86*9880d681SAndroid Build Coastguard Worker %x = call double @llvm.round.f64(double -2.7) #0 87*9880d681SAndroid Build Coastguard Worker ret double %x 88*9880d681SAndroid Build Coastguard Worker} 89*9880d681SAndroid Build Coastguard Worker 90*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind readnone } 91