| target triple = "mipsisa32r6el-unknown-linux-gnu" |
| |
| ; RUN: llc -filetype=asm %s -o - | FileCheck %s --check-prefix=MIPSELR6 |
| ; Function Attrs: noinline nounwind optnone uwtable |
| define i1 @foo0() nounwind { |
| ; MIPSELR6: bnezc $1, $BB0_2 |
| ; MIPSELR6-NEXT: nop |
| ; MIPSELR6: jr $ra |
| entry: |
| %0 = icmp eq i32 0, 1 |
| br i1 %0, label %2, label %3 |
| ret i1 %0 |
| 2: |
| ret i1 %0 |
| 3: |
| ret i1 %0 |
| } |
| |
| define i32 @foo1() nounwind { |
| ; MIPSELR6: addiu $2, $2, 1 |
| ; MIPSELR6-NEXT: .set noreorder |
| ; MIPSELR6-NEXT: beqzc $2, $tmp0 |
| ; MIPSELR6-NEXT: nop |
| ; MIPSELR6-NEXT: .set reorder |
| ; MIPSELR6: jrc $ra |
| entry: |
| %0 = tail call i32 asm "1: addiu $0, $0, 1; beqzc $0, 1b", "=r"() nounwind |
| ret i32 %0 |
| } |
| |
| define i32 @foo2() nounwind { |
| ; MIPSELR6: .set push |
| ; MIPSELR6-NEXT: .set at |
| ; MIPSELR6-NEXT: .set macro |
| ; MIPSELR6-NEXT: .set reorder |
| ; MIPSELR6: .set noreorder |
| ; MIPSELR6-NEXT: beqzc $9, End |
| ; MIPSELR6-NEXT: nop |
| ; MIPSELR6-NEXT: .set reorder |
| ; MIPSELR6: addiu $9, $9, 1 |
| entry: |
| %0 = tail call i32 asm "beqzc $$t1, End", "=r"() nounwind |
| %1 = tail call i32 asm "addiu $$t1, $$t1, 1", "=r"() nounwind |
| %2 = add nsw i32 %1, %0 |
| ret i32 %2 |
| } |
| |
| define i32 @foo3() nounwind { |
| ; MIPSELR6: addiu $2, $2, 1 |
| ; MIPSELR6-NEXT: .set noreorder |
| ; MIPSELR6-NEXT: beqzc $2, $tmp1 |
| ; MIPSELR6-NEXT: nop |
| ; MIPSELR6-NEXT: .set noreorder |
| ; MIPSELR6-NEXT: j End |
| ; MIPSELR6-NEXT: nop |
| ; MIPSELR6-NEXT: .set reorder |
| entry: |
| %0 = tail call i32 asm "1: addiu $0, $0, 1; beqzc $0, 1b; j End", "=r"() nounwind |
| ret i32 %0 |
| } |
| |
| define i32 @foo4() nounwind { |
| ; MIPSELR6: addiu $2, $2, 1 |
| ; MIPSELR6-NEXT: .set noreorder |
| ; MIPSELR6-NEXT: beqzc $2, $tmp2 |
| ; MIPSELR6-NEXT: addiu $2, $2, 1 |
| ; MIPSELR6-NEXT: .set reorder |
| entry: |
| %0 = tail call i32 asm "1: addiu $0, $0, 1; beqzc $0, 1b; addiu $0, $0, 1", "=r"() nounwind |
| ret i32 %0 |
| } |