Coverage Report

Created: 2020-02-15 09:57

/Users/buildslave/jenkins/workspace/coverage/llvm-project/clang/include/clang/Basic/OpenCLOptions.h
Line
Count
Source (jump to first uncovered line)
1
//===--- OpenCLOptions.h ----------------------------------------*- C++ -*-===//
2
//
3
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4
// See https://llvm.org/LICENSE.txt for license information.
5
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6
//
7
//===----------------------------------------------------------------------===//
8
///
9
/// \file
10
/// Defines the clang::OpenCLOptions class.
11
///
12
//===----------------------------------------------------------------------===//
13
14
#ifndef LLVM_CLANG_BASIC_OPENCLOPTIONS_H
15
#define LLVM_CLANG_BASIC_OPENCLOPTIONS_H
16
17
#include "clang/Basic/LangOptions.h"
18
#include "llvm/ADT/StringMap.h"
19
20
namespace clang {
21
22
/// OpenCL supported extensions and optional core features
23
class OpenCLOptions {
24
  struct Info {
25
    bool Supported; // Is this option supported
26
    bool Enabled;   // Is this option enabled
27
    unsigned Avail; // Option starts to be available in this OpenCL version
28
    unsigned Core;  // Option becomes (optional) core feature in this OpenCL
29
                    // version
30
    Info(bool S = false, bool E = false, unsigned A = 100, unsigned C = ~0U)
31
6.23M
      :Supported(S), Enabled(E), Avail(A), Core(C){}
32
  };
33
  llvm::StringMap<Info> OptMap;
34
public:
35
2.22k
  bool isKnown(llvm::StringRef Ext) const {
36
2.22k
    return OptMap.find(Ext) != OptMap.end();
37
2.22k
  }
38
39
99.6k
  bool isEnabled(llvm::StringRef Ext) const {
40
99.6k
    return OptMap.find(Ext)->second.Enabled;
41
99.6k
  }
42
43
  // Is supported as either an extension or an (optional) core feature for
44
  // OpenCL version \p CLVer.
45
25.6k
  bool isSupported(llvm::StringRef Ext, const LangOptions &LO) const {
46
25.6k
    // In C++ mode all extensions should work at least as in v2.0.
47
25.6k
    auto CLVer = LO.OpenCLCPlusPlus ? 
2002.70k
:
LO.OpenCLVersion22.9k
;
48
25.6k
    auto I = OptMap.find(Ext)->getValue();
49
25.6k
    return I.Supported && 
I.Avail <= CLVer18.4k
;
50
25.6k
  }
51
52
  // Is supported (optional) OpenCL core features for OpenCL version \p CLVer.
53
  // For supported extension, return false.
54
24.7k
  bool isSupportedCore(llvm::StringRef Ext, const LangOptions &LO) const {
55
24.7k
    // In C++ mode all extensions should work at least as in v2.0.
56
24.7k
    auto CLVer = LO.OpenCLCPlusPlus ? 
2002.75k
:
LO.OpenCLVersion22.0k
;
57
24.7k
    auto I = OptMap.find(Ext)->getValue();
58
24.7k
    return I.Supported && 
I.Avail <= CLVer18.3k
&&
I.Core != ~0U13.8k
&&
CLVer >= I.Core4.39k
;
59
24.7k
  }
60
61
  // Is supported OpenCL extension for OpenCL version \p CLVer.
62
  // For supported (optional) core feature, return false.
63
2.12k
  bool isSupportedExtension(llvm::StringRef Ext, const LangOptions &LO) const {
64
2.12k
    // In C++ mode all extensions should work at least as in v2.0.
65
2.12k
    auto CLVer = LO.OpenCLCPlusPlus ? 
200111
:
LO.OpenCLVersion2.01k
;
66
2.12k
    auto I = OptMap.find(Ext)->getValue();
67
2.12k
    return I.Supported && 
I.Avail <= CLVer1.14k
&&
(1.03k
I.Core == ~0U1.03k
||
CLVer < I.Core421
);
68
2.12k
  }
69
70
763
  void enable(llvm::StringRef Ext, bool V = true) {
71
763
    OptMap[Ext].Enabled = V;
72
763
  }
73
74
  /// Enable or disable support for OpenCL extensions
75
  /// \param Ext name of the extension optionally prefixed with
76
  ///        '+' or '-'
77
  /// \param V used when \p Ext is not prefixed by '+' or '-'
78
6.77k
  void support(llvm::StringRef Ext, bool V = true) {
79
6.77k
    assert(!Ext.empty() && "Extension is empty.");
80
6.77k
81
6.77k
    switch (Ext[0]) {
82
16
    case '+':
83
16
      V = true;
84
16
      Ext = Ext.drop_front();
85
16
      break;
86
12
    case '-':
87
12
      V = false;
88
12
      Ext = Ext.drop_front();
89
12
      break;
90
6.77k
    }
91
6.77k
92
6.77k
    if (Ext.equals("all")) {
93
6
      supportAll(V);
94
6
      return;
95
6
    }
96
6.76k
    OptMap[Ext].Supported = V;
97
6.76k
  }
98
99
148k
  OpenCLOptions(){
100
148k
#define OPENCLEXT_INTERNAL(Ext, AvailVer, CoreVer) \
101
6.23M
    OptMap[#Ext].Avail = AvailVer; \
102
6.23M
    OptMap[#Ext].Core = CoreVer;
103
148k
#include "clang/Basic/OpenCLExtensions.def"
104
148k
  }
105
106
535
  void addSupport(const OpenCLOptions &Opts) {
107
535
    for (auto &I:Opts.OptMap)
108
22.4k
      if (I.second.Supported)
109
17.2k
        OptMap[I.getKey()].Supported = true;
110
535
  }
111
112
8.74k
  void copy(const OpenCLOptions &Opts) {
113
8.74k
    OptMap = Opts.OptMap;
114
8.74k
  }
115
116
  // Turn on or off support of all options.
117
60.1k
  void supportAll(bool On = true) {
118
60.1k
    for (llvm::StringMap<Info>::iterator I = OptMap.begin(),
119
2.58M
         E = OptMap.end(); I != E; 
++I2.52M
)
120
2.52M
      I->second.Supported = On;
121
60.1k
  }
122
123
22
  void disableAll() {
124
22
    for (llvm::StringMap<Info>::iterator I = OptMap.begin(),
125
963
         E = OptMap.end(); I != E; 
++I941
)
126
941
      I->second.Enabled = false;
127
22
  }
128
129
557
  void enableSupportedCore(LangOptions LO) {
130
557
    for (llvm::StringMap<Info>::iterator I = OptMap.begin(), E = OptMap.end();
131
23.9k
         I != E; 
++I23.4k
)
132
23.4k
      if (isSupportedCore(I->getKey(), LO))
133
2.32k
        I->second.Enabled = true;
134
557
  }
135
136
  friend class ASTWriter;
137
  friend class ASTReader;
138
};
139
140
} // end namespace clang
141
142
#endif