Skip to content

Commit e897bd0

Browse files
committed
Add scalarizer test for extractvalue bugfix
1 parent b340f93 commit e897bd0

File tree

1 file changed

+31
-0
lines changed

1 file changed

+31
-0
lines changed
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
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

Comments
 (0)