1 //===-- Alpha.h - Top-level interface for Alpha representation --*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // 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
18 #include "llvm/Target/TargetMachine.h"
22 class AlphaTargetMachine
;
24 class MachineCodeEmitter
;
25 class ObjectCodeEmitter
;
26 class formatted_raw_ostream
;
28 FunctionPass
*createAlphaISelDag(AlphaTargetMachine
&TM
);
29 FunctionPass
*createAlphaCodePrinterPass(formatted_raw_ostream
&OS
,
32 FunctionPass
*createAlphaPatternInstructionSelector(TargetMachine
&TM
);
33 FunctionPass
*createAlphaCodeEmitterPass(AlphaTargetMachine
&TM
,
34 MachineCodeEmitter
&MCE
);
35 FunctionPass
*createAlphaJITCodeEmitterPass(AlphaTargetMachine
&TM
,
37 FunctionPass
*createAlphaObjectCodeEmitterPass(AlphaTargetMachine
&TM
,
38 ObjectCodeEmitter
&OCE
);
39 FunctionPass
*createAlphaLLRPPass(AlphaTargetMachine
&tm
);
40 FunctionPass
*createAlphaBranchSelectionPass();
42 } // end namespace llvm;
44 // Defines symbolic names for Alpha registers. This defines a mapping from
45 // register name to register number.
47 #include "AlphaGenRegisterNames.inc"
49 // Defines symbolic names for the Alpha instructions.
51 #include "AlphaGenInstrNames.inc"