//
//===----------------------------------------------------------------------===//
-#include "llvm/Assembly/CWriter.h"
+#include "CTargetMachine.h"
+#include "llvm/Target/TargetMachineImpls.h"
#include "llvm/Constants.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Module.h"
std::map<const Type *, std::string> TypeNames;
std::set<const Value*> MangledGlobals;
- bool needsMalloc;
std::map<const ConstantFP *, unsigned> FPConstantMap;
public:
// Function declarations
if (!M.empty()) {
Out << "\n/* Function Declarations */\n";
- needsMalloc = true;
for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) {
// If the function is external and the name collides don't print it.
// Sometimes the bytecode likes to have multiple "declarations" for
}
}
- // Print Malloc prototype if needed
- if (needsMalloc) {
- Out << "\n/* Malloc to make sun happy */\n";
- Out << "extern void * malloc();\n\n";
- }
-
// Output the global variable declarations
if (!M.gempty()) {
Out << "\n\n/* Global Variable Declarations */\n";
void CWriter::printFunctionSignature(const Function *F, bool Prototype) {
- // If the program provides its own malloc prototype we don't need
- // to include the general one.
- if (Mang->getValueName(F) == "malloc")
- needsMalloc = false;
-
if (F->hasInternalLinkage()) Out << "static ";
if (F->hasLinkOnceLinkage()) Out << "inline ";
}
void CWriter::visitMallocInst(MallocInst &I) {
- Out << "(";
- printType(Out, I.getType());
- Out << ")malloc(sizeof(";
- printType(Out, I.getType()->getElementType());
- Out << ")";
-
- if (I.isArrayAllocation()) {
- Out << " * " ;
- writeOperand(I.getOperand(0));
- }
- Out << ")";
+ assert(0 && "lowerallocations pass didn't work!");
}
void CWriter::visitAllocaInst(AllocaInst &I) {
}
void CWriter::visitFreeInst(FreeInst &I) {
- Out << "free((char*)";
- writeOperand(I.getOperand(0));
- Out << ")";
+ assert(0 && "lowerallocations pass didn't work!");
}
void CWriter::printIndexingExpression(Value *Ptr, gep_type_iterator I,
// External Interface declaration
//===----------------------------------------------------------------------===//
-void llvm::AddPassesToWriteC(PassManager &PM, std::ostream &o) {
+bool CTargetMachine::addPassesToEmitAssembly(PassManager &PM, std::ostream &o) {
+ PM.add(createLowerAllocationsPass());
PM.add(createLowerInvokePass());
- //PM.add(createLowerAllocationsPass());
PM.add(new CWriter(o));
+ return false;
+}
+
+TargetMachine *llvm::allocateCTargetMachine(const Module &M,
+ IntrinsicLowering *IL) {
+ return new CTargetMachine(M, IL);
}
--- /dev/null
+//===-- CTargetMachine.h - TargetMachine for the C backend ------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file was developed by the LLVM research group and is distributed under
+// the University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file declares the TargetMachine that is used by the C backend.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef CTARGETMACHINE_H
+#define CTARGETMACHINE_H
+
+#include "llvm/Target/TargetMachine.h"
+
+namespace llvm {
+class IntrinsicLowering;
+
+struct CTargetMachine : public TargetMachine {
+ CTargetMachine(const Module &M, IntrinsicLowering *IL) :
+ TargetMachine("CBackend", IL) {}
+
+ virtual const TargetInstrInfo &getInstrInfo() const { abort(); }
+ virtual const TargetFrameInfo &getFrameInfo() const { abort(); }
+ virtual const TargetSchedInfo &getSchedInfo() const { abort(); }
+ virtual const TargetRegInfo &getRegInfo() const { abort(); }
+ virtual const TargetCacheInfo &getCacheInfo() const { abort(); }
+
+ // This is the only thing that actually does anything here.
+ virtual bool addPassesToEmitAssembly(PassManager &PM, std::ostream &Out);
+};
+
+} // End llvm namespace
+
+
+#endif
//
//===----------------------------------------------------------------------===//
-#include "llvm/Assembly/CWriter.h"
+#include "CTargetMachine.h"
+#include "llvm/Target/TargetMachineImpls.h"
#include "llvm/Constants.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Module.h"
std::map<const Type *, std::string> TypeNames;
std::set<const Value*> MangledGlobals;
- bool needsMalloc;
std::map<const ConstantFP *, unsigned> FPConstantMap;
public:
// Function declarations
if (!M.empty()) {
Out << "\n/* Function Declarations */\n";
- needsMalloc = true;
for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) {
// If the function is external and the name collides don't print it.
// Sometimes the bytecode likes to have multiple "declarations" for
}
}
- // Print Malloc prototype if needed
- if (needsMalloc) {
- Out << "\n/* Malloc to make sun happy */\n";
- Out << "extern void * malloc();\n\n";
- }
-
// Output the global variable declarations
if (!M.gempty()) {
Out << "\n\n/* Global Variable Declarations */\n";
void CWriter::printFunctionSignature(const Function *F, bool Prototype) {
- // If the program provides its own malloc prototype we don't need
- // to include the general one.
- if (Mang->getValueName(F) == "malloc")
- needsMalloc = false;
-
if (F->hasInternalLinkage()) Out << "static ";
if (F->hasLinkOnceLinkage()) Out << "inline ";
}
void CWriter::visitMallocInst(MallocInst &I) {
- Out << "(";
- printType(Out, I.getType());
- Out << ")malloc(sizeof(";
- printType(Out, I.getType()->getElementType());
- Out << ")";
-
- if (I.isArrayAllocation()) {
- Out << " * " ;
- writeOperand(I.getOperand(0));
- }
- Out << ")";
+ assert(0 && "lowerallocations pass didn't work!");
}
void CWriter::visitAllocaInst(AllocaInst &I) {
}
void CWriter::visitFreeInst(FreeInst &I) {
- Out << "free((char*)";
- writeOperand(I.getOperand(0));
- Out << ")";
+ assert(0 && "lowerallocations pass didn't work!");
}
void CWriter::printIndexingExpression(Value *Ptr, gep_type_iterator I,
// External Interface declaration
//===----------------------------------------------------------------------===//
-void llvm::AddPassesToWriteC(PassManager &PM, std::ostream &o) {
+bool CTargetMachine::addPassesToEmitAssembly(PassManager &PM, std::ostream &o) {
+ PM.add(createLowerAllocationsPass());
PM.add(createLowerInvokePass());
- //PM.add(createLowerAllocationsPass());
PM.add(new CWriter(o));
+ return false;
+}
+
+TargetMachine *llvm::allocateCTargetMachine(const Module &M,
+ IntrinsicLowering *IL) {
+ return new CTargetMachine(M, IL);
}