| ; Test branching instructions. |
| ; TODO(kschimpf): Get this working. |
| |
| ; REQUIRES: allow_dump |
| |
| ; Compile using standalone assembler. |
| ; RUN: %p2i --filetype=asm -i %s --target=arm32 --args -Om1 \ |
| ; RUN: | FileCheck %s --check-prefix=ASM |
| |
| ; Show bytes in assembled standalone code. |
| ; RUN: %p2i --filetype=asm -i %s --target=arm32 --assemble --disassemble \ |
| ; RUN: --args -Om1 | FileCheck %s --check-prefix=DIS |
| |
| ; Compile using integrated assembler. |
| ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --args -Om1 \ |
| ; RUN: | FileCheck %s --check-prefix=IASM |
| |
| ; Show bytes in assembled integrated code. |
| ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --assemble --disassemble \ |
| ; RUN: --args -Om1 | FileCheck %s --check-prefix=DIS |
| |
| define internal void @simple_uncond_branch() { |
| ; DIS-LABEL: 00000000 <simple_uncond_branch>: |
| ; ASM-LABEL: simple_uncond_branch: |
| ; IASM-LABEL:simple_uncond_branch: |
| |
| ; ASM-NEXT: .Lsimple_uncond_branch$__0: |
| ; IASM-NEXT: .Lsimple_uncond_branch$__0: |
| |
| br label %l2 |
| ; ASM-NEXT: b .Lsimple_uncond_branch$l2 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0xea |
| ; DIS-NEXT: 0: ea000000 |
| |
| l1: |
| ; ASM-NEXT: .Lsimple_uncond_branch$l1: |
| ; IASM-NEXT: .Lsimple_uncond_branch$l1: |
| |
| br label %l3 |
| ; ASM-NEXT: b .Lsimple_uncond_branch$l3 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0x0 |
| ; IASM-NEXT: .byte 0xea |
| ; DIS-NEXT: 4: ea000000 |
| |
| l2: |
| ; ASM-NEXT: .Lsimple_uncond_branch$l2: |
| ; IASM-NEXT: .Lsimple_uncond_branch$l2: |
| |
| br label %l1 |
| ; ASM-NEXT: b .Lsimple_uncond_branch$l1 |
| ; IASM-NEXT: .byte 0xfd |
| ; IASM-NEXT: .byte 0xff |
| ; IASM-NEXT: .byte 0xff |
| ; IASM-NEXT: .byte 0xea |
| ; DIS-NEXT: 8: eafffffd |
| |
| l3: |
| ; ASM-NEXT: .Lsimple_uncond_branch$l3: |
| ; IASM-NEXT: .Lsimple_uncond_branch$l3: |
| |
| ret void |
| ; ASM-NEXT: bx lr |
| ; IASM-NEXT: .byte 0x1e |
| ; IASM-NEXT: .byte 0xff |
| ; IASM-NEXT: .byte 0x2f |
| ; IASM-NEXT: .byte 0xe1 |
| ; DIS-NEXT: c: e12fff1e |
| |
| } |