1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 02:52:53 +02:00

*** empty log message ***

llvm-svn: 2552
This commit is contained in:
Sumant Kowshik 2002-05-08 18:09:58 +00:00
parent 07a6a20a96
commit 64cf4b95c9
9 changed files with 1494 additions and 15 deletions

View File

@ -0,0 +1,21 @@
//===-- llvm/CGen/Writer.h - Printer for VM assembly files -------*- C++ -*--=//
//
// This functionality is implemented by the lib/CWriter library.
// This library is used to print C language files to an iostream.
//
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_C_WRITER_H
#define LLVM_C_WRITER_H
class Module;
#include <iosfwd>
void WriteToC(const Module *Module, std::ostream &o);
#endif

7
lib/CWriter/Makefile Normal file
View File

@ -0,0 +1,7 @@
LEVEL = ../..
LIBRARYNAME = cwriter
include $(LEVEL)/Makefile.common

1415
lib/CWriter/Writer.cpp Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +1,5 @@
LEVEL = ..
DIRS = VMCore Analysis Transforms AsmParser Bytecode Support CodeGen Target
DIRS = VMCore Analysis Transforms AsmParser Bytecode Support CodeGen Target CWriter
include $(LEVEL)/Makefile.common

View File

@ -1,7 +1,7 @@
LEVEL = ../..
TOOLNAME = dis
USEDLIBS = bcreader vmcore support
USEDLIBS = bcreader vmcore support cwriter
include $(LEVEL)/Makefile.common

View File

@ -11,6 +11,8 @@
// -rdfo - Print basic blocks in reverse depth first order
// -po - Print basic blocks in post order
// -rpo - Print basic blocks in reverse post order
//
// -c - Print C code
//
// TODO: add -vcg which prints VCG compatible output.
//
@ -23,6 +25,7 @@
#include "Support/PostOrderIterator.h"
#include "Support/CommandLine.h"
#include "Support/Signals.h"
#include "llvm/Assembly/CWriter.h"
#include <fstream>
#include <iostream>
using std::cerr;
@ -34,6 +37,8 @@ enum OutputMode {
rdfo, // Reverse Depth First ordering
po, // Post Order
rpo, // Reverse Post Order
c, // Generate C code
};
cl::String InputFilename ("", "Load <arg> file, print as assembly", 0, "-");
@ -45,6 +50,8 @@ cl::EnumFlags<enum OutputMode> WriteMode(cl::NoFlags,
clEnumVal(rdfo , "Write basic blocks in reverse DFO"),
clEnumVal(po , "Write basic blocks in postorder"),
clEnumVal(rpo , "Write basic blocks in reverse postorder"),
clEnumVal(c , "Write corresponding C code"),
0);
int main(int argc, char **argv) {
@ -77,7 +84,10 @@ int main(int argc, char **argv) {
} else {
OutputFilename = IFN; // Append a .ll to it
}
OutputFilename += ".ll";
if (WriteMode == c)
OutputFilename += ".c";
else
OutputFilename += ".ll";
if (!Force && std::ifstream(OutputFilename.c_str())) {
// If force is not specified, make sure not to overwrite a file!
@ -99,11 +109,12 @@ int main(int argc, char **argv) {
Out = &std::cout;
}
// All that dis does is write the assembly out to a file... which is exactly
// what the writer library is supposed to do...
//
// All that dis does is write the assembly or C out to a file... which is
// exactly what the writer or cwriter library is supposed to do...
if (WriteMode == Default) {
(*Out) << M; // Print out in list order
} else if (WriteMode == c) {
WriteToC(M, *Out);
} else {
// TODO: This does not print anything other than the basic blocks in the
// functions... more should definately be printed. It should be valid
@ -145,3 +156,4 @@ int main(int argc, char **argv) {
if (Out != &std::cout) delete Out;
return 0;
}

View File

@ -1,7 +1,7 @@
LEVEL = ../..
TOOLNAME = dis
USEDLIBS = bcreader vmcore support
USEDLIBS = bcreader vmcore support cwriter
include $(LEVEL)/Makefile.common

View File

@ -11,6 +11,8 @@
// -rdfo - Print basic blocks in reverse depth first order
// -po - Print basic blocks in post order
// -rpo - Print basic blocks in reverse post order
//
// -c - Print C code
//
// TODO: add -vcg which prints VCG compatible output.
//
@ -23,6 +25,7 @@
#include "Support/PostOrderIterator.h"
#include "Support/CommandLine.h"
#include "Support/Signals.h"
#include "llvm/Assembly/CWriter.h"
#include <fstream>
#include <iostream>
using std::cerr;
@ -34,6 +37,8 @@ enum OutputMode {
rdfo, // Reverse Depth First ordering
po, // Post Order
rpo, // Reverse Post Order
c, // Generate C code
};
cl::String InputFilename ("", "Load <arg> file, print as assembly", 0, "-");
@ -45,6 +50,8 @@ cl::EnumFlags<enum OutputMode> WriteMode(cl::NoFlags,
clEnumVal(rdfo , "Write basic blocks in reverse DFO"),
clEnumVal(po , "Write basic blocks in postorder"),
clEnumVal(rpo , "Write basic blocks in reverse postorder"),
clEnumVal(c , "Write corresponding C code"),
0);
int main(int argc, char **argv) {
@ -77,7 +84,10 @@ int main(int argc, char **argv) {
} else {
OutputFilename = IFN; // Append a .ll to it
}
OutputFilename += ".ll";
if (WriteMode == c)
OutputFilename += ".c";
else
OutputFilename += ".ll";
if (!Force && std::ifstream(OutputFilename.c_str())) {
// If force is not specified, make sure not to overwrite a file!
@ -99,11 +109,12 @@ int main(int argc, char **argv) {
Out = &std::cout;
}
// All that dis does is write the assembly out to a file... which is exactly
// what the writer library is supposed to do...
//
// All that dis does is write the assembly or C out to a file... which is
// exactly what the writer or cwriter library is supposed to do...
if (WriteMode == Default) {
(*Out) << M; // Print out in list order
} else if (WriteMode == c) {
WriteToC(M, *Out);
} else {
// TODO: This does not print anything other than the basic blocks in the
// functions... more should definately be printed. It should be valid
@ -145,3 +156,4 @@ int main(int argc, char **argv) {
if (Out != &std::cout) delete Out;
return 0;
}

View File

@ -11,6 +11,8 @@
// -rdfo - Print basic blocks in reverse depth first order
// -po - Print basic blocks in post order
// -rpo - Print basic blocks in reverse post order
//
// -c - Print C code
//
// TODO: add -vcg which prints VCG compatible output.
//
@ -23,6 +25,7 @@
#include "Support/PostOrderIterator.h"
#include "Support/CommandLine.h"
#include "Support/Signals.h"
#include "llvm/Assembly/CWriter.h"
#include <fstream>
#include <iostream>
using std::cerr;
@ -34,6 +37,8 @@ enum OutputMode {
rdfo, // Reverse Depth First ordering
po, // Post Order
rpo, // Reverse Post Order
c, // Generate C code
};
cl::String InputFilename ("", "Load <arg> file, print as assembly", 0, "-");
@ -45,6 +50,8 @@ cl::EnumFlags<enum OutputMode> WriteMode(cl::NoFlags,
clEnumVal(rdfo , "Write basic blocks in reverse DFO"),
clEnumVal(po , "Write basic blocks in postorder"),
clEnumVal(rpo , "Write basic blocks in reverse postorder"),
clEnumVal(c , "Write corresponding C code"),
0);
int main(int argc, char **argv) {
@ -77,7 +84,10 @@ int main(int argc, char **argv) {
} else {
OutputFilename = IFN; // Append a .ll to it
}
OutputFilename += ".ll";
if (WriteMode == c)
OutputFilename += ".c";
else
OutputFilename += ".ll";
if (!Force && std::ifstream(OutputFilename.c_str())) {
// If force is not specified, make sure not to overwrite a file!
@ -99,11 +109,12 @@ int main(int argc, char **argv) {
Out = &std::cout;
}
// All that dis does is write the assembly out to a file... which is exactly
// what the writer library is supposed to do...
//
// All that dis does is write the assembly or C out to a file... which is
// exactly what the writer or cwriter library is supposed to do...
if (WriteMode == Default) {
(*Out) << M; // Print out in list order
} else if (WriteMode == c) {
WriteToC(M, *Out);
} else {
// TODO: This does not print anything other than the basic blocks in the
// functions... more should definately be printed. It should be valid
@ -145,3 +156,4 @@ int main(int argc, char **argv) {
if (Out != &std::cout) delete Out;
return 0;
}