• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===--- AnalyzerOptions.h - Analysis Engine Options ------------*- 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 header defines various options for the static analyzer that are set
11 // by the frontend and are consulted throughout the analyzer.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #ifndef LLVM_CLANG_ANALYZEROPTIONS_H
16 #define LLVM_CLANG_ANALYZEROPTIONS_H
17 
18 #include "clang/Basic/LLVM.h"
19 #include "llvm/ADT/IntrusiveRefCntPtr.h"
20 #include "llvm/ADT/Optional.h"
21 #include "llvm/ADT/StringMap.h"
22 #include <string>
23 #include <vector>
24 
25 namespace clang {
26 class ASTConsumer;
27 class DiagnosticsEngine;
28 class Preprocessor;
29 class LangOptions;
30 
31 /// Analysis - Set of available source code analyses.
32 enum Analyses {
33 #define ANALYSIS(NAME, CMDFLAG, DESC, SCOPE) NAME,
34 #include "clang/StaticAnalyzer/Core/Analyses.def"
35 NumAnalyses
36 };
37 
38 /// AnalysisStores - Set of available analysis store models.
39 enum AnalysisStores {
40 #define ANALYSIS_STORE(NAME, CMDFLAG, DESC, CREATFN) NAME##Model,
41 #include "clang/StaticAnalyzer/Core/Analyses.def"
42 NumStores
43 };
44 
45 /// AnalysisConstraints - Set of available constraint models.
46 enum AnalysisConstraints {
47 #define ANALYSIS_CONSTRAINTS(NAME, CMDFLAG, DESC, CREATFN) NAME##Model,
48 #include "clang/StaticAnalyzer/Core/Analyses.def"
49 NumConstraints
50 };
51 
52 /// AnalysisDiagClients - Set of available diagnostic clients for rendering
53 ///  analysis results.
54 enum AnalysisDiagClients {
55 #define ANALYSIS_DIAGNOSTICS(NAME, CMDFLAG, DESC, CREATFN, AUTOCREAT) PD_##NAME,
56 #include "clang/StaticAnalyzer/Core/Analyses.def"
57 NUM_ANALYSIS_DIAG_CLIENTS
58 };
59 
60 /// AnalysisPurgeModes - Set of available strategies for dead symbol removal.
61 enum AnalysisPurgeMode {
62 #define ANALYSIS_PURGE(NAME, CMDFLAG, DESC) NAME,
63 #include "clang/StaticAnalyzer/Core/Analyses.def"
64 NumPurgeModes
65 };
66 
67 /// AnalysisInlineFunctionSelection - Set of inlining function selection heuristics.
68 enum AnalysisInliningMode {
69 #define ANALYSIS_INLINING_MODE(NAME, CMDFLAG, DESC) NAME,
70 #include "clang/StaticAnalyzer/Core/Analyses.def"
71 NumInliningModes
72 };
73 
74 /// \brief Describes the different kinds of C++ member functions which can be
75 /// considered for inlining by the analyzer.
76 ///
77 /// These options are cumulative; enabling one kind of member function will
78 /// enable all kinds with lower enum values.
79 enum CXXInlineableMemberKind {
80   // Uninitialized = 0,
81 
82   /// A dummy mode in which no C++ inlining is enabled.
83   CIMK_None = 1,
84 
85   /// Refers to regular member function and operator calls.
86   CIMK_MemberFunctions,
87 
88   /// Refers to constructors (implicit or explicit).
89   ///
90   /// Note that a constructor will not be inlined if the corresponding
91   /// destructor is non-trivial.
92   CIMK_Constructors,
93 
94   /// Refers to destructors (implicit or explicit).
95   CIMK_Destructors
96 };
97 
98 /// \brief Describes the different modes of inter-procedural analysis.
99 enum IPAKind {
100   IPAK_NotSet = 0,
101 
102   /// Perform only intra-procedural analysis.
103   IPAK_None = 1,
104 
105   /// Inline C functions and blocks when their definitions are available.
106   IPAK_BasicInlining = 2,
107 
108   /// Inline callees(C, C++, ObjC) when their definitions are available.
109   IPAK_Inlining = 3,
110 
111   /// Enable inlining of dynamically dispatched methods.
112   IPAK_DynamicDispatch = 4,
113 
114   /// Enable inlining of dynamically dispatched methods, bifurcate paths when
115   /// exact type info is unavailable.
116   IPAK_DynamicDispatchBifurcate = 5
117 };
118 
119 class AnalyzerOptions : public RefCountedBase<AnalyzerOptions> {
120 public:
121   typedef llvm::StringMap<std::string> ConfigTable;
122 
123   /// \brief Pair of checker name and enable/disable.
124   std::vector<std::pair<std::string, bool> > CheckersControlList;
125 
126   /// \brief A key-value table of use-specified configuration values.
127   ConfigTable Config;
128   AnalysisStores AnalysisStoreOpt;
129   AnalysisConstraints AnalysisConstraintsOpt;
130   AnalysisDiagClients AnalysisDiagOpt;
131   AnalysisPurgeMode AnalysisPurgeOpt;
132 
133   std::string AnalyzeSpecificFunction;
134 
135   /// \brief The maximum number of times the analyzer visits a block.
136   unsigned maxBlockVisitOnPath;
137 
138 
139   unsigned ShowCheckerHelp : 1;
140   unsigned AnalyzeAll : 1;
141   unsigned AnalyzerDisplayProgress : 1;
142   unsigned AnalyzeNestedBlocks : 1;
143 
144   /// \brief The flag regulates if we should eagerly assume evaluations of
145   /// conditionals, thus, bifurcating the path.
146   ///
147   /// This flag indicates how the engine should handle expressions such as: 'x =
148   /// (y != 0)'.  When this flag is true then the subexpression 'y != 0' will be
149   /// eagerly assumed to be true or false, thus evaluating it to the integers 0
150   /// or 1 respectively.  The upside is that this can increase analysis
151   /// precision until we have a better way to lazily evaluate such logic.  The
152   /// downside is that it eagerly bifurcates paths.
153   unsigned eagerlyAssumeBinOpBifurcation : 1;
154 
155   unsigned TrimGraph : 1;
156   unsigned visualizeExplodedGraphWithGraphViz : 1;
157   unsigned visualizeExplodedGraphWithUbiGraph : 1;
158   unsigned UnoptimizedCFG : 1;
159   unsigned PrintStats : 1;
160 
161   /// \brief Do not re-analyze paths leading to exhausted nodes with a different
162   /// strategy. We get better code coverage when retry is enabled.
163   unsigned NoRetryExhausted : 1;
164 
165   /// \brief The inlining stack depth limit.
166   unsigned InlineMaxStackDepth;
167 
168   /// \brief The mode of function selection used during inlining.
169   AnalysisInliningMode InliningMode;
170 
171 private:
172   /// \brief Describes the kinds for high-level analyzer mode.
173   enum UserModeKind {
174     UMK_NotSet = 0,
175     /// Perform shallow but fast analyzes.
176     UMK_Shallow = 1,
177     /// Perform deep analyzes.
178     UMK_Deep = 2
179   };
180 
181   /// Controls the high-level analyzer mode, which influences the default
182   /// settings for some of the lower-level config options (such as IPAMode).
183   /// \sa getUserMode
184   UserModeKind UserMode;
185 
186   /// Controls the mode of inter-procedural analysis.
187   IPAKind IPAMode;
188 
189   /// Controls which C++ member functions will be considered for inlining.
190   CXXInlineableMemberKind CXXMemberInliningMode;
191 
192   /// \sa includeTemporaryDtorsInCFG
193   Optional<bool> IncludeTemporaryDtorsInCFG;
194 
195   /// \sa mayInlineCXXStandardLibrary
196   Optional<bool> InlineCXXStandardLibrary;
197 
198   /// \sa mayInlineTemplateFunctions
199   Optional<bool> InlineTemplateFunctions;
200 
201   /// \sa mayInlineCXXContainerCtorsAndDtors
202   Optional<bool> InlineCXXContainerCtorsAndDtors;
203 
204   /// \sa mayInlineCXXSharedPtrDtor
205   Optional<bool> InlineCXXSharedPtrDtor;
206 
207   /// \sa mayInlineObjCMethod
208   Optional<bool> ObjCInliningMode;
209 
210   // Cache of the "ipa-always-inline-size" setting.
211   // \sa getAlwaysInlineSize
212   Optional<unsigned> AlwaysInlineSize;
213 
214   /// \sa shouldSuppressNullReturnPaths
215   Optional<bool> SuppressNullReturnPaths;
216 
217   // \sa getMaxInlinableSize
218   Optional<unsigned> MaxInlinableSize;
219 
220   /// \sa shouldAvoidSuppressingNullArgumentPaths
221   Optional<bool> AvoidSuppressingNullArgumentPaths;
222 
223   /// \sa shouldSuppressInlinedDefensiveChecks
224   Optional<bool> SuppressInlinedDefensiveChecks;
225 
226   /// \sa shouldSuppressFromCXXStandardLibrary
227   Optional<bool> SuppressFromCXXStandardLibrary;
228 
229   /// \sa reportIssuesInMainSourceFile
230   Optional<bool> ReportIssuesInMainSourceFile;
231 
232   /// \sa getGraphTrimInterval
233   Optional<unsigned> GraphTrimInterval;
234 
235   /// \sa getMaxTimesInlineLarge
236   Optional<unsigned> MaxTimesInlineLarge;
237 
238   /// \sa getMaxNodesPerTopLevelFunction
239   Optional<unsigned> MaxNodesPerTopLevelFunction;
240 
241 public:
242   /// Interprets an option's string value as a boolean.
243   ///
244   /// Accepts the strings "true" and "false".
245   /// If an option value is not provided, returns the given \p DefaultVal.
246   bool getBooleanOption(StringRef Name, bool DefaultVal);
247 
248   /// Variant that accepts a Optional value to cache the result.
249   bool getBooleanOption(Optional<bool> &V, StringRef Name, bool DefaultVal);
250 
251   /// Interprets an option's string value as an integer value.
252   int getOptionAsInteger(StringRef Name, int DefaultVal);
253 
254   /// \brief Retrieves and sets the UserMode. This is a high-level option,
255   /// which is used to set other low-level options. It is not accessible
256   /// outside of AnalyzerOptions.
257   UserModeKind getUserMode();
258 
259   /// \brief Returns the inter-procedural analysis mode.
260   IPAKind getIPAMode();
261 
262   /// Returns the option controlling which C++ member functions will be
263   /// considered for inlining.
264   ///
265   /// This is controlled by the 'c++-inlining' config option.
266   ///
267   /// \sa CXXMemberInliningMode
268   bool mayInlineCXXMemberFunction(CXXInlineableMemberKind K);
269 
270   /// Returns true if ObjectiveC inlining is enabled, false otherwise.
271   bool mayInlineObjCMethod();
272 
273   /// Returns whether or not the destructors for C++ temporary objects should
274   /// be included in the CFG.
275   ///
276   /// This is controlled by the 'cfg-temporary-dtors' config option, which
277   /// accepts the values "true" and "false".
278   bool includeTemporaryDtorsInCFG();
279 
280   /// Returns whether or not C++ standard library functions may be considered
281   /// for inlining.
282   ///
283   /// This is controlled by the 'c++-stdlib-inlining' config option, which
284   /// accepts the values "true" and "false".
285   bool mayInlineCXXStandardLibrary();
286 
287   /// Returns whether or not templated functions may be considered for inlining.
288   ///
289   /// This is controlled by the 'c++-template-inlining' config option, which
290   /// accepts the values "true" and "false".
291   bool mayInlineTemplateFunctions();
292 
293   /// Returns whether or not constructors and destructors of C++ container
294   /// objects may be considered for inlining.
295   ///
296   /// This is controlled by the 'c++-container-inlining' config option, which
297   /// accepts the values "true" and "false".
298   bool mayInlineCXXContainerCtorsAndDtors();
299 
300   /// Returns whether or not the destructor of C++ 'shared_ptr' may be
301   /// considered for inlining.
302   ///
303   /// This covers std::shared_ptr, std::tr1::shared_ptr, and boost::shared_ptr,
304   /// and indeed any destructor named "~shared_ptr".
305   ///
306   /// This is controlled by the 'c++-shared_ptr-inlining' config option, which
307   /// accepts the values "true" and "false".
308   bool mayInlineCXXSharedPtrDtor();
309 
310   /// Returns whether or not paths that go through null returns should be
311   /// suppressed.
312   ///
313   /// This is a heuristic for avoiding bug reports with paths that go through
314   /// inlined functions that are more defensive than their callers.
315   ///
316   /// This is controlled by the 'suppress-null-return-paths' config option,
317   /// which accepts the values "true" and "false".
318   bool shouldSuppressNullReturnPaths();
319 
320   /// Returns whether a bug report should \em not be suppressed if its path
321   /// includes a call with a null argument, even if that call has a null return.
322   ///
323   /// This option has no effect when #shouldSuppressNullReturnPaths() is false.
324   ///
325   /// This is a counter-heuristic to avoid false negatives.
326   ///
327   /// This is controlled by the 'avoid-suppressing-null-argument-paths' config
328   /// option, which accepts the values "true" and "false".
329   bool shouldAvoidSuppressingNullArgumentPaths();
330 
331   /// Returns whether or not diagnostics containing inlined defensive NULL
332   /// checks should be suppressed.
333   ///
334   /// This is controlled by the 'suppress-inlined-defensive-checks' config
335   /// option, which accepts the values "true" and "false".
336   bool shouldSuppressInlinedDefensiveChecks();
337 
338   /// Returns whether or not diagnostics reported within the C++ standard
339   /// library should be suppressed.
340   ///
341   /// This is controlled by the 'suppress-c++-stdlib' config option,
342   /// which accepts the values "true" and "false".
343   bool shouldSuppressFromCXXStandardLibrary();
344 
345   /// Returns whether or not the diagnostic report should be always reported
346   /// in the main source file and not the headers.
347   ///
348   /// This is controlled by the 'report-in-main-source-file' config option,
349   /// which accepts the values "true" and "false".
350   bool shouldReportIssuesInMainSourceFile();
351 
352   /// Returns whether irrelevant parts of a bug report path should be pruned
353   /// out of the final output.
354   ///
355   /// This is controlled by the 'prune-paths' config option, which accepts the
356   /// values "true" and "false".
357   bool shouldPrunePaths();
358 
359   /// Returns true if 'static' initializers should be in conditional logic
360   /// in the CFG.
361   bool shouldConditionalizeStaticInitializers();
362 
363   // Returns the size of the functions (in basic blocks), which should be
364   // considered to be small enough to always inline.
365   //
366   // This is controlled by "ipa-always-inline-size" analyzer-config option.
367   unsigned getAlwaysInlineSize();
368 
369   // Returns the bound on the number of basic blocks in an inlined function
370   // (50 by default).
371   //
372   // This is controlled by "-analyzer-config max-inlinable-size" option.
373   unsigned getMaxInlinableSize();
374 
375   /// Returns true if the analyzer engine should synthesize fake bodies
376   /// for well-known functions.
377   bool shouldSynthesizeBodies();
378 
379   /// Returns how often nodes in the ExplodedGraph should be recycled to save
380   /// memory.
381   ///
382   /// This is controlled by the 'graph-trim-interval' config option. To disable
383   /// node reclamation, set the option to "0".
384   unsigned getGraphTrimInterval();
385 
386   /// Returns the maximum times a large function could be inlined.
387   ///
388   /// This is controlled by the 'max-times-inline-large' config option.
389   unsigned getMaxTimesInlineLarge();
390 
391   /// Returns the maximum number of nodes the analyzer can generate while
392   /// exploring a top level function (for each exploded graph).
393   /// 150000 is default; 0 means no limit.
394   ///
395   /// This is controlled by the 'max-nodes' config option.
396   unsigned getMaxNodesPerTopLevelFunction();
397 
398 public:
AnalyzerOptions()399   AnalyzerOptions() :
400     AnalysisStoreOpt(RegionStoreModel),
401     AnalysisConstraintsOpt(RangeConstraintsModel),
402     AnalysisDiagOpt(PD_HTML),
403     AnalysisPurgeOpt(PurgeStmt),
404     ShowCheckerHelp(0),
405     AnalyzeAll(0),
406     AnalyzerDisplayProgress(0),
407     AnalyzeNestedBlocks(0),
408     eagerlyAssumeBinOpBifurcation(0),
409     TrimGraph(0),
410     visualizeExplodedGraphWithGraphViz(0),
411     visualizeExplodedGraphWithUbiGraph(0),
412     UnoptimizedCFG(0),
413     PrintStats(0),
414     NoRetryExhausted(0),
415     // Cap the stack depth at 4 calls (5 stack frames, base + 4 calls).
416     InlineMaxStackDepth(5),
417     InliningMode(NoRedundancy),
418     UserMode(UMK_NotSet),
419     IPAMode(IPAK_NotSet),
420     CXXMemberInliningMode() {}
421 
422 };
423 
424 typedef IntrusiveRefCntPtr<AnalyzerOptions> AnalyzerOptionsRef;
425 
426 }
427 
428 #endif
429