Add calls to NormalizeMethod() and to ScheduleInstructionsWithSSA().
[oota-llvm.git] / tools / llc / llc.cpp
index a3312967d64942c85e79c5410aba57d9c646d737..7bf820f9f0e5a045993eaadb97db69d40298dec2 100644 (file)
 #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) {
-    Method * method = *MI;
+  for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI)
+    {
+      Method* method = *MI;
+      
+      NormalizeMethod(method);
       
-    if (SelectInstructionsForMethod(method, Target)) {
-      failed = true;
-      cerr << "Instruction selection failed for method "
-          << method->getName() << "\n\n";
+      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;
+       }
     }
-  }
   
   return failed;
 }
 
 
+
 //---------------------------------------------------------------------------
 // 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) {
     cerr << "bytecode didn't read correctly.\n";
     return 1;
   }
-  
-  if (CompileModule(module, Target)) {
+
+  if (CompileModule(module, target)) {
     cerr << "Error compiling " << InputFilename << "!\n";
     delete module;
     return 1;