| Chris Lattner | 12e9730 | 2006-09-04 04:14:57 +0000 | [diff] [blame] | 1 | //===-- PPC.h - Top-level interface for PowerPC Target ----------*- C++ -*-===// | 
| Misha Brukman | b440243 | 2005-04-21 23:30:14 +0000 | [diff] [blame] | 2 | // | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
|  | 5 | // This file was developed by the LLVM research group and is distributed under | 
|  | 6 | // the University of Illinois Open Source License. See LICENSE.TXT for details. | 
| Misha Brukman | b440243 | 2005-04-21 23:30:14 +0000 | [diff] [blame] | 7 | // | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file contains the entry points for global functions defined in the LLVM | 
|  | 11 | // PowerPC back-end. | 
|  | 12 | // | 
|  | 13 | //===----------------------------------------------------------------------===// | 
|  | 14 |  | 
| Chris Lattner | 12e9730 | 2006-09-04 04:14:57 +0000 | [diff] [blame] | 15 | #ifndef LLVM_TARGET_POWERPC_H | 
|  | 16 | #define LLVM_TARGET_POWERPC_H | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 17 |  | 
| Nate Begeman | f17ea0f | 2004-08-11 07:40:04 +0000 | [diff] [blame] | 18 | #include <iosfwd> | 
|  | 19 |  | 
| Chris Lattner | 6be7260 | 2006-11-04 05:27:39 +0000 | [diff] [blame] | 20 |  | 
|  | 21 | // GCC #defines PPC on Linux but we use it as our namespace name | 
|  | 22 | #undef PPC | 
|  | 23 |  | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 24 | namespace llvm { | 
| Chris Lattner | 6be7260 | 2006-11-04 05:27:39 +0000 | [diff] [blame] | 25 | class PPCTargetMachine; | 
|  | 26 | class FunctionPassManager; | 
|  | 27 | class FunctionPass; | 
|  | 28 | class MachineCodeEmitter; | 
|  | 29 |  | 
| Misha Brukman | ef8cf02 | 2004-07-27 18:33:06 +0000 | [diff] [blame] | 30 | FunctionPass *createPPCBranchSelectionPass(); | 
| Evan Cheng | 2dd2c65 | 2006-03-13 23:20:37 +0000 | [diff] [blame] | 31 | FunctionPass *createPPCISelDag(PPCTargetMachine &TM); | 
| Chris Lattner | a81a75c | 2006-09-20 17:12:19 +0000 | [diff] [blame] | 32 | FunctionPass *createPPCAsmPrinterPass(std::ostream &OS, | 
|  | 33 | PPCTargetMachine &TM); | 
| Nate Begeman | 3cb3921 | 2006-08-23 21:08:52 +0000 | [diff] [blame] | 34 | FunctionPass *createPPCCodeEmitterPass(PPCTargetMachine &TM, | 
|  | 35 | MachineCodeEmitter &MCE); | 
| Chris Lattner | 12e9730 | 2006-09-04 04:14:57 +0000 | [diff] [blame] | 36 | void addPPCMachOObjectWriterPass(FunctionPassManager &FPM, std::ostream &o, | 
| Nate Begeman | 3cb3921 | 2006-08-23 21:08:52 +0000 | [diff] [blame] | 37 | PPCTargetMachine &tm); | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 38 | } // end namespace llvm; | 
|  | 39 |  | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 40 | // Defines symbolic names for PowerPC registers.  This defines a mapping from | 
|  | 41 | // register name to register number. | 
|  | 42 | // | 
| Chris Lattner | 0921e3b | 2005-10-14 23:37:35 +0000 | [diff] [blame] | 43 | #include "PPCGenRegisterNames.inc" | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 44 |  | 
|  | 45 | // Defines symbolic names for the PowerPC instructions. | 
|  | 46 | // | 
| Chris Lattner | 0921e3b | 2005-10-14 23:37:35 +0000 | [diff] [blame] | 47 | #include "PPCGenInstrNames.inc" | 
| Misha Brukman | e05203f | 2004-06-21 16:55:25 +0000 | [diff] [blame] | 48 |  | 
|  | 49 | #endif |