|
1 | 1 | ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 |
2 | 2 | ; RUN: opt -S -passes=instcombine < %s | FileCheck %s |
3 | 3 |
|
4 | | -define i8 @pr142518(ptr %p, i8 %x, i1 %c) { |
| 4 | +define i8 @pr142518(ptr %p, i8 %x, i1 %c) "instcombine-no-verify-fixpoint" { |
5 | 5 | ; CHECK-LABEL: define i8 @pr142518( |
6 | | -; CHECK-SAME: ptr [[P:%.*]], i8 [[X:%.*]], i1 [[C:%.*]]) { |
| 6 | +; CHECK-SAME: ptr [[P:%.*]], i8 [[X:%.*]], i1 [[C:%.*]]) #[[ATTR0:[0-9]+]] { |
7 | 7 | ; CHECK-NEXT: [[ENTRY:.*:]] |
8 | | -; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[X]], -2 |
| 8 | +; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i8 [[X]], -1 |
9 | 9 | ; CHECK-NEXT: br label %[[LOOP:.*]] |
10 | 10 | ; CHECK: [[LOOP]]: |
| 11 | +; CHECK-NEXT: [[NOT1:%.*]] = xor i1 [[CMP1]], true |
| 12 | +; CHECK-NEXT: [[OR:%.*]] = or i1 [[CMP1]], [[NOT1]] |
| 13 | +; CHECK-NEXT: [[CMP:%.*]] = xor i1 [[OR]], true |
11 | 14 | ; CHECK-NEXT: [[EXT2:%.*]] = zext i1 [[CMP]] to i8 |
12 | 15 | ; CHECK-NEXT: store i8 [[EXT2]], ptr [[P]], align 1 |
13 | 16 | ; CHECK-NEXT: br i1 false, label %[[LOOP]], label %[[EXIT:.*]] |
14 | 17 | ; CHECK: [[EXIT]]: |
15 | | -; CHECK-NEXT: [[EXT3:%.*]] = zext i1 [[CMP]] to i8 |
| 18 | +; CHECK-NEXT: [[NOT3:%.*]] = xor i1 [[OR]], true |
| 19 | +; CHECK-NEXT: [[EXT3:%.*]] = zext i1 [[NOT3]] to i8 |
16 | 20 | ; CHECK-NEXT: ret i8 [[EXT3]] |
17 | 21 | ; |
18 | 22 | entry: |
|
0 commit comments