Add calls to NormalizeMethod() and to ScheduleInstructionsWithSSA().

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@404 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Vikram S. Adve 2001-08-28 23:23:14 +00:00
parent 59e3b8220a
commit 14335835f1

View File

@ -14,23 +14,48 @@
#include "llvm/Module.h"
#include "llvm/Method.h"
#include "llvm/Bytecode/Reader.h"
#include "llvm/Optimizations/Normalize.h"
#include "llvm/CodeGen/InstrSelection.h"
#include "llvm/CodeGen/InstrScheduling.h"
#include "llvm/CodeGen/Sparc.h"
#include "llvm/Support/CommandLine.h"
cl::String InputFilename ("", "Input filename", cl::NoFlags, "-");
cl::String OutputFilename("o", "Output filename", cl::NoFlags, "");
static bool CompileModule(Module *M, TargetMachine &Target) {
void
NormalizeMethod(Method* method)
{
NormalizePhiConstantArgs(method);
}
static bool
CompileModule(Module *M, TargetMachine &target)
{
bool failed = false;
for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI) {
for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI)
{
Method* method = *MI;
if (SelectInstructionsForMethod(method, Target)) {
failed = true;
NormalizeMethod(method);
failed = SelectInstructionsForMethod(method, target);
if (failed)
{
cerr << "Instruction selection failed for method "
<< method->getName() << "\n\n";
break;
}
failed = ScheduleInstructionsWithSSA(method, target);
if (failed)
{
cerr << "Instruction scheduling before allocation failed for method "
<< method->getName() << "\n\n";
break;
}
}
@ -38,15 +63,18 @@ static bool CompileModule(Module *M, TargetMachine &Target) {
}
//---------------------------------------------------------------------------
// Function main()
//
// Entry point for the driver.
// Entry point for the llc compiler.
//---------------------------------------------------------------------------
int main(int argc, char** argv) {
int
main(int argc, char** argv)
{
cl::ParseCommandLineOptions(argc, argv, " llvm system compiler\n");
UltraSparc Target;
UltraSparc target;
Module *module = ParseBytecodeFile(InputFilename);
if (module == 0) {
@ -54,7 +82,7 @@ int main(int argc, char** argv) {
return 1;
}
if (CompileModule(module, Target)) {
if (CompileModule(module, target)) {
cerr << "Error compiling " << InputFilename << "!\n";
delete module;
return 1;