aboutsummaryrefslogtreecommitdiffstats
path: root/test/MC
diff options
context:
space:
mode:
authorJack Carter <jack.carter@imgtec.com>2013-10-04 21:26:15 +0000
committerJack Carter <jack.carter@imgtec.com>2013-10-04 21:26:15 +0000
commit8e48edcf3dd7dea9fec58b05a6ace6fbd0260d7c (patch)
treeb5631843b607f2a9a0447dd870eed1f6095a8883 /test/MC
parent36ea408903e4acafcb90650d94c9aa8e7484c1f5 (diff)
downloadexternal_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')
-rw-r--r--test/MC/Mips/mips_directives.s7
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)