|
1 |
| -; RUN: opt -passes='simplifycfg<sink-common-insts;hoist-common-insts>,verify' -disable-output %s |
2 |
| - |
3 |
| -; XFAIL: * |
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2 |
| 2 | +; RUN: opt -passes='simplifycfg<sink-common-insts;hoist-common-insts>,verify' -S %s | FileCheck %s |
4 | 3 |
|
5 | 4 | declare void @clobber1()
|
6 | 5 | declare void @clobber2()
|
7 | 6 |
|
8 |
| -; FIXME: currently simplifycfg tries to sink the stores to the exit block and |
9 |
| -; introduces a select for the pointer operand. This is not allowed for |
10 |
| -; swifterror pointers. |
11 |
| -define swiftcc void @sink_store(ptr %arg, ptr swifterror %arg1, i1 %c) { |
| 7 | +; Do not try to sink the stores to the exit block, as this requires introducing |
| 8 | +; a select for the pointer operand. This is not allowed for swifterror pointers. |
| 9 | +define swiftcc void @sink(ptr %arg, ptr swifterror %arg1, i1 %c) { |
| 10 | +; CHECK-LABEL: define swiftcc void @sink |
| 11 | +; CHECK-SAME: (ptr [[ARG:%.*]], ptr swifterror [[ARG1:%.*]], i1 [[C:%.*]]) { |
| 12 | +; CHECK-NEXT: bb: |
| 13 | +; CHECK-NEXT: br i1 [[C]], label [[THEN:%.*]], label [[ELSE:%.*]] |
| 14 | +; CHECK: then: |
| 15 | +; CHECK-NEXT: call void @clobber1() |
| 16 | +; CHECK-NEXT: store ptr null, ptr [[ARG]], align 8 |
| 17 | +; CHECK-NEXT: br label [[EXIT:%.*]] |
| 18 | +; CHECK: else: |
| 19 | +; CHECK-NEXT: call void @clobber2() |
| 20 | +; CHECK-NEXT: store ptr null, ptr [[ARG1]], align 8 |
| 21 | +; CHECK-NEXT: br label [[EXIT]] |
| 22 | +; CHECK: exit: |
| 23 | +; CHECK-NEXT: ret void |
| 24 | +; |
12 | 25 | bb:
|
13 | 26 | br i1 %c, label %then, label %else
|
14 | 27 |
|
|
27 | 40 | }
|
28 | 41 |
|
29 | 42 | define swiftcc void @hoist_store(ptr %arg, ptr swifterror %arg1, i1 %c) {
|
| 43 | +; CHECK-LABEL: define swiftcc void @hoist_store |
| 44 | +; CHECK-SAME: (ptr [[ARG:%.*]], ptr swifterror [[ARG1:%.*]], i1 [[C:%.*]]) { |
| 45 | +; CHECK-NEXT: bb: |
| 46 | +; CHECK-NEXT: br i1 [[C]], label [[THEN:%.*]], label [[ELSE:%.*]] |
| 47 | +; CHECK: then: |
| 48 | +; CHECK-NEXT: store ptr null, ptr [[ARG]], align 8 |
| 49 | +; CHECK-NEXT: call void @clobber1() |
| 50 | +; CHECK-NEXT: br label [[EXIT:%.*]] |
| 51 | +; CHECK: else: |
| 52 | +; CHECK-NEXT: store ptr null, ptr [[ARG1]], align 8 |
| 53 | +; CHECK-NEXT: call void @clobber2() |
| 54 | +; CHECK-NEXT: br label [[EXIT]] |
| 55 | +; CHECK: exit: |
| 56 | +; CHECK-NEXT: ret void |
| 57 | +; |
30 | 58 | bb:
|
31 | 59 | br i1 %c, label %then, label %else
|
32 | 60 |
|
|
66 | 94 | ret ptr %p
|
67 | 95 | }
|
68 | 96 | define swiftcc ptr @hoist_load(ptr %arg, ptr swifterror %arg1, i1 %c) {
|
| 97 | +; CHECK-LABEL: define swiftcc ptr @hoist_load |
| 98 | +; CHECK-SAME: (ptr [[ARG:%.*]], ptr swifterror [[ARG1:%.*]], i1 [[C:%.*]]) { |
| 99 | +; CHECK-NEXT: bb: |
| 100 | +; CHECK-NEXT: br i1 [[C]], label [[THEN:%.*]], label [[ELSE:%.*]] |
| 101 | +; CHECK: then: |
| 102 | +; CHECK-NEXT: [[L1:%.*]] = load ptr, ptr [[ARG]], align 8 |
| 103 | +; CHECK-NEXT: call void @clobber1() |
| 104 | +; CHECK-NEXT: br label [[EXIT:%.*]] |
| 105 | +; CHECK: else: |
| 106 | +; CHECK-NEXT: [[L2:%.*]] = load ptr, ptr [[ARG1]], align 8 |
| 107 | +; CHECK-NEXT: call void @clobber2() |
| 108 | +; CHECK-NEXT: br label [[EXIT]] |
| 109 | +; CHECK: exit: |
| 110 | +; CHECK-NEXT: [[P:%.*]] = phi ptr [ [[L1]], [[THEN]] ], [ [[L2]], [[ELSE]] ] |
| 111 | +; CHECK-NEXT: ret ptr [[P]] |
| 112 | +; |
69 | 113 | bb:
|
70 | 114 | br i1 %c, label %then, label %else
|
71 | 115 |
|
|
0 commit comments