diff options
author | Chris Lattner <sabre@nondot.org> | 2002-02-11 22:35:46 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-02-11 22:35:46 +0000 |
commit | 9530a6f3cd8d071c260baa12f28d66f9d6f983d1 (patch) | |
tree | 9f09243fcfb9317d5c45e7105c0e85e410af24ff /lib/Target/SparcV9/EmitBytecodeToAssembly.cpp | |
parent | 355df3f73d6eabc7ce236c0204fe155996543d08 (diff) |
Write llvm bytecode to output .s file as last step of LLC.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1728 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/SparcV9/EmitBytecodeToAssembly.cpp')
-rw-r--r-- | lib/Target/SparcV9/EmitBytecodeToAssembly.cpp | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/lib/Target/SparcV9/EmitBytecodeToAssembly.cpp b/lib/Target/SparcV9/EmitBytecodeToAssembly.cpp new file mode 100644 index 0000000000..7cbf08557f --- /dev/null +++ b/lib/Target/SparcV9/EmitBytecodeToAssembly.cpp @@ -0,0 +1,77 @@ +//===-- EmitBytecodeToAssembly.cpp - Emit bytecode to Sparc .s File --------==// +// +// This file implements the pass that writes LLVM bytecode as data to a sparc +// assembly file. The bytecode gets assembled into a special bytecode section +// of the executable for use at runtime later. +// +//===----------------------------------------------------------------------===// + +#include "SparcInternals.h" +#include "llvm/Bytecode/Writer.h" + +namespace { + + // sparcasmbuf - stream buf for encoding output bytes as .byte directives for + // the sparc assembler. + // + class sparcasmbuf : public streambuf { + std::ostream &BaseStr; + public: + typedef char char_type; + typedef int int_type; + typedef streampos pos_type; + typedef streamoff off_type; + + sparcasmbuf(std::ostream &On) : BaseStr(On) {} + + virtual int_type overflow(int_type C) { + if (C != EOF) + BaseStr << "\t.byte " << C << "\n"; // Output C; + return C; + } + }; + + + // osparcasmstream - Define an ostream implementation that uses a sparcasmbuf + // as the underlying streambuf to write the data to. This streambuf formats + // the output as .byte directives for sparc output. + // + class osparcasmstream : public ostream { + sparcasmbuf sb; + public: + typedef char char_type; + typedef int int_type; + typedef streampos pos_type; + typedef streamoff off_type; + + explicit osparcasmstream(ostream &On) : ostream(&sb), sb(On) { } + + sparcasmbuf *rdbuf() const { + return const_cast<sparcasmbuf*>(&sb); + } + }; + + // SparcBytecodeWriter - Write bytecode out to a stream that is sparc'ified + class SparcBytecodeWriter : public Pass { + std::ostream &Out; + public: + SparcBytecodeWriter(std::ostream &out) : Out(out) {} + + virtual bool run(Module *M) { + // Write bytecode out to the sparc assembly stream + Out << "\n\n!LLVM BYTECODE OUTPUT\n\t.section \".rodata\"\n\t.align 8\n"; + Out << "\t.global LLVMBytecode\n\t.type LLVMBytecode,#object\n"; + Out << "LLVMBytecode:\n"; + osparcasmstream OS(Out); + WriteBytecodeToFile(M, OS); + + Out << ".end_LLVMBytecode:\n"; + Out << "\t.size LLVMBytecode, .end_LLVMBytecode-LLVMBytecode\n\n"; + return false; + } + }; +} // end anonymous namespace + +Pass *UltraSparc::getEmitBytecodeToAsmPass(std::ostream &Out) { + return new SparcBytecodeWriter(Out); +} |