[llvm] 99d6e31 - [NFC][SROA] Add C++'s `std::clamp()` testcase from PR47271/PR49909

Roman Lebedev via llvm-commits llvm-commits at lists.llvm.org
Fri Apr 9 14:56:49 PDT 2021


Author: Roman Lebedev
Date: 2021-04-10T00:56:00+03:00
New Revision: 99d6e31e0bd02d484c213a7446fd707c62dec45b

URL: https://github.com/llvm/llvm-project/commit/99d6e31e0bd02d484c213a7446fd707c62dec45b
DIFF: https://github.com/llvm/llvm-project/commit/99d6e31e0bd02d484c213a7446fd707c62dec45b.diff

LOG: [NFC][SROA] Add C++'s `std::clamp()` testcase from PR47271/PR49909

Added: 
    llvm/test/Transforms/SROA/std-clamp.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/SROA/std-clamp.ll b/llvm/test/Transforms/SROA/std-clamp.ll
new file mode 100644
index 0000000000000..5619042522884
--- /dev/null
+++ b/llvm/test/Transforms/SROA/std-clamp.ll
@@ -0,0 +1,35 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt < %s -sroa -S | FileCheck %s
+
+target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
+
+define float @_Z8stdclampfff(float %x, float %lo, float %hi) {
+; CHECK-LABEL: @_Z8stdclampfff(
+; CHECK-NEXT:  bb:
+; CHECK-NEXT:    [[I:%.*]] = alloca float, align 4
+; CHECK-NEXT:    [[I3:%.*]] = alloca float, align 4
+; CHECK-NEXT:    [[I4:%.*]] = alloca float, align 4
+; CHECK-NEXT:    store float [[X:%.*]], float* [[I]], align 4
+; CHECK-NEXT:    store float [[LO:%.*]], float* [[I3]], align 4
+; CHECK-NEXT:    store float [[HI:%.*]], float* [[I4]], align 4
+; CHECK-NEXT:    [[I5:%.*]] = fcmp fast olt float [[X]], [[LO]]
+; CHECK-NEXT:    [[I6:%.*]] = fcmp fast olt float [[HI]], [[X]]
+; CHECK-NEXT:    [[I7:%.*]] = select i1 [[I6]], float* [[I4]], float* [[I]]
+; CHECK-NEXT:    [[I8:%.*]] = select i1 [[I5]], float* [[I3]], float* [[I7]]
+; CHECK-NEXT:    [[I9:%.*]] = load float, float* [[I8]], align 4
+; CHECK-NEXT:    ret float [[I9]]
+;
+bb:
+  %i = alloca float, align 4
+  %i3 = alloca float, align 4
+  %i4 = alloca float, align 4
+  store float %x, float* %i, align 4
+  store float %lo, float* %i3, align 4
+  store float %hi, float* %i4, align 4
+  %i5 = fcmp fast olt float %x, %lo
+  %i6 = fcmp fast olt float %hi, %x
+  %i7 = select i1 %i6, float* %i4, float* %i
+  %i8 = select i1 %i5, float* %i3, float* %i7
+  %i9 = load float, float* %i8, align 4
+  ret float %i9
+}


        


More information about the llvm-commits mailing list