inst-directive-other.s
1.85 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// 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