|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 |
| 2 | +; RUN: opt -passes='function(scalarizer)' -S < %s | FileCheck %s |
| 3 | + |
| 4 | +define noundef <2 x i32> @func(<2 x i32> noundef %a, <2 x i32> noundef %b) { |
| 5 | +; CHECK-LABEL: define noundef <2 x i32> @func( |
| 6 | +; CHECK-SAME: <2 x i32> noundef [[A:%.*]], <2 x i32> noundef [[B:%.*]]) { |
| 7 | +; CHECK-NEXT: [[A_I0:%.*]] = extractelement <2 x i32> [[A]], i64 0 |
| 8 | +; CHECK-NEXT: [[B_I0:%.*]] = extractelement <2 x i32> [[B]], i64 0 |
| 9 | +; CHECK-NEXT: [[UADDC_I0:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A_I0]], i32 [[B_I0]]) |
| 10 | +; CHECK-NEXT: [[A_I1:%.*]] = extractelement <2 x i32> [[A]], i64 1 |
| 11 | +; CHECK-NEXT: [[B_I1:%.*]] = extractelement <2 x i32> [[B]], i64 1 |
| 12 | +; CHECK-NEXT: [[UADDC_I1:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A_I1]], i32 [[B_I1]]) |
| 13 | +; CHECK-NEXT: [[CARRY_ELEM1:%.*]] = extractvalue { i32, i1 } [[UADDC_I0]], 1 |
| 14 | +; CHECK-NEXT: [[CARRY_ELEM11:%.*]] = extractvalue { i32, i1 } [[UADDC_I1]], 1 |
| 15 | +; CHECK-NEXT: [[SUM_ELEM0:%.*]] = extractvalue { i32, i1 } [[UADDC_I0]], 0 |
| 16 | +; CHECK-NEXT: [[SUM_ELEM02:%.*]] = extractvalue { i32, i1 } [[UADDC_I1]], 0 |
| 17 | +; CHECK-NEXT: [[CARRY_ZEXT_I0:%.*]] = zext i1 [[CARRY_ELEM1]] to i32 |
| 18 | +; CHECK-NEXT: [[CARRY_ZEXT_I1:%.*]] = zext i1 [[CARRY_ELEM11]] to i32 |
| 19 | +; CHECK-NEXT: [[RESULT_I0:%.*]] = add i32 [[SUM_ELEM0]], [[CARRY_ZEXT_I0]] |
| 20 | +; CHECK-NEXT: [[RESULT_I1:%.*]] = add i32 [[SUM_ELEM02]], [[CARRY_ZEXT_I1]] |
| 21 | +; CHECK-NEXT: [[RESULT_UPTO0:%.*]] = insertelement <2 x i32> poison, i32 [[RESULT_I0]], i64 0 |
| 22 | +; CHECK-NEXT: [[RESULT:%.*]] = insertelement <2 x i32> [[RESULT_UPTO0]], i32 [[RESULT_I1]], i64 1 |
| 23 | +; CHECK-NEXT: ret <2 x i32> [[RESULT]] |
| 24 | +; |
| 25 | + %uaddc = call { <2 x i32>, <2 x i1> } @llvm.uadd.with.overflow.v2i32(<2 x i32> %a, <2 x i32> %b) |
| 26 | + %carry = extractvalue { <2 x i32>, <2 x i1> } %uaddc, 1 |
| 27 | + %sum = extractvalue { <2 x i32>, <2 x i1> } %uaddc, 0 |
| 28 | + %carry_zext = zext <2 x i1> %carry to <2 x i32> |
| 29 | + %result = add <2 x i32> %sum, %carry_zext |
| 30 | + ret <2 x i32> %result |
| 31 | +} |
0 commit comments