mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-27 17:31:33 +00:00
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
46 lines
1.4 KiB
C++
46 lines
1.4 KiB
C++
//=== MipsELFStreamer.h - MipsELFStreamer ------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENCE.TXT for details.
|
|
//
|
|
//===-------------------------------------------------------------------===//
|
|
#ifndef MIPSELFSTREAMER_H_
|
|
#define MIPSELFSTREAMER_H_
|
|
|
|
#include "llvm/MC/MCELFStreamer.h"
|
|
|
|
namespace llvm {
|
|
class MipsAsmPrinter;
|
|
class MipsMCAsmFlags;
|
|
class MipsSubtarget;
|
|
class MCSymbol;
|
|
|
|
class MipsELFStreamer : public MCELFStreamer {
|
|
public:
|
|
MipsELFStreamer(MCContext &Context, MCAsmBackend &TAB,
|
|
raw_ostream &OS, MCCodeEmitter *Emitter,
|
|
bool RelaxAll, bool NoExecStack)
|
|
: MCELFStreamer(SK_MipsELFStreamer, Context, TAB, OS, Emitter) {
|
|
}
|
|
|
|
~MipsELFStreamer() {}
|
|
void emitELFHeaderFlagsCG(const MipsSubtarget &Subtarget);
|
|
void emitELFHeaderFlagsAsm(const MipsMCAsmFlags &MAFlags);
|
|
void emitMipsSTOCG(const MipsSubtarget &Subtarget,
|
|
MCSymbol *Sym,
|
|
unsigned Val);
|
|
|
|
static bool classof(const MCStreamer *S) {
|
|
return S->getKind() == SK_MipsELFStreamer;
|
|
}
|
|
};
|
|
|
|
MCELFStreamer* createMipsELFStreamer(MCContext &Context, MCAsmBackend &TAB,
|
|
raw_ostream &OS, MCCodeEmitter *Emitter,
|
|
bool RelaxAll, bool NoExecStack);
|
|
}
|
|
|
|
#endif /* MIPSELFSTREAMER_H_ */
|