summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/CodeGen/PowerPC/combine-sext-and-shl-after-isel.ll134
1 files changed, 130 insertions, 4 deletions
diff --git a/llvm/test/CodeGen/PowerPC/combine-sext-and-shl-after-isel.ll b/llvm/test/CodeGen/PowerPC/combine-sext-and-shl-after-isel.ll
index 1e6648928b9..b559ff6d52c 100644
--- a/llvm/test/CodeGen/PowerPC/combine-sext-and-shl-after-isel.ll
+++ b/llvm/test/CodeGen/PowerPC/combine-sext-and-shl-after-isel.ll
@@ -42,8 +42,7 @@ define dso_local i32 @poc(i32* %base, i32 %index, i1 %flag, i32 %default) {
; CHECK-P9-NEXT: andi. r5, r5, 1
; CHECK-P9-NEXT: bc 4, gt, .LBB0_2
; CHECK-P9-NEXT: # %bb.1: # %true
-; CHECK-P9-NEXT: extsw r4, r4
-; CHECK-P9-NEXT: sldi r4, r4, 2
+; CHECK-P9-NEXT: extswsli r4, r4, 2
; CHECK-P9-NEXT: lwzx r3, r3, r4
; CHECK-P9-NEXT: blr
; CHECK-P9-NEXT: .LBB0_2: # %false
@@ -55,8 +54,7 @@ define dso_local i32 @poc(i32* %base, i32 %index, i1 %flag, i32 %default) {
; CHECK-P9-BE-NEXT: andi. r5, r5, 1
; CHECK-P9-BE-NEXT: bc 4, gt, .LBB0_2
; CHECK-P9-BE-NEXT: # %bb.1: # %true
-; CHECK-P9-BE-NEXT: extsw r4, r4
-; CHECK-P9-BE-NEXT: sldi r4, r4, 2
+; CHECK-P9-BE-NEXT: extswsli r4, r4, 2
; CHECK-P9-BE-NEXT: lwzx r3, r3, r4
; CHECK-P9-BE-NEXT: blr
; CHECK-P9-BE-NEXT: .LBB0_2: # %false
@@ -74,3 +72,131 @@ true:
false:
ret i32 %default
}
+
+define dso_local i64 @poc_i64(i64* %base, i32 %index, i1 %flag, i64 %default) {
+; CHECK-LABEL: poc_i64:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: andi. r5, r5, 1
+; CHECK-NEXT: bc 4, gt, .LBB1_2
+; CHECK-NEXT: # %bb.1: # %true
+; CHECK-NEXT: extsw r4, r4
+; CHECK-NEXT: sldi r4, r4, 3
+; CHECK-NEXT: ldx r3, r3, r4
+; CHECK-NEXT: blr
+; CHECK-NEXT: .LBB1_2: # %false
+; CHECK-NEXT: mr r3, r6
+; CHECK-NEXT: blr
+;
+; CHECK-BE-LABEL: poc_i64:
+; CHECK-BE: # %bb.0: # %entry
+; CHECK-BE-NEXT: andi. r5, r5, 1
+; CHECK-BE-NEXT: bc 4, gt, .LBB1_2
+; CHECK-BE-NEXT: # %bb.1: # %true
+; CHECK-BE-NEXT: extsw r4, r4
+; CHECK-BE-NEXT: sldi r4, r4, 3
+; CHECK-BE-NEXT: ldx r3, r3, r4
+; CHECK-BE-NEXT: blr
+; CHECK-BE-NEXT: .LBB1_2: # %false
+; CHECK-BE-NEXT: mr r3, r6
+; CHECK-BE-NEXT: blr
+;
+; CHECK-P9-LABEL: poc_i64:
+; CHECK-P9: # %bb.0: # %entry
+; CHECK-P9-NEXT: andi. r5, r5, 1
+; CHECK-P9-NEXT: bc 4, gt, .LBB1_2
+; CHECK-P9-NEXT: # %bb.1: # %true
+; CHECK-P9-NEXT: extswsli r4, r4, 3
+; CHECK-P9-NEXT: ldx r3, r3, r4
+; CHECK-P9-NEXT: blr
+; CHECK-P9-NEXT: .LBB1_2: # %false
+; CHECK-P9-NEXT: mr r3, r6
+; CHECK-P9-NEXT: blr
+;
+; CHECK-P9-BE-LABEL: poc_i64:
+; CHECK-P9-BE: # %bb.0: # %entry
+; CHECK-P9-BE-NEXT: andi. r5, r5, 1
+; CHECK-P9-BE-NEXT: bc 4, gt, .LBB1_2
+; CHECK-P9-BE-NEXT: # %bb.1: # %true
+; CHECK-P9-BE-NEXT: extswsli r4, r4, 3
+; CHECK-P9-BE-NEXT: ldx r3, r3, r4
+; CHECK-P9-BE-NEXT: blr
+; CHECK-P9-BE-NEXT: .LBB1_2: # %false
+; CHECK-P9-BE-NEXT: mr r3, r6
+; CHECK-P9-BE-NEXT: blr
+entry:
+ %iconv = sext i32 %index to i64
+ br i1 %flag, label %true, label %false
+
+true:
+ %ptr = getelementptr inbounds i64, i64* %base, i64 %iconv
+ %value = load i64, i64* %ptr, align 8
+ ret i64 %value
+
+false:
+ ret i64 %default
+}
+
+define dso_local i64 @no_extswsli(i64* %base, i32 %index, i1 %flag) {
+; CHECK-LABEL: no_extswsli:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: andi. r5, r5, 1
+; CHECK-NEXT: extsw r4, r4
+; CHECK-NEXT: bc 4, gt, .LBB2_2
+; CHECK-NEXT: # %bb.1: # %true
+; CHECK-NEXT: sldi r4, r4, 3
+; CHECK-NEXT: ldx r3, r3, r4
+; CHECK-NEXT: blr
+; CHECK-NEXT: .LBB2_2: # %false
+; CHECK-NEXT: mr r3, r4
+; CHECK-NEXT: blr
+;
+; CHECK-BE-LABEL: no_extswsli:
+; CHECK-BE: # %bb.0: # %entry
+; CHECK-BE-NEXT: andi. r5, r5, 1
+; CHECK-BE-NEXT: extsw r4, r4
+; CHECK-BE-NEXT: bc 4, gt, .LBB2_2
+; CHECK-BE-NEXT: # %bb.1: # %true
+; CHECK-BE-NEXT: sldi r4, r4, 3
+; CHECK-BE-NEXT: ldx r3, r3, r4
+; CHECK-BE-NEXT: blr
+; CHECK-BE-NEXT: .LBB2_2: # %false
+; CHECK-BE-NEXT: mr r3, r4
+; CHECK-BE-NEXT: blr
+;
+; CHECK-P9-LABEL: no_extswsli:
+; CHECK-P9: # %bb.0: # %entry
+; CHECK-P9-NEXT: extsw r4, r4
+; CHECK-P9-NEXT: andi. r5, r5, 1
+; CHECK-P9-NEXT: bc 4, gt, .LBB2_2
+; CHECK-P9-NEXT: # %bb.1: # %true
+; CHECK-P9-NEXT: sldi r4, r4, 3
+; CHECK-P9-NEXT: ldx r3, r3, r4
+; CHECK-P9-NEXT: blr
+; CHECK-P9-NEXT: .LBB2_2: # %false
+; CHECK-P9-NEXT: mr r3, r4
+; CHECK-P9-NEXT: blr
+;
+; CHECK-P9-BE-LABEL: no_extswsli:
+; CHECK-P9-BE: # %bb.0: # %entry
+; CHECK-P9-BE-NEXT: extsw r4, r4
+; CHECK-P9-BE-NEXT: andi. r5, r5, 1
+; CHECK-P9-BE-NEXT: bc 4, gt, .LBB2_2
+; CHECK-P9-BE-NEXT: # %bb.1: # %true
+; CHECK-P9-BE-NEXT: sldi r4, r4, 3
+; CHECK-P9-BE-NEXT: ldx r3, r3, r4
+; CHECK-P9-BE-NEXT: blr
+; CHECK-P9-BE-NEXT: .LBB2_2: # %false
+; CHECK-P9-BE-NEXT: mr r3, r4
+; CHECK-P9-BE-NEXT: blr
+entry:
+ %iconv = sext i32 %index to i64
+ br i1 %flag, label %true, label %false
+
+true:
+ %ptr = getelementptr inbounds i64, i64* %base, i64 %iconv
+ %value = load i64, i64* %ptr, align 8
+ ret i64 %value
+
+false:
+ ret i64 %iconv
+}
OpenPOWER on IntegriCloud