[MC] Change AsmParser to leverage Assembler during evaluation
Teach AsmParser to check with Assembler for when evaluating constant
expressions. This improves the handing of preprocessor expressions
that must be resolved at parse time. This idiom can be found as
assembling-time assertion checks in source-level assemblers. Note that
this relies on the MCStreamer to keep sufficient tabs on Section /
Fragment information which the MCAsmStreamer does not. As a result the
textual output may fail where the equivalent object generation would
pass. This can most easily be resolved by folding the MCAsmStreamer
and MCObjectStreamer together which is planned for in a separate
patch.
Currently, this feature is only enabled for assembly input, keeping IR
compilation consistent between assembly and object generation.
Reviewers: echristo, rnk, probinson, espindola, peter.smith
Reviewed By: peter.smith
Subscribers: eraman, peter.smith, arichardson, jyknight, hiraditya, llvm-commits
Differential Revision: https://reviews.llvm.org/D45164
llvm-svn: 331218
2018-05-01 03:22:40 +08:00
|
|
|
# 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
|
2018-05-19 01:45:48 +08:00
|
|
|
# OBJTEXT-NEXT: 0000 9090ff34 25000000 00909090 78563412
|
|
|
|
# OBJTEXT-NEXT: 0010 78563412 90
|
[MC] Change AsmParser to leverage Assembler during evaluation
Teach AsmParser to check with Assembler for when evaluating constant
expressions. This improves the handing of preprocessor expressions
that must be resolved at parse time. This idiom can be found as
assembling-time assertion checks in source-level assemblers. Note that
this relies on the MCStreamer to keep sufficient tabs on Section /
Fragment information which the MCAsmStreamer does not. As a result the
textual output may fail where the equivalent object generation would
pass. This can most easily be resolved by folding the MCAsmStreamer
and MCObjectStreamer together which is planned for in a separate
patch.
Currently, this feature is only enabled for assembly input, keeping IR
compilation consistent between assembly and object generation.
Reviewers: echristo, rnk, probinson, espindola, peter.smith
Reviewed By: peter.smith
Subscribers: eraman, peter.smith, arichardson, jyknight, hiraditya, llvm-commits
Differential Revision: https://reviews.llvm.org/D45164
llvm-svn: 331218
2018-05-01 03:22:40 +08:00
|
|
|
|
|
|
|
.text
|
|
|
|
|
|
|
|
text1:
|
|
|
|
nop
|
|
|
|
# ASM-ERR: [[@LINE+1]]:5: error: expected absolute expression
|
|
|
|
.if . - text1 == 1
|
|
|
|
nop
|
|
|
|
.else
|
|
|
|
ret
|
|
|
|
.endif
|
|
|
|
push gs
|
2018-05-19 01:45:48 +08:00
|
|
|
nop
|
|
|
|
nop
|
|
|
|
nop
|
[MC] Change AsmParser to leverage Assembler during evaluation
Teach AsmParser to check with Assembler for when evaluating constant
expressions. This improves the handing of preprocessor expressions
that must be resolved at parse time. This idiom can be found as
assembling-time assertion checks in source-level assemblers. Note that
this relies on the MCStreamer to keep sufficient tabs on Section /
Fragment information which the MCAsmStreamer does not. As a result the
textual output may fail where the equivalent object generation would
pass. This can most easily be resolved by folding the MCAsmStreamer
and MCObjectStreamer together which is planned for in a separate
patch.
Currently, this feature is only enabled for assembly input, keeping IR
compilation consistent between assembly and object generation.
Reviewers: echristo, rnk, probinson, espindola, peter.smith
Reviewed By: peter.smith
Subscribers: eraman, peter.smith, arichardson, jyknight, hiraditya, llvm-commits
Differential Revision: https://reviews.llvm.org/D45164
llvm-svn: 331218
2018-05-01 03:22:40 +08:00
|
|
|
# No additional errors.
|
|
|
|
#
|
|
|
|
# ASM-ERR-NOT: {{[0-9]+}}:{{[0-9]+}}: error:
|
2018-05-19 01:45:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
text2:
|
|
|
|
.long 0x12345678
|
|
|
|
text3:
|
|
|
|
.fill (text3-text2)/4, 4, 0x12345678
|
|
|
|
nop
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|