| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: opt -S -passes=instsimplify < %s | FileCheck %s |
| |
| declare float @roundevenf(float) #0 |
| declare float @llvm.roundeven.f32(float) |
| declare double @roundeven(double) #0 |
| declare double @llvm.roundeven.f64(double) |
| |
| define float @constant_fold_roundeven_f32_01() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_01( |
| ; CHECK-SAME: ) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: ret float 1.000000e+00 |
| ; |
| %x = call float @roundevenf(float 1.25) #0 |
| ret float %x |
| } |
| |
| define float @constant_fold_roundeven_f32_02() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_02( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float -1.000000e+00 |
| ; |
| %x = call float @llvm.roundeven.f32(float -1.25) #0 |
| ret float %x |
| } |
| |
| ; roundeven rounds ties to even, so 1.5 -> 2.0 (nearest even) |
| define float @constant_fold_roundeven_f32_03() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_03( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float 2.000000e+00 |
| ; |
| %x = call float @roundevenf(float 1.5) #0 |
| ret float %x |
| } |
| |
| ; roundeven rounds ties to even, so -1.5 -> -2.0 (nearest even) |
| define float @constant_fold_roundeven_f32_04() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_04( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float -2.000000e+00 |
| ; |
| %x = call float @llvm.roundeven.f32(float -1.5) #0 |
| ret float %x |
| } |
| |
| ; roundeven rounds ties to even, so 2.5 -> 2.0 (nearest even) |
| define float @constant_fold_roundeven_f32_05() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_05( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float 2.000000e+00 |
| ; |
| %x = call float @roundevenf(float 2.5) #0 |
| ret float %x |
| } |
| |
| ; roundeven rounds ties to even, so -2.5 -> -2.0 (nearest even) |
| define float @constant_fold_roundeven_f32_06() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_06( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float -2.000000e+00 |
| ; |
| %x = call float @llvm.roundeven.f32(float -2.5) #0 |
| ret float %x |
| } |
| |
| define float @constant_fold_roundeven_f32_07() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_07( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float 3.000000e+00 |
| ; |
| %x = call float @roundevenf(float 2.75) #0 |
| ret float %x |
| } |
| |
| define float @constant_fold_roundeven_f32_08() #0 { |
| ; CHECK-LABEL: define float @constant_fold_roundeven_f32_08( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret float -3.000000e+00 |
| ; |
| %x = call float @llvm.roundeven.f32(float -2.75) #0 |
| ret float %x |
| } |
| |
| define double @constant_fold_roundeven_f64_01() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_01( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double 1.000000e+00 |
| ; |
| %x = call double @roundeven(double 1.3) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_02() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_02( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double -1.000000e+00 |
| ; |
| %x = call double @llvm.roundeven.f64(double -1.3) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_03() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_03( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double 2.000000e+00 |
| ; |
| %x = call double @roundeven(double 1.5) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_04() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_04( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double -2.000000e+00 |
| ; |
| %x = call double @llvm.roundeven.f64(double -1.5) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_05() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_05( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double 2.000000e+00 |
| ; |
| %x = call double @roundeven(double 2.5) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_06() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_06( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double -2.000000e+00 |
| ; |
| %x = call double @llvm.roundeven.f64(double -2.5) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_07() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_07( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double 3.000000e+00 |
| ; |
| %x = call double @roundeven(double 2.7) #0 |
| ret double %x |
| } |
| |
| define double @constant_fold_roundeven_f64_08() #0 { |
| ; CHECK-LABEL: define double @constant_fold_roundeven_f64_08( |
| ; CHECK-SAME: ) #[[ATTR0]] { |
| ; CHECK-NEXT: ret double -3.000000e+00 |
| ; |
| %x = call double @llvm.roundeven.f64(double -2.7) #0 |
| ret double %x |
| } |
| |
| attributes #0 = { nounwind readnone willreturn } |