LLVM  8.0.1
SparcTargetMachine.h
Go to the documentation of this file.
1 //===-- SparcTargetMachine.h - Define TargetMachine for Sparc ---*- 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 declares the Sparc specific subclass of TargetMachine.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_LIB_TARGET_SPARC_SPARCTARGETMACHINE_H
15 #define LLVM_LIB_TARGET_SPARC_SPARCTARGETMACHINE_H
16 
17 #include "SparcInstrInfo.h"
18 #include "SparcSubtarget.h"
20 
21 namespace llvm {
22 
24  std::unique_ptr<TargetLoweringObjectFile> TLOF;
25  SparcSubtarget Subtarget;
26  bool is64Bit;
27  mutable StringMap<std::unique_ptr<SparcSubtarget>> SubtargetMap;
28 public:
29  SparcTargetMachine(const Target &T, const Triple &TT, StringRef CPU,
30  StringRef FS, const TargetOptions &Options,
32  CodeGenOpt::Level OL, bool JIT, bool is64bit);
33  ~SparcTargetMachine() override;
34 
35  const SparcSubtarget *getSubtargetImpl() const { return &Subtarget; }
36  const SparcSubtarget *getSubtargetImpl(const Function &) const override;
37 
38  // Pass Pipeline Configuration
41  return TLOF.get();
42  }
43 };
44 
45 /// Sparc 32-bit target machine
46 ///
48  virtual void anchor();
49 public:
50  SparcV8TargetMachine(const Target &T, const Triple &TT, StringRef CPU,
51  StringRef FS, const TargetOptions &Options,
53  CodeGenOpt::Level OL, bool JIT);
54 };
55 
56 /// Sparc 64-bit target machine
57 ///
59  virtual void anchor();
60 public:
61  SparcV9TargetMachine(const Target &T, const Triple &TT, StringRef CPU,
62  StringRef FS, const TargetOptions &Options,
64  CodeGenOpt::Level OL, bool JIT);
65 };
66 
68  virtual void anchor();
69 
70 public:
71  SparcelTargetMachine(const Target &T, const Triple &TT, StringRef CPU,
72  StringRef FS, const TargetOptions &Options,
74  CodeGenOpt::Level OL, bool JIT);
75 };
76 
77 } // end namespace llvm
78 
79 #endif
This class represents lattice values for constants.
Definition: AllocatorList.h:24
const SparcSubtarget * getSubtargetImpl() const
Target-Independent Code Generator Pass Configuration Options.
TargetLoweringObjectFile * getObjFileLowering() const override
This class describes a target machine that is implemented with the LLVM target-independent code gener...
Triple - Helper class for working with autoconf configuration names.
Definition: Triple.h:44
PassManagerBase - An abstract interface to allow code to add passes to a pass manager without having ...
SparcTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Optional< Reloc::Model > RM, Optional< CodeModel::Model > CM, CodeGenOpt::Level OL, bool JIT, bool is64bit)
Create an ILP32 architecture model.
Sparc 32-bit target machine.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings"...
Definition: StringMap.h:220
Target - Wrapper for Target specific information.
TargetOptions Options
Definition: TargetMachine.h:97
TargetPassConfig * createPassConfig(PassManagerBase &PM) override
Create a pass configuration object to be used by addPassToEmitX methods for generating a pipeline of ...
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:49
Sparc 64-bit target machine.