make the stubbed-out printer methods abort instead of
[oota-llvm.git] / lib / Target / PowerPC / PPC.h
index e63892ddb3d47573e7b9552cba1e1e800502d165..24e2710a15c9bd13945c67c2125a2eba47acf1b2 100644 (file)
@@ -1,10 +1,10 @@
-//===-- PowerPC.h - Top-level interface for PowerPC representation -*- C++ -*-//
-// 
+//===-- PPC.h - Top-level interface for PowerPC Target ----------*- C++ -*-===//
+//
 //                     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 is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
 //===----------------------------------------------------------------------===//
 //
 // This file contains the entry points for global functions defined in the LLVM
 //
 //===----------------------------------------------------------------------===//
 
-#ifndef TARGET_POWERPC_H
-#define TARGET_POWERPC_H
+#ifndef LLVM_TARGET_POWERPC_H
+#define LLVM_TARGET_POWERPC_H
 
-#include <iosfwd>
+// GCC #defines PPC on Linux but we use it as our namespace name
+#undef PPC
 
 namespace llvm {
+  class PPCTargetMachine;
+  class FunctionPass;
+  class formatted_raw_ostream;
+  class JITCodeEmitter;
+  class Target;
+  class MachineInstr;
+  class MCInst;
+  class AsmPrinter;
+  
+FunctionPass *createPPCBranchSelectionPass();
+FunctionPass *createPPCISelDag(PPCTargetMachine &TM);
+FunctionPass *createPPCJITCodeEmitterPass(PPCTargetMachine &TM,
+                                          JITCodeEmitter &MCE);
 
-class FunctionPass;
-class TargetMachine;
+void LowerPPCMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI,
+                                  AsmPrinter &AP);
+
+extern Target ThePPC32Target;
+extern Target ThePPC64Target;
 
-// Here is where you would define factory methods for powerpc-specific
-// passes. For example:
-FunctionPass *createPPCSimpleInstructionSelector(TargetMachine &TM);
-FunctionPass *createPPCCodePrinterPass(std::ostream &OS, TargetMachine &TM);
-FunctionPass *createPowerPCPEI();
-FunctionPass *createPPCBranchSelectionPass();
 } // end namespace llvm;
 
 // Defines symbolic names for PowerPC registers.  This defines a mapping from
 // register name to register number.
 //
-#include "PowerPCGenRegisterNames.inc"
+#include "PPCGenRegisterNames.inc"
 
 // Defines symbolic names for the PowerPC instructions.
 //
-#include "PowerPCGenInstrNames.inc"
+#include "PPCGenInstrNames.inc"
 
 #endif