Convert the C backend into a target, for use with LLC. This allows us to use

the lowerallocations pass to eliminate malloc/free warnings and hackish code

llvm-svn: 11409
This commit is contained in:
Chris Lattner 2004-02-13 23:18:48 +00:00
parent 9fae109121
commit 0591bb5bc8
2 changed files with 51 additions and 30 deletions

View File

@ -0,0 +1,39 @@
//===-- 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

View File

@ -12,7 +12,8 @@
//
//===----------------------------------------------------------------------===//
#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"
@ -42,7 +43,6 @@ namespace {
std::map<const Type *, std::string> TypeNames;
std::set<const Value*> MangledGlobals;
bool needsMalloc;
std::map<const ConstantFP *, unsigned> FPConstantMap;
public:
@ -669,7 +669,6 @@ bool CWriter::doInitialization(Module &M) {
// 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
@ -684,12 +683,6 @@ bool CWriter::doInitialization(Module &M) {
}
}
// 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";
@ -873,11 +866,6 @@ void CWriter::printContainedStructs(const Type *Ty,
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 ";
@ -1264,17 +1252,7 @@ void CWriter::visitCallSite(CallSite CS) {
}
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) {
@ -1291,9 +1269,7 @@ 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,
@ -1394,8 +1370,14 @@ void CWriter::visitVAArgInst(VAArgInst &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);
}