|  | //===-- Passes.cpp - Target independent code generation passes ------------===// | 
|  | // | 
|  | //                     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 defines interfaces to access the target independent code | 
|  | // generation passes provided by the LLVM backend. | 
|  | // | 
|  | //===---------------------------------------------------------------------===// | 
|  |  | 
|  | #include "llvm/CodeGen/Passes.h" | 
|  | #include "llvm/Support/CommandLine.h" | 
|  | #include <iostream> | 
|  | using namespace llvm; | 
|  |  | 
|  | namespace { | 
|  | enum RegAllocName { simple, local, linearscan, iterativescan }; | 
|  |  | 
|  | cl::opt<RegAllocName> | 
|  | RegAlloc( | 
|  | "regalloc", | 
|  | cl::desc("Register allocator to use: (default = linearscan)"), | 
|  | cl::Prefix, | 
|  | cl::values( | 
|  | clEnumVal(simple,        "  simple register allocator"), | 
|  | clEnumVal(local,         "  local register allocator"), | 
|  | clEnumVal(linearscan,    "  linear scan register allocator"), | 
|  | clEnumVal(iterativescan, "  iterative scan register allocator"), | 
|  | clEnumValEnd), | 
|  | cl::init(linearscan)); | 
|  | } | 
|  |  | 
|  | FunctionPass *llvm::createRegisterAllocator() { | 
|  | switch (RegAlloc) { | 
|  | default: | 
|  | std::cerr << "no register allocator selected"; | 
|  | abort(); | 
|  | case simple: | 
|  | return createSimpleRegisterAllocator(); | 
|  | case local: | 
|  | return createLocalRegisterAllocator(); | 
|  | case linearscan: | 
|  | return createLinearScanRegisterAllocator(); | 
|  | case iterativescan: | 
|  | return createIterativeScanRegisterAllocator(); | 
|  | } | 
|  | } | 
|  |  |