| // RUN: llvm-mc %s -triple=arm64-apple-darwin -filetype=asm -o - \ |
| // RUN: | FileCheck %s --check-prefix=CHECK-ASM |
| // RUN: llvm-mc %s -triple=arm64-apple-darwin -filetype=obj -o - \ |
| // RUN: | llvm-objdump -d - | FileCheck %s --check-prefixes=CHECK-OBJ,CHECK-OBJ-CODE |
| // RUN: llvm-mc %s -triple=aarch64-win32-gnu -filetype=asm -o - \ |
| // RUN: | FileCheck %s --check-prefix=CHECK-ASM |
| // RUN: llvm-mc %s -triple=aarch64-win32-gnu -filetype=obj -o - \ |
| // RUN: | llvm-objdump -d - | FileCheck %s --check-prefixes=CHECK-OBJ,CHECK-OBJ-CODE |
| // RUN: llvm-mc %s -triple=aarch64-linux-gnu -filetype=asm -o - \ |
| // RUN: | FileCheck %s --check-prefix=CHECK-ASM |
| // RUN: llvm-mc %s -triple=aarch64-linux-gnu -filetype=obj -o - \ |
| // RUN: | llvm-objdump -d - | FileCheck %s --check-prefixes=CHECK-OBJ,CHECK-OBJ-DATA |
| // RUN: llvm-mc %s -triple=aarch64_be-linux-gnu -filetype=asm -o - \ |
| // RUN: | FileCheck %s --check-prefix=CHECK-ASM |
| // RUN: llvm-mc %s -triple=aarch64_be-linux-gnu -filetype=obj -o - \ |
| // RUN: | llvm-objdump -d - | FileCheck %s --check-prefixes=CHECK-OBJ,CHECK-OBJ-BE |
| |
| .text |
| |
| .p2align 2 |
| .globl _func |
| _func: |
| nop |
| // A .long is stored differently for big endian aarch64 targets, while |
| // instructions always are stored in little endian. |
| // ELF distinguishes between data and code when emitted this way, but |
| // MachO and COFF don't. |
| .long 0xd503201f |
| .inst 0xd503201f |
| |
| // CHECK-ASM: .p2align 2 |
| // CHECK-ASM: .globl _func |
| // CHECK-ASM: _func: |
| // CHECK-ASM: nop |
| // CHECK-ASM: .{{long|word}} 3573751839 |
| // CHECK-ASM: .inst 0xd503201f |
| |
| // CHECK-OBJ: 0: 1f 20 03 d5 nop |
| // CHECK-OBJ-CODE: 4: 1f 20 03 d5 nop |
| // CHECK-OBJ-DATA: 4: 1f 20 03 d5 .word 0xd503201f |
| // CHECK-OBJ-BE: 4: d5 03 20 1f .word 0xd503201f |
| // CHECK-OBJ: 8: 1f 20 03 d5 nop |