blob: 88fc87e30985186eeaf91d37ac8e432d0fe6004d [file] [log] [blame]
Misha Brukman5dfe3a92004-06-21 16:55:25 +00001//===-- PowerPC.h - Top-level interface for PowerPC representation -*- C++ -*-//
Misha Brukmanb5f662f2005-04-21 23:30:14 +00002//
Misha Brukman5dfe3a92004-06-21 16:55:25 +00003// 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 Brukmanb5f662f2005-04-21 23:30:14 +00007//
Misha Brukman5dfe3a92004-06-21 16:55:25 +00008//===----------------------------------------------------------------------===//
9//
10// This file contains the entry points for global functions defined in the LLVM
11// PowerPC back-end.
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef TARGET_POWERPC_H
16#define TARGET_POWERPC_H
17
Nate Begeman7a4fe9b2004-08-11 07:40:04 +000018#include <iosfwd>
19
Misha Brukman5dfe3a92004-06-21 16:55:25 +000020namespace llvm {
21
22class FunctionPass;
Evan Chengc4c62572006-03-13 23:20:37 +000023class PPCTargetMachine;
Misha Brukman5dfe3a92004-06-21 16:55:25 +000024
Nate Begeman3d72d142005-08-04 20:49:48 +000025enum PPCTargetEnum {
26 TargetDefault, TargetAIX, TargetDarwin
27};
28
Misha Brukman999d9cf2004-07-27 18:33:06 +000029FunctionPass *createPPCBranchSelectionPass();
Evan Chengc4c62572006-03-13 23:20:37 +000030FunctionPass *createPPCISelDag(PPCTargetMachine &TM);
31FunctionPass *createDarwinAsmPrinter(std::ostream &OS, PPCTargetMachine &TM);
32FunctionPass *createAIXAsmPrinter(std::ostream &OS, PPCTargetMachine &TM);
Nate Begeman2497e632005-07-21 20:44:43 +000033
Nate Begeman3d72d142005-08-04 20:49:48 +000034extern PPCTargetEnum PPCTarget;
Misha Brukman5dfe3a92004-06-21 16:55:25 +000035} // end namespace llvm;
36
Misha Brukmanfc256592004-11-14 20:34:01 +000037// GCC #defines PPC on Linux but we use it as our namespace name
38#undef PPC
39
Misha Brukman5dfe3a92004-06-21 16:55:25 +000040// Defines symbolic names for PowerPC registers. This defines a mapping from
41// register name to register number.
42//
Chris Lattner4c7b43b2005-10-14 23:37:35 +000043#include "PPCGenRegisterNames.inc"
Misha Brukman5dfe3a92004-06-21 16:55:25 +000044
45// Defines symbolic names for the PowerPC instructions.
46//
Chris Lattner4c7b43b2005-10-14 23:37:35 +000047#include "PPCGenInstrNames.inc"
Misha Brukman5dfe3a92004-06-21 16:55:25 +000048
49#endif