diff options
author | Jack Carter <jack.carter@imgtec.com> | 2013-10-04 21:26:15 +0000 |
---|---|---|
committer | Jack Carter <jack.carter@imgtec.com> | 2013-10-04 21:26:15 +0000 |
commit | 8e48edcf3dd7dea9fec58b05a6ace6fbd0260d7c (patch) | |
tree | b5631843b607f2a9a0447dd870eed1f6095a8883 /test/MC/Mips | |
parent | 36ea408903e4acafcb90650d94c9aa8e7484c1f5 (diff) | |
download | external_llvm-8e48edcf3dd7dea9fec58b05a6ace6fbd0260d7c.zip external_llvm-8e48edcf3dd7dea9fec58b05a6ace6fbd0260d7c.tar.gz external_llvm-8e48edcf3dd7dea9fec58b05a6ace6fbd0260d7c.tar.bz2 |
[MC][AsmParser] Hook for post assembly file processing
This patch handles LLVM standalone assembler (llvm-mc) ELF flag setting based on input file
directive processing.
Mips assembly requires processing inline directives that directly and
indirectly affect the output ELF header flags. This patch handles one
".abicalls".
To process these directives we are following the model the code generator
uses by storing state in a container as we go through processing and when
we detect the end of input file processing, AsmParser is notified and we
update the ELF header flags through a MipsELFStreamer method with a call from
MCTargetAsmParser::emitEndOfAsmFile(MCStreamer &OutStreamer).
This patch will allow other targets the same functionality.
Jack
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@191982 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/MC/Mips')
-rw-r--r-- | test/MC/Mips/mips_directives.s | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/test/MC/Mips/mips_directives.s b/test/MC/Mips/mips_directives.s index bbb2616..b1f8182 100644 --- a/test/MC/Mips/mips_directives.s +++ b/test/MC/Mips/mips_directives.s @@ -1,9 +1,12 @@ # RUN: llvm-mc -show-encoding -triple mips-unknown-unknown %s | FileCheck %s +# RUN: llvm-mc -filetype=obj -triple mips-unknown-unknown %s | \ +# RUN: llvm-readobj -h | FileCheck -check-prefix=CHECK-ELF %s # # CHECK: .text # CHECK: $BB0_2: $BB0_2: - .ent directives_test + .ent directives_test + .abicalls .frame $sp,0,$ra .mask 0x00000000,0 .fmask 0x00000000,0 @@ -43,3 +46,5 @@ $JTI0_0: # CHECK: and $3, $15, $15 # encoding: [0x01,0xef,0x18,0x24] abs.s f6,FPU_MASK and r3,$t7,STORE_MASK + +# CHECK-ELF: Flags [ (0x6) |