aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/llc/llc.cpp54
1 files changed, 24 insertions, 30 deletions
diff --git a/tools/llc/llc.cpp b/tools/llc/llc.cpp
index 73298ed..77cc7ce 100644
--- a/tools/llc/llc.cpp
+++ b/tools/llc/llc.cpp
@@ -11,6 +11,7 @@
#include "llvm/Support/CommandLine.h"
#include "llvm/Module.h"
#include "llvm/Method.h"
+#include <memory>
cl::String InputFilename ("", "Input filename", cl::NoFlags, "-");
cl::String OutputFilename("o", "Output filename", cl::NoFlags, "");
@@ -18,9 +19,7 @@ cl::String OutputFilename("o", "Output filename", cl::NoFlags, "");
//-------------------------- Internal Functions -----------------------------//
-static void
-NormalizeMethod(Method* method)
-{
+static void NormalizeMethod(Method* method) {
NormalizePhiConstantArgs(method);
}
@@ -31,39 +30,34 @@ NormalizeMethod(Method* method)
// Entry point for the llc compiler.
//===---------------------------------------------------------------------===//
-int
-main(int argc, char** argv)
-{
+int main(int argc, char **argv) {
+ // Parse command line options...
cl::ParseCommandLineOptions(argc, argv, " llvm system compiler\n");
- TargetMachine *Target = allocateSparcTargetMachine();
-
- Module *M = ParseBytecodeFile(InputFilename);
- if (M == 0)
- {
- cerr << "bytecode didn't read correctly.\n";
- delete Target;
- return 1;
- }
- bool Failed = false;
- for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI)
- {
- Method *Meth = *MI;
+ // Allocate a target... in the future this will be controllable on the
+ // command line.
+ auto_ptr<TargetMachine> Target(allocateSparcTargetMachine());
+
+ // Load the module to be compiled...
+ auto_ptr<Module> M(ParseBytecodeFile(InputFilename));
+ if (M.get() == 0) {
+ cerr << "bytecode didn't read correctly.\n";
+ return 1;
+ }
+
+ // Loop over all of the methods in the module, compiling them.
+ for (Module::const_iterator MI = M->begin(), ME = M->end(); MI != ME; ++MI) {
+ Method *Meth = *MI;
- NormalizeMethod(Meth);
+ NormalizeMethod(Meth);
- if (Target->compileMethod(Meth))
- {
- cerr << "Error compiling " << InputFilename << "!\n";
- Failed = true;
- break;
- }
+ if (Target.get()->compileMethod(Meth)) {
+ cerr << "Error compiling " << InputFilename << "!\n";
+ return 1;
}
+ }
- // Clean up and exit
- delete M;
- delete Target;
- return Failed;
+ return 0;
}