1 //===-- Alpha.h - Top-level interface for Alpha representation --*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
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.
8 //===----------------------------------------------------------------------===//
10 // This file contains the entry points for global functions defined in the LLVM
13 //===----------------------------------------------------------------------===//
15 #ifndef TARGET_ALPHA_H
16 #define TARGET_ALPHA_H
22 class AlphaTargetMachine
;
25 class MachineCodeEmitter
;
27 FunctionPass
*createAlphaSimpleInstructionSelector(TargetMachine
&TM
);
28 FunctionPass
*createAlphaISelDag(TargetMachine
&TM
);
29 FunctionPass
*createAlphaCodePrinterPass(std::ostream
&OS
,
31 FunctionPass
*createAlphaPatternInstructionSelector(TargetMachine
&TM
);
32 FunctionPass
*createAlphaCodeEmitterPass(AlphaTargetMachine
&TM
,
33 MachineCodeEmitter
&MCE
);
34 FunctionPass
*createAlphaLLRPPass(AlphaTargetMachine
&tm
);
35 FunctionPass
*createAlphaBranchSelectionPass();
37 } // end namespace llvm;
39 // Defines symbolic names for Alpha registers. This defines a mapping from
40 // register name to register number.
42 #include "AlphaGenRegisterNames.inc"
44 // Defines symbolic names for the Alpha instructions.
46 #include "AlphaGenInstrNames.inc"