File: TargetMachine.h

package info (click to toggle)
intel-graphics-compiler2 2.22.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 107,676 kB
  • sloc: cpp: 809,645; lisp: 288,070; ansic: 16,397; python: 4,010; yacc: 2,588; lex: 1,666; pascal: 314; sh: 186; makefile: 38
file content (78 lines) | stat: -rw-r--r-- 3,037 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*========================== begin_copyright_notice ============================

Copyright (C) 2020-2021 Intel Corporation

SPDX-License-Identifier: MIT

============================= end_copyright_notice ===========================*/

#ifndef IGCLLVM_TARGET_TARGETMACHINE_H
#define IGCLLVM_TARGET_TARGETMACHINE_H

#include "llvm/Config/llvm-config.h"
#include "llvm/CodeGen/MachineModuleInfo.h"
#include "llvm/Support/CodeGen.h"
#include "llvm/Target/TargetMachine.h"

#if LLVM_VERSION_MAJOR < 15
#define LLVM_GET_TTI_API_QUAL
#else // LLVM_VERSION_MAJOR
#define LLVM_GET_TTI_API_QUAL const
#endif // LLVM_VERSION_MAJOR

namespace IGCLLVM {
class TargetMachine : public llvm::TargetMachine {
public:
  using CodeGenFileType = llvm::CodeGenFileType;

protected:
  TargetMachine(const llvm::Target &T, llvm::StringRef DataLayoutString, const llvm::Triple &TargetTriple,
                llvm::StringRef CPU, llvm::StringRef FS, const llvm::TargetOptions &Options)
      : llvm::TargetMachine(T, DataLayoutString, TargetTriple, CPU, FS, Options) {}

private:
  bool addPassesToEmitFile(llvm::PassManagerBase &PM, llvm::raw_pwrite_stream &o, llvm::raw_pwrite_stream *pi,
                           llvm::CodeGenFileType FileType, bool DisableVerify,
                           llvm::MachineModuleInfoWrapperPass *MMIWP) override {
    llvm::MachineModuleInfo *MMI = nullptr;
    if (MMIWP)
      MMI = &MMIWP->getMMI();
    return addPassesToEmitFile(PM, o, pi, FileType, DisableVerify, MMI);
  }

public:
  virtual bool addPassesToEmitFile(llvm::PassManagerBase &PM, llvm::raw_pwrite_stream &o, llvm::raw_pwrite_stream *pi,
                                   CodeGenFileType FileType, bool DisableVerify, llvm::MachineModuleInfo *MMI) {
    return true;
  }
};

class LLVMTargetMachine : public llvm::LLVMTargetMachine {
public:
  using CodeGenFileType = llvm::CodeGenFileType;

protected:
  LLVMTargetMachine(const llvm::Target &T, llvm::StringRef DataLayoutString, const llvm::Triple &TargetTriple,
                    llvm::StringRef CPU, llvm::StringRef FS, const llvm::TargetOptions &Options, llvm::Reloc::Model RM,
                    llvm::CodeModel::Model CM, llvm::CodeGenOpt::Level OL)
      : llvm::LLVMTargetMachine(T, DataLayoutString, TargetTriple, CPU, FS, Options, RM, CM, OL) {}

private:
  bool addPassesToEmitFile(llvm::PassManagerBase &PM, llvm::raw_pwrite_stream &o, llvm::raw_pwrite_stream *pi,
                           llvm::CodeGenFileType FileType, bool DisableVerify,
                           llvm::MachineModuleInfoWrapperPass *MMIWP) override {
    llvm::MachineModuleInfo *MMI = nullptr;
    if (MMIWP)
      MMI = &MMIWP->getMMI();
    return addPassesToEmitFile(PM, o, pi, FileType, DisableVerify, MMI);
  }

public:
  virtual bool addPassesToEmitFile(llvm::PassManagerBase &PM, llvm::raw_pwrite_stream &o, llvm::raw_pwrite_stream *pi,
                                   CodeGenFileType FileType, bool DisableVerify, llvm::MachineModuleInfo *MMI) {
    return true;
  }
};
} // namespace IGCLLVM

#endif