assembler-expressions.s
1.27 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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# RUN: not llvm-mc -triple x86_64-unknown-unknown %s 2>&1 | FileCheck %s --check-prefix=ASM-ERR
# RUN: llvm-mc -filetype=obj -triple x86_64-unknown-unknown %s | llvm-objdump -j .data -s - | FileCheck %s --check-prefix=OBJDATA
# RUN: llvm-mc -filetype=obj -triple x86_64-unknown-unknown %s | llvm-objdump -j .text -s - | FileCheck %s --check-prefix=OBJTEXT
.data
# OBJDATA: Contents of section .data
# OBJDATA-NEXT: 0000 aa0506ff
foo2:
# ASM-ERR: [[@LINE+1]]:5: error: expected absolute expression
.if . - foo2 == 0
.byte 0xaa
.else
.byte 0x00
.endif
foo3:
.byte 5
# ASM-ERR: [[@LINE+1]]:5: error: expected absolute expression
.if . - foo3 == 1
.byte 6
.else
.byte 7
.endif
.byte 0xff
# nop is a fixed size instruction so this should pass.
# OBJTEXT: Contents of section .text
# OBJTEXT-NEXT: 0000 909090ff 34250000 00009090 90785634
# OBJTEXT-NEXT: 0010 12785634 1290
.text
text1:
# ASM-ERR: [[@LINE+1]]:5: error: expected absolute expression
.if . - text1 == 0
nop
.endif
text2:
nop
# ASM-ERR: [[@LINE+1]]:5: error: expected absolute expression
.if . - text2 == 1
nop
.else
ret
.endif
push gs
nop
nop
nop
# No additional errors.
#
# ASM-ERR-NOT: {{[0-9]+}}:{{[0-9]+}}: error:
text3:
.long 0x12345678
text4:
.fill (text4-text3)/4, 4, 0x12345678
nop