Allow TargetMachine to refuse static code gen

llvm-svn: 4415
This commit is contained in:
Chris Lattner 2002-10-29 21:12:46 +00:00
parent 52b4de4ae9
commit eec571dce8
4 changed files with 17 additions and 9 deletions

View File

@ -51,7 +51,7 @@ protected:
ShortAl, ByteAl) { }
public:
virtual ~TargetMachine() {}
//
// Interfaces to the major aspects of target machine information:
// -- Instruction opcode and operand information
@ -74,9 +74,12 @@ public:
/// addPassesToEmitAssembly - Add passes to the specified pass manager to get
/// assembly langage code emited. Typically this will involve several steps
/// of code generation.
/// of code generation. This method should return true if code generation is
/// not supported.
///
virtual void addPassesToEmitAssembly(PassManager &PM, std::ostream &Out) = 0;
virtual bool addPassesToEmitAssembly(PassManager &PM, std::ostream &Out) {
return true;
}
/// addPassesToJITCompile - Add passes to the specified pass manager to
/// implement a fast dynamic compiler for this target. Return true if this is

View File

@ -141,7 +141,7 @@ UltraSparc::UltraSparc()
// addPassesToEmitAssembly - This method controls the entire code generation
// process for the ultra sparc.
//
void UltraSparc::addPassesToEmitAssembly(PassManager &PM, std::ostream &Out)
bool UltraSparc::addPassesToEmitAssembly(PassManager &PM, std::ostream &Out)
{
// Construct and initialize the MachineFunction object for this fn.
PM.add(createMachineCodeConstructionPass(*this));
@ -189,4 +189,5 @@ void UltraSparc::addPassesToEmitAssembly(PassManager &PM, std::ostream &Out)
// Emit bytecode to the assembly file into its special section next
PM.add(getEmitBytecodeToAsmPass(Out));
PM.add(getFunctionInfo(Out));
return false;
}

View File

@ -718,7 +718,7 @@ public:
virtual const MachineCacheInfo &getCacheInfo() const { return cacheInfo; }
virtual const MachineOptInfo &getOptInfo() const { return optInfo; }
virtual void addPassesToEmitAssembly(PassManager &PM, std::ostream &Out);
virtual bool addPassesToEmitAssembly(PassManager &PM, std::ostream &Out);
// getPrologEpilogCodeInserter - Inserts prolog/epilog code.
virtual Pass* getPrologEpilogInsertionPass();

View File

@ -281,10 +281,14 @@ main(int argc, char **argv)
}
}
Target.addPassesToEmitAssembly(Passes, *Out);
// Run our queue of passes all at once now, efficiently.
Passes.run(*M.get());
// Ask the target to add backend passes as neccesary
if (Target.addPassesToEmitAssembly(Passes, *Out)) {
cerr << argv[0] << ": target '" << Target.TargetName
<< " does not support static compilation!\n";
} else {
// Run our queue of passes all at once now, efficiently.
Passes.run(*M.get());
}
// Delete the ostream if it's not a stdout stream
if (Out != &std::cout) delete Out;