1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179
|
// RUN: mlir-opt -split-input-file -spirv-canonicalize-gl %s | FileCheck %s
// CHECK-LABEL: func @clamp_fordlessthan
// CHECK-SAME: (%[[INPUT:.*]]: f32, %[[MIN:.*]]: f32, %[[MAX:.*]]: f32)
func.func @clamp_fordlessthan(%input: f32, %min: f32, %max: f32) -> f32 {
// CHECK: [[RES:%.*]] = spirv.GL.FClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.FOrdLessThan %min, %input : f32
%mid = spirv.Select %0, %input, %min : i1, f32
%1 = spirv.FOrdLessThan %mid, %max : f32
%2 = spirv.Select %1, %mid, %max : i1, f32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : f32
}
// -----
// CHECK-LABEL: func @clamp_fordlessthan
// CHECK-SAME: (%[[INPUT:.*]]: f32, %[[MIN:.*]]: f32, %[[MAX:.*]]: f32)
func.func @clamp_fordlessthan(%input: f32, %min: f32, %max: f32) -> f32 {
// CHECK: [[RES:%.*]] = spirv.GL.FClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.FOrdLessThan %input, %min : f32
%mid = spirv.Select %0, %min, %input : i1, f32
%1 = spirv.FOrdLessThan %max, %input : f32
%2 = spirv.Select %1, %max, %mid : i1, f32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : f32
}
// -----
// CHECK-LABEL: func @clamp_fordlessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: f32, %[[MIN:.*]]: f32, %[[MAX:.*]]: f32)
func.func @clamp_fordlessthanequal(%input: f32, %min: f32, %max: f32) -> f32 {
// CHECK: [[RES:%.*]] = spirv.GL.FClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.FOrdLessThanEqual %min, %input : f32
%mid = spirv.Select %0, %input, %min : i1, f32
%1 = spirv.FOrdLessThanEqual %mid, %max : f32
%2 = spirv.Select %1, %mid, %max : i1, f32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : f32
}
// -----
// CHECK-LABEL: func @clamp_fordlessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: f32, %[[MIN:.*]]: f32, %[[MAX:.*]]: f32)
func.func @clamp_fordlessthanequal(%input: f32, %min: f32, %max: f32) -> f32 {
// CHECK: [[RES:%.*]] = spirv.GL.FClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.FOrdLessThanEqual %input, %min : f32
%mid = spirv.Select %0, %min, %input : i1, f32
%1 = spirv.FOrdLessThanEqual %max, %input : f32
%2 = spirv.Select %1, %max, %mid : i1, f32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : f32
}
// -----
// CHECK-LABEL: func @clamp_slessthan
// CHECK-SAME: (%[[INPUT:.*]]: si32, %[[MIN:.*]]: si32, %[[MAX:.*]]: si32)
func.func @clamp_slessthan(%input: si32, %min: si32, %max: si32) -> si32 {
// CHECK: [[RES:%.*]] = spirv.GL.SClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.SLessThan %min, %input : si32
%mid = spirv.Select %0, %input, %min : i1, si32
%1 = spirv.SLessThan %mid, %max : si32
%2 = spirv.Select %1, %mid, %max : i1, si32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : si32
}
// -----
// CHECK-LABEL: func @clamp_slessthan
// CHECK-SAME: (%[[INPUT:.*]]: si32, %[[MIN:.*]]: si32, %[[MAX:.*]]: si32)
func.func @clamp_slessthan(%input: si32, %min: si32, %max: si32) -> si32 {
// CHECK: [[RES:%.*]] = spirv.GL.SClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.SLessThan %input, %min : si32
%mid = spirv.Select %0, %min, %input : i1, si32
%1 = spirv.SLessThan %max, %input : si32
%2 = spirv.Select %1, %max, %mid : i1, si32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : si32
}
// -----
// CHECK-LABEL: func @clamp_slessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: si32, %[[MIN:.*]]: si32, %[[MAX:.*]]: si32)
func.func @clamp_slessthanequal(%input: si32, %min: si32, %max: si32) -> si32 {
// CHECK: [[RES:%.*]] = spirv.GL.SClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.SLessThanEqual %min, %input : si32
%mid = spirv.Select %0, %input, %min : i1, si32
%1 = spirv.SLessThanEqual %mid, %max : si32
%2 = spirv.Select %1, %mid, %max : i1, si32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : si32
}
// -----
// CHECK-LABEL: func @clamp_slessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: si32, %[[MIN:.*]]: si32, %[[MAX:.*]]: si32)
func.func @clamp_slessthanequal(%input: si32, %min: si32, %max: si32) -> si32 {
// CHECK: [[RES:%.*]] = spirv.GL.SClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.SLessThanEqual %input, %min : si32
%mid = spirv.Select %0, %min, %input : i1, si32
%1 = spirv.SLessThanEqual %max, %input : si32
%2 = spirv.Select %1, %max, %mid : i1, si32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : si32
}
// -----
// CHECK-LABEL: func @clamp_ulessthan
// CHECK-SAME: (%[[INPUT:.*]]: i32, %[[MIN:.*]]: i32, %[[MAX:.*]]: i32)
func.func @clamp_ulessthan(%input: i32, %min: i32, %max: i32) -> i32 {
// CHECK: [[RES:%.*]] = spirv.GL.UClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.ULessThan %min, %input : i32
%mid = spirv.Select %0, %input, %min : i1, i32
%1 = spirv.ULessThan %mid, %max : i32
%2 = spirv.Select %1, %mid, %max : i1, i32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : i32
}
// -----
// CHECK-LABEL: func @clamp_ulessthan
// CHECK-SAME: (%[[INPUT:.*]]: i32, %[[MIN:.*]]: i32, %[[MAX:.*]]: i32)
func.func @clamp_ulessthan(%input: i32, %min: i32, %max: i32) -> i32 {
// CHECK: [[RES:%.*]] = spirv.GL.UClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.ULessThan %input, %min : i32
%mid = spirv.Select %0, %min, %input : i1, i32
%1 = spirv.ULessThan %max, %input : i32
%2 = spirv.Select %1, %max, %mid : i1, i32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : i32
}
// -----
// CHECK-LABEL: func @clamp_ulessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: i32, %[[MIN:.*]]: i32, %[[MAX:.*]]: i32)
func.func @clamp_ulessthanequal(%input: i32, %min: i32, %max: i32) -> i32 {
// CHECK: [[RES:%.*]] = spirv.GL.UClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.ULessThanEqual %min, %input : i32
%mid = spirv.Select %0, %input, %min : i1, i32
%1 = spirv.ULessThanEqual %mid, %max : i32
%2 = spirv.Select %1, %mid, %max : i1, i32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : i32
}
// -----
// CHECK-LABEL: func @clamp_ulessthanequal
// CHECK-SAME: (%[[INPUT:.*]]: i32, %[[MIN:.*]]: i32, %[[MAX:.*]]: i32)
func.func @clamp_ulessthanequal(%input: i32, %min: i32, %max: i32) -> i32 {
// CHECK: [[RES:%.*]] = spirv.GL.UClamp %[[INPUT]], %[[MIN]], %[[MAX]]
%0 = spirv.ULessThanEqual %input, %min : i32
%mid = spirv.Select %0, %min, %input : i1, i32
%1 = spirv.ULessThanEqual %max, %input : i32
%2 = spirv.Select %1, %max, %mid : i1, i32
// CHECK-NEXT: spirv.ReturnValue [[RES]]
spirv.ReturnValue %2 : i32
}
|