Ehsan Amiri | a538b0f | 2016-08-03 18:17:35 +0000 | [diff] [blame] | 1 | ; RUN: llc -verify-machineinstrs -mcpu=ppc64 < %s | FileCheck %s |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 2 | target datalayout = "E-m:e-i64:64-n32:64" |
| 3 | target triple = "powerpc64-unknown-linux-gnu" |
| 4 | |
| 5 | ; Function Attrs: noreturn nounwind |
| 6 | define signext i32 @_Z1fRPc(i8** nocapture dereferenceable(8) %p) #0 { |
| 7 | entry: |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 8 | %.pre = load i8*, i8** %p, align 8 |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 9 | br label %loop |
| 10 | |
| 11 | loop: ; preds = %loop.backedge, %entry |
| 12 | %0 = phi i8* [ %.pre, %entry ], [ %.be, %loop.backedge ] |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 13 | %1 = load i8, i8* %0, align 1 |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 14 | %tobool = icmp eq i8 %1, 0 |
David Blaikie | 79e6c74 | 2015-02-27 19:29:02 +0000 | [diff] [blame] | 15 | %incdec.ptr = getelementptr inbounds i8, i8* %0, i64 1 |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 16 | store i8* %incdec.ptr, i8** %p, align 8 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 17 | %2 = load i8, i8* %incdec.ptr, align 1 |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 18 | %tobool2 = icmp ne i8 %2, 0 |
| 19 | %or.cond = and i1 %tobool, %tobool2 |
| 20 | br i1 %or.cond, label %if.then3, label %loop.backedge |
| 21 | |
| 22 | if.then3: ; preds = %loop |
David Blaikie | 79e6c74 | 2015-02-27 19:29:02 +0000 | [diff] [blame] | 23 | %incdec.ptr4 = getelementptr inbounds i8, i8* %0, i64 2 |
Hal Finkel | 5d5d153 | 2015-01-10 08:21:59 +0000 | [diff] [blame] | 24 | store i8* %incdec.ptr4, i8** %p, align 8 |
| 25 | br label %loop.backedge |
| 26 | |
| 27 | loop.backedge: ; preds = %if.then3, %loop |
| 28 | %.be = phi i8* [ %incdec.ptr4, %if.then3 ], [ %incdec.ptr, %loop ] |
| 29 | br label %loop |
| 30 | |
| 31 | ; CHECK-LABEL: @_Z1fRPc |
| 32 | ; CHECK-NOT: rlwinm {{[0-9]+}}, {{[0-9]+}}, 0, 24, 31 |
| 33 | ; CHECK-NOT: clrlwi {{[0-9]+}}, {{[0-9]+}}, 24 |
| 34 | } |
| 35 | |
| 36 | attributes #0 = { noreturn nounwind } |
| 37 | |