PTX: Add preliminary support for floating-point divide and multiply-and-add
[oota-llvm.git] / lib / Target / PTX / PTX.h
1 //===-- PTX.h - Top-level interface for PTX representation ------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains the entry points for global functions defined in the LLVM
11 // PTX back-end.
12 //
13 //===----------------------------------------------------------------------===//
14
15 #ifndef PTX_H
16 #define PTX_H
17
18 #include "llvm/Target/TargetMachine.h"
19
20 namespace llvm {
21   class PTXTargetMachine;
22   class FunctionPass;
23
24   namespace PTX {
25     enum StateSpace {
26       GLOBAL = 0, // default to global state space
27       CONSTANT = 1,
28       LOCAL = 2,
29       PARAMETER = 3,
30       SHARED = 4
31     };
32   } // namespace PTX
33
34   FunctionPass *createPTXISelDag(PTXTargetMachine &TM,
35                                  CodeGenOpt::Level OptLevel);
36
37   FunctionPass *createPTXMFInfoExtract(PTXTargetMachine &TM,
38                                        CodeGenOpt::Level OptLevel);
39
40   extern Target ThePTXTarget;
41 } // namespace llvm;
42
43 // Defines symbolic names for PTX registers.
44 #include "PTXGenRegisterNames.inc"
45
46 // Defines symbolic names for the PTX instructions.
47 #include "PTXGenInstrNames.inc"
48
49 #endif // PTX_H