1 ; RUN: llc < %s -mtriple=armv7-apple-darwin | FileCheck %s
3 ; Make sure that we merge the consecutive load/store sequence below and use a
4 ; word (16 bit) instead of a byte copy.
5 ; CHECK: MergeLoadStoreBaseIndexOffset
6 ; CHECK: ldrh [[REG:r[0-9]+]], [{{.*}}]
7 ; CHECK: strh [[REG]], [r1], #2
8 define void @MergeLoadStoreBaseIndexOffset(ptr %a, ptr %b, ptr %c, i32 %n) {
12 %.09 = phi i32 [ %n, %0 ], [ %11, %1 ]
13 %.08 = phi ptr [ %b, %0 ], [ %10, %1 ]
14 %.0 = phi ptr [ %a, %0 ], [ %2, %1 ]
15 %2 = getelementptr inbounds i32, ptr %.0, i32 1
16 %3 = load i32, ptr %.0, align 1
17 %4 = getelementptr inbounds i8, ptr %c, i32 %3
18 %5 = load i8, ptr %4, align 1
20 %7 = getelementptr inbounds i8, ptr %c, i32 %6
21 %8 = load i8, ptr %7, align 1
22 store i8 %5, ptr %.08, align 1
23 %9 = getelementptr inbounds i8, ptr %.08, i32 1
24 store i8 %8, ptr %9, align 1
25 %10 = getelementptr inbounds i8, ptr %.08, i32 2
26 %11 = add nsw i32 %.09, -1
27 %12 = icmp eq i32 %11, 0
28 br i1 %12, label %13, label %1
34 ; Make sure that we merge the consecutive load/store sequence below and use a
35 ; word (16 bit) instead of a byte copy even if there are intermediate sign
37 ; CHECK: MergeLoadStoreBaseIndexOffsetSext
38 ; CHECK: ldrh [[REG:r[0-9]+]], [{{.*}}]
39 ; CHECK: strh [[REG]], [r1], #2
40 define void @MergeLoadStoreBaseIndexOffsetSext(ptr %a, ptr %b, ptr %c, i32 %n) {
44 %.09 = phi i32 [ %n, %0 ], [ %12, %1 ]
45 %.08 = phi ptr [ %b, %0 ], [ %11, %1 ]
46 %.0 = phi ptr [ %a, %0 ], [ %2, %1 ]
47 %2 = getelementptr inbounds i8, ptr %.0, i32 1
48 %3 = load i8, ptr %.0, align 1
49 %4 = sext i8 %3 to i32
50 %5 = getelementptr inbounds i8, ptr %c, i32 %4
51 %6 = load i8, ptr %5, align 1
53 %8 = getelementptr inbounds i8, ptr %c, i32 %7
54 %9 = load i8, ptr %8, align 1
55 store i8 %6, ptr %.08, align 1
56 %10 = getelementptr inbounds i8, ptr %.08, i32 1
57 store i8 %9, ptr %10, align 1
58 %11 = getelementptr inbounds i8, ptr %.08, i32 2
59 %12 = add nsw i32 %.09, -1
60 %13 = icmp eq i32 %12, 0
61 br i1 %13, label %14, label %1
67 ; However, we can only merge ignore sign extensions when they are on all memory
69 ; CHECK: loadStoreBaseIndexOffsetSextNoSex
70 ; CHECK-NOT: ldrh [[REG:r[0-9]+]], [{{.*}}]
71 ; CHECK-NOT: strh [[REG]], [r1], #2
72 define void @loadStoreBaseIndexOffsetSextNoSex(ptr %a, ptr %b, ptr %c, i32 %n) {
76 %.09 = phi i32 [ %n, %0 ], [ %12, %1 ]
77 %.08 = phi ptr [ %b, %0 ], [ %11, %1 ]
78 %.0 = phi ptr [ %a, %0 ], [ %2, %1 ]
79 %2 = getelementptr inbounds i8, ptr %.0, i32 1
80 %3 = load i8, ptr %.0, align 1
81 %4 = sext i8 %3 to i32
82 %5 = getelementptr inbounds i8, ptr %c, i32 %4
83 %6 = load i8, ptr %5, align 1
85 %wrap.4 = sext i8 %7 to i32
86 %8 = getelementptr inbounds i8, ptr %c, i32 %wrap.4
87 %9 = load i8, ptr %8, align 1
88 store i8 %6, ptr %.08, align 1
89 %10 = getelementptr inbounds i8, ptr %.08, i32 1
90 store i8 %9, ptr %10, align 1
91 %11 = getelementptr inbounds i8, ptr %.08, i32 2
92 %12 = add nsw i32 %.09, -1
93 %13 = icmp eq i32 %12, 0
94 br i1 %13, label %14, label %1