• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2011 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ART_COMPILER_DRIVER_COMPILER_DRIVER_H_
18 #define ART_COMPILER_DRIVER_COMPILER_DRIVER_H_
19 
20 #include <set>
21 #include <string>
22 #include <unordered_set>
23 #include <vector>
24 
25 #include "arch/instruction_set.h"
26 #include "base/arena_allocator.h"
27 #include "base/bit_utils.h"
28 #include "base/mutex.h"
29 #include "base/timing_logger.h"
30 #include "class_reference.h"
31 #include "compiler.h"
32 #include "dex_file.h"
33 #include "driver/compiled_method_storage.h"
34 #include "jit/offline_profiling_info.h"
35 #include "invoke_type.h"
36 #include "method_reference.h"
37 #include "mirror/class.h"  // For mirror::Class::Status.
38 #include "os.h"
39 #include "runtime.h"
40 #include "safe_map.h"
41 #include "thread_pool.h"
42 #include "utils/array_ref.h"
43 #include "utils/dex_cache_arrays_layout.h"
44 
45 namespace art {
46 
47 namespace mirror {
48 class DexCache;
49 }  // namespace mirror
50 
51 namespace verifier {
52 class MethodVerifier;
53 }  // namespace verifier
54 
55 class BitVector;
56 class CompiledClass;
57 class CompiledMethod;
58 class CompilerOptions;
59 class DexCompilationUnit;
60 class DexFileToMethodInlinerMap;
61 struct InlineIGetIPutData;
62 class InstructionSetFeatures;
63 class ParallelCompilationManager;
64 class ScopedObjectAccess;
65 template <class Allocator> class SrcMap;
66 class SrcMapElem;
67 using SwapSrcMap = SrcMap<SwapAllocator<SrcMapElem>>;
68 template<class T> class Handle;
69 class TimingLogger;
70 class VerificationResults;
71 class VerifiedMethod;
72 
73 enum EntryPointCallingConvention {
74   // ABI of invocations to a method's interpreter entry point.
75   kInterpreterAbi,
76   // ABI of calls to a method's native code, only used for native methods.
77   kJniAbi,
78   // ABI of calls to a method's quick code entry point.
79   kQuickAbi
80 };
81 
82 class CompilerDriver {
83  public:
84   // Create a compiler targeting the requested "instruction_set".
85   // "image" should be true if image specific optimizations should be
86   // enabled.  "image_classes" lets the compiler know what classes it
87   // can assume will be in the image, with null implying all available
88   // classes.
89   CompilerDriver(const CompilerOptions* compiler_options,
90                  VerificationResults* verification_results,
91                  DexFileToMethodInlinerMap* method_inliner_map,
92                  Compiler::Kind compiler_kind,
93                  InstructionSet instruction_set,
94                  const InstructionSetFeatures* instruction_set_features,
95                  bool boot_image,
96                  bool app_image,
97                  std::unordered_set<std::string>* image_classes,
98                  std::unordered_set<std::string>* compiled_classes,
99                  std::unordered_set<std::string>* compiled_methods,
100                  size_t thread_count,
101                  bool dump_stats,
102                  bool dump_passes,
103                  CumulativeLogger* timer,
104                  int swap_fd,
105                  const ProfileCompilationInfo* profile_compilation_info);
106 
107   ~CompilerDriver();
108 
109   // Set dex files that will be stored in the oat file after being compiled.
SetDexFilesForOatFile(const std::vector<const DexFile * > & dex_files)110   void SetDexFilesForOatFile(const std::vector<const DexFile*>& dex_files) {
111     dex_files_for_oat_file_ = &dex_files;
112   }
113 
114   // Get dex file that will be stored in the oat file after being compiled.
GetDexFilesForOatFile()115   ArrayRef<const DexFile* const> GetDexFilesForOatFile() const {
116     return (dex_files_for_oat_file_ != nullptr)
117         ? ArrayRef<const DexFile* const>(*dex_files_for_oat_file_)
118         : ArrayRef<const DexFile* const>();
119   }
120 
121   void CompileAll(jobject class_loader,
122                   const std::vector<const DexFile*>& dex_files,
123                   TimingLogger* timings)
124       REQUIRES(!Locks::mutator_lock_, !compiled_classes_lock_, !dex_to_dex_references_lock_);
125 
126   // Compile a single Method.
127   void CompileOne(Thread* self, ArtMethod* method, TimingLogger* timings)
128       SHARED_REQUIRES(Locks::mutator_lock_)
129       REQUIRES(!compiled_methods_lock_, !compiled_classes_lock_, !dex_to_dex_references_lock_);
130 
GetVerificationResults()131   VerificationResults* GetVerificationResults() const {
132     DCHECK(Runtime::Current()->IsAotCompiler());
133     return verification_results_;
134   }
135 
GetMethodInlinerMap()136   DexFileToMethodInlinerMap* GetMethodInlinerMap() const {
137     return method_inliner_map_;
138   }
139 
GetInstructionSet()140   InstructionSet GetInstructionSet() const {
141     return instruction_set_;
142   }
143 
GetInstructionSetFeatures()144   const InstructionSetFeatures* GetInstructionSetFeatures() const {
145     return instruction_set_features_;
146   }
147 
GetCompilerOptions()148   const CompilerOptions& GetCompilerOptions() const {
149     return *compiler_options_;
150   }
151 
GetCompiler()152   Compiler* GetCompiler() const {
153     return compiler_.get();
154   }
155 
156   // Are we compiling and creating an image file?
IsBootImage()157   bool IsBootImage() const {
158     return boot_image_;
159   }
160 
GetImageClasses()161   const std::unordered_set<std::string>* GetImageClasses() const {
162     return image_classes_.get();
163   }
164 
165   // Generate the trampolines that are invoked by unresolved direct methods.
166   std::unique_ptr<const std::vector<uint8_t>> CreateJniDlsymLookup() const;
167   std::unique_ptr<const std::vector<uint8_t>> CreateQuickGenericJniTrampoline() const;
168   std::unique_ptr<const std::vector<uint8_t>> CreateQuickImtConflictTrampoline() const;
169   std::unique_ptr<const std::vector<uint8_t>> CreateQuickResolutionTrampoline() const;
170   std::unique_ptr<const std::vector<uint8_t>> CreateQuickToInterpreterBridge() const;
171 
172   CompiledClass* GetCompiledClass(ClassReference ref) const
173       REQUIRES(!compiled_classes_lock_);
174 
175   CompiledMethod* GetCompiledMethod(MethodReference ref) const
176       REQUIRES(!compiled_methods_lock_);
177   size_t GetNonRelativeLinkerPatchCount() const
178       REQUIRES(!compiled_methods_lock_);
179 
180   // Add a compiled method.
181   void AddCompiledMethod(const MethodReference& method_ref,
182                          CompiledMethod* const compiled_method,
183                          size_t non_relative_linker_patch_count)
184       REQUIRES(!compiled_methods_lock_);
185   // Remove and delete a compiled method.
186   void RemoveCompiledMethod(const MethodReference& method_ref) REQUIRES(!compiled_methods_lock_);
187 
188   void SetRequiresConstructorBarrier(Thread* self,
189                                      const DexFile* dex_file,
190                                      uint16_t class_def_index,
191                                      bool requires)
192       REQUIRES(!requires_constructor_barrier_lock_);
193   bool RequiresConstructorBarrier(Thread* self,
194                                   const DexFile* dex_file,
195                                   uint16_t class_def_index)
196       REQUIRES(!requires_constructor_barrier_lock_);
197 
198   // Callbacks from compiler to see what runtime checks must be generated.
199 
200   bool CanAssumeTypeIsPresentInDexCache(Handle<mirror::DexCache> dex_cache,
201                                         uint32_t type_idx)
202       SHARED_REQUIRES(Locks::mutator_lock_);
203 
204   bool CanAssumeStringIsPresentInDexCache(const DexFile& dex_file, uint32_t string_idx)
205       REQUIRES(!Locks::mutator_lock_);
206 
207   // Are runtime access checks necessary in the compiled code?
208   bool CanAccessTypeWithoutChecks(uint32_t referrer_idx,
209                                   Handle<mirror::DexCache> dex_cache,
210                                   uint32_t type_idx)
211       SHARED_REQUIRES(Locks::mutator_lock_);
212 
213   // Are runtime access and instantiable checks necessary in the code?
214   // out_is_finalizable is set to whether the type is finalizable.
215   bool CanAccessInstantiableTypeWithoutChecks(uint32_t referrer_idx,
216                                               Handle<mirror::DexCache> dex_cache,
217                                               uint32_t type_idx,
218                                               bool* out_is_finalizable)
219       SHARED_REQUIRES(Locks::mutator_lock_);
220 
221   bool CanEmbedTypeInCode(const DexFile& dex_file, uint32_t type_idx,
222                           bool* is_type_initialized, bool* use_direct_type_ptr,
223                           uintptr_t* direct_type_ptr, bool* out_is_finalizable);
224 
225   // Query methods for the java.lang.ref.Reference class.
226   bool CanEmbedReferenceTypeInCode(ClassReference* ref,
227                                    bool* use_direct_type_ptr, uintptr_t* direct_type_ptr);
228   uint32_t GetReferenceSlowFlagOffset() const;
229   uint32_t GetReferenceDisableFlagOffset() const;
230 
231   // Get the DexCache for the
232   mirror::DexCache* GetDexCache(const DexCompilationUnit* mUnit)
233     SHARED_REQUIRES(Locks::mutator_lock_);
234 
235   mirror::ClassLoader* GetClassLoader(const ScopedObjectAccess& soa,
236                                       const DexCompilationUnit* mUnit)
237     SHARED_REQUIRES(Locks::mutator_lock_);
238 
239   // Resolve compiling method's class. Returns null on failure.
240   mirror::Class* ResolveCompilingMethodsClass(
241       const ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
242       Handle<mirror::ClassLoader> class_loader, const DexCompilationUnit* mUnit)
243       SHARED_REQUIRES(Locks::mutator_lock_);
244 
245   mirror::Class* ResolveClass(
246       const ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
247       Handle<mirror::ClassLoader> class_loader, uint16_t type_index,
248       const DexCompilationUnit* mUnit)
249       SHARED_REQUIRES(Locks::mutator_lock_);
250 
251   // Resolve a field. Returns null on failure, including incompatible class change.
252   // NOTE: Unlike ClassLinker's ResolveField(), this method enforces is_static.
253   ArtField* ResolveField(
254       const ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
255       Handle<mirror::ClassLoader> class_loader, const DexCompilationUnit* mUnit,
256       uint32_t field_idx, bool is_static)
257       SHARED_REQUIRES(Locks::mutator_lock_);
258 
259   // Resolve a field with a given dex file.
260   ArtField* ResolveFieldWithDexFile(
261       const ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
262       Handle<mirror::ClassLoader> class_loader, const DexFile* dex_file,
263       uint32_t field_idx, bool is_static)
264       SHARED_REQUIRES(Locks::mutator_lock_);
265 
266   // Get declaration location of a resolved field.
267   void GetResolvedFieldDexFileLocation(
268       ArtField* resolved_field, const DexFile** declaring_dex_file,
269       uint16_t* declaring_class_idx, uint16_t* declaring_field_idx)
270       SHARED_REQUIRES(Locks::mutator_lock_);
271 
272   bool IsFieldVolatile(ArtField* field) SHARED_REQUIRES(Locks::mutator_lock_);
273   MemberOffset GetFieldOffset(ArtField* field) SHARED_REQUIRES(Locks::mutator_lock_);
274 
275   // Find a dex cache for a dex file.
276   inline mirror::DexCache* FindDexCache(const DexFile* dex_file)
277       SHARED_REQUIRES(Locks::mutator_lock_);
278 
279   // Can we fast-path an IGET/IPUT access to an instance field? If yes, compute the field offset.
280   std::pair<bool, bool> IsFastInstanceField(
281       mirror::DexCache* dex_cache, mirror::Class* referrer_class,
282       ArtField* resolved_field, uint16_t field_idx)
283       SHARED_REQUIRES(Locks::mutator_lock_);
284 
285   // Can we fast-path an SGET/SPUT access to a static field? If yes, compute the type index
286   // of the declaring class in the referrer's dex file.
287   std::pair<bool, bool> IsFastStaticField(
288       mirror::DexCache* dex_cache, mirror::Class* referrer_class,
289       ArtField* resolved_field, uint16_t field_idx, uint32_t* storage_index)
290       SHARED_REQUIRES(Locks::mutator_lock_);
291 
292   // Return whether the declaring class of `resolved_method` is
293   // available to `referrer_class`. If this is true, compute the type
294   // index of the declaring class in the referrer's dex file and
295   // return it through the out argument `storage_index`; otherwise
296   // return DexFile::kDexNoIndex through `storage_index`.
297   bool IsClassOfStaticMethodAvailableToReferrer(mirror::DexCache* dex_cache,
298                                                 mirror::Class* referrer_class,
299                                                 ArtMethod* resolved_method,
300                                                 uint16_t method_idx,
301                                                 uint32_t* storage_index)
302       SHARED_REQUIRES(Locks::mutator_lock_);
303 
304   // Is static field's in referrer's class?
305   bool IsStaticFieldInReferrerClass(mirror::Class* referrer_class, ArtField* resolved_field)
306       SHARED_REQUIRES(Locks::mutator_lock_);
307 
308   // Is static field's class initialized?
309   bool IsStaticFieldsClassInitialized(mirror::Class* referrer_class,
310                                       ArtField* resolved_field)
311       SHARED_REQUIRES(Locks::mutator_lock_);
312 
313   // Resolve a method. Returns null on failure, including incompatible class change.
314   ArtMethod* ResolveMethod(
315       ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
316       Handle<mirror::ClassLoader> class_loader, const DexCompilationUnit* mUnit,
317       uint32_t method_idx, InvokeType invoke_type, bool check_incompatible_class_change = true)
318       SHARED_REQUIRES(Locks::mutator_lock_);
319 
320   // Get declaration location of a resolved field.
321   void GetResolvedMethodDexFileLocation(
322       ArtMethod* resolved_method, const DexFile** declaring_dex_file,
323       uint16_t* declaring_class_idx, uint16_t* declaring_method_idx)
324       SHARED_REQUIRES(Locks::mutator_lock_);
325 
326   // Get the index in the vtable of the method.
327   uint16_t GetResolvedMethodVTableIndex(
328       ArtMethod* resolved_method, InvokeType type)
329       SHARED_REQUIRES(Locks::mutator_lock_);
330 
331   // Can we fast-path an INVOKE? If no, returns 0. If yes, returns a non-zero opaque flags value
332   // for ProcessedInvoke() and computes the necessary lowering info.
333   int IsFastInvoke(
334       ScopedObjectAccess& soa, Handle<mirror::DexCache> dex_cache,
335       Handle<mirror::ClassLoader> class_loader, const DexCompilationUnit* mUnit,
336       mirror::Class* referrer_class, ArtMethod* resolved_method, InvokeType* invoke_type,
337       MethodReference* target_method, const MethodReference* devirt_target,
338       uintptr_t* direct_code, uintptr_t* direct_method)
339       SHARED_REQUIRES(Locks::mutator_lock_);
340 
341   // Is method's class initialized for an invoke?
342   // For static invokes to determine whether we need to consider potential call to <clinit>().
343   // For non-static invokes, assuming a non-null reference, the class is always initialized.
344   bool IsMethodsClassInitialized(mirror::Class* referrer_class, ArtMethod* resolved_method)
345       SHARED_REQUIRES(Locks::mutator_lock_);
346 
347   // Get the layout of dex cache arrays for a dex file. Returns invalid layout if the
348   // dex cache arrays don't have a fixed layout.
349   DexCacheArraysLayout GetDexCacheArraysLayout(const DexFile* dex_file);
350 
351   void ProcessedInstanceField(bool resolved);
352   void ProcessedStaticField(bool resolved, bool local);
353   void ProcessedInvoke(InvokeType invoke_type, int flags);
354 
355   void ComputeFieldInfo(uint32_t field_idx, const DexCompilationUnit* mUnit,
356                         const ScopedObjectAccess& soa, bool is_static,
357                         ArtField** resolved_field,
358                         mirror::Class** referrer_class,
359                         mirror::DexCache** dex_cache)
360       SHARED_REQUIRES(Locks::mutator_lock_);
361 
362   // Can we fast path instance field access? Computes field's offset and volatility.
363   bool ComputeInstanceFieldInfo(uint32_t field_idx, const DexCompilationUnit* mUnit, bool is_put,
364                                 MemberOffset* field_offset, bool* is_volatile)
365       REQUIRES(!Locks::mutator_lock_);
366 
367   ArtField* ComputeInstanceFieldInfo(uint32_t field_idx,
368                                              const DexCompilationUnit* mUnit,
369                                              bool is_put,
370                                              const ScopedObjectAccess& soa)
371       SHARED_REQUIRES(Locks::mutator_lock_);
372 
373 
374   // Can we fastpath a interface, super class or virtual method call? Computes method's vtable
375   // index.
376   bool ComputeInvokeInfo(const DexCompilationUnit* mUnit, const uint32_t dex_pc,
377                          bool update_stats, bool enable_devirtualization,
378                          InvokeType* type, MethodReference* target_method, int* vtable_idx,
379                          uintptr_t* direct_code, uintptr_t* direct_method)
380       REQUIRES(!Locks::mutator_lock_);
381 
382   const VerifiedMethod* GetVerifiedMethod(const DexFile* dex_file, uint32_t method_idx) const;
383   bool IsSafeCast(const DexCompilationUnit* mUnit, uint32_t dex_pc);
384 
GetSupportBootImageFixup()385   bool GetSupportBootImageFixup() const {
386     return support_boot_image_fixup_;
387   }
388 
SetSupportBootImageFixup(bool support_boot_image_fixup)389   void SetSupportBootImageFixup(bool support_boot_image_fixup) {
390     support_boot_image_fixup_ = support_boot_image_fixup;
391   }
392 
SetCompilerContext(void * compiler_context)393   void SetCompilerContext(void* compiler_context) {
394     compiler_context_ = compiler_context;
395   }
396 
GetCompilerContext()397   void* GetCompilerContext() const {
398     return compiler_context_;
399   }
400 
GetThreadCount()401   size_t GetThreadCount() const {
402     return parallel_thread_count_;
403   }
404 
GetDumpStats()405   bool GetDumpStats() const {
406     return dump_stats_;
407   }
408 
GetDumpPasses()409   bool GetDumpPasses() const {
410     return dump_passes_;
411   }
412 
GetTimingsLogger()413   CumulativeLogger* GetTimingsLogger() const {
414     return timings_logger_;
415   }
416 
SetDedupeEnabled(bool dedupe_enabled)417   void SetDedupeEnabled(bool dedupe_enabled) {
418     compiled_method_storage_.SetDedupeEnabled(dedupe_enabled);
419   }
DedupeEnabled()420   bool DedupeEnabled() const {
421     return compiled_method_storage_.DedupeEnabled();
422   }
423 
424   // Checks if class specified by type_idx is one of the image_classes_
425   bool IsImageClass(const char* descriptor) const;
426 
427   // Checks whether the provided class should be compiled, i.e., is in classes_to_compile_.
428   bool IsClassToCompile(const char* descriptor) const;
429 
430   // Checks whether the provided method should be compiled, i.e., is in method_to_compile_.
431   bool IsMethodToCompile(const MethodReference& method_ref) const;
432 
433   // Checks whether profile guided compilation is enabled and if the method should be compiled
434   // according to the profile file.
435   bool ShouldCompileBasedOnProfile(const MethodReference& method_ref) const;
436 
437   // Checks whether profile guided verification is enabled and if the method should be verified
438   // according to the profile file.
439   bool ShouldVerifyClassBasedOnProfile(const DexFile& dex_file, uint16_t class_idx) const;
440 
441   void RecordClassStatus(ClassReference ref, mirror::Class::Status status)
442       REQUIRES(!compiled_classes_lock_);
443 
444   // Checks if the specified method has been verified without failures. Returns
445   // false if the method is not in the verification results (GetVerificationResults).
446   bool IsMethodVerifiedWithoutFailures(uint32_t method_idx,
447                                        uint16_t class_def_idx,
448                                        const DexFile& dex_file) const;
449 
450   // Get memory usage during compilation.
451   std::string GetMemoryUsageString(bool extended) const;
452 
453   bool IsStringTypeIndex(uint16_t type_index, const DexFile* dex_file);
454   bool IsStringInit(uint32_t method_index, const DexFile* dex_file, int32_t* offset);
455 
SetHadHardVerifierFailure()456   void SetHadHardVerifierFailure() {
457     had_hard_verifier_failure_ = true;
458   }
459 
GetCompilerKind()460   Compiler::Kind GetCompilerKind() {
461     return compiler_kind_;
462   }
463 
GetCompiledMethodStorage()464   CompiledMethodStorage* GetCompiledMethodStorage() {
465     return &compiled_method_storage_;
466   }
467 
468   // Can we assume that the klass is loaded?
469   bool CanAssumeClassIsLoaded(mirror::Class* klass)
470       SHARED_REQUIRES(Locks::mutator_lock_);
471 
MayInline(const DexFile * inlined_from,const DexFile * inlined_into)472   bool MayInline(const DexFile* inlined_from, const DexFile* inlined_into) const {
473     if (!kIsTargetBuild) {
474       return MayInlineInternal(inlined_from, inlined_into);
475     }
476     return true;
477   }
478 
479   void MarkForDexToDexCompilation(Thread* self, const MethodReference& method_ref)
480       REQUIRES(!dex_to_dex_references_lock_);
481 
GetCurrentDexToDexMethods()482   const BitVector* GetCurrentDexToDexMethods() const {
483     return current_dex_to_dex_methods_;
484   }
485 
486  private:
487   // Return whether the declaring class of `resolved_member` is
488   // available to `referrer_class` for read or write access using two
489   // Boolean values returned as a pair. If is true at least for read
490   // access, compute the type index of the declaring class in the
491   // referrer's dex file and return it through the out argument
492   // `storage_index`; otherwise return DexFile::kDexNoIndex through
493   // `storage_index`.
494   template <typename ArtMember>
495   std::pair<bool, bool> IsClassOfStaticMemberAvailableToReferrer(mirror::DexCache* dex_cache,
496                                                                  mirror::Class* referrer_class,
497                                                                  ArtMember* resolved_member,
498                                                                  uint16_t member_idx,
499                                                                  uint32_t* storage_index)
500       SHARED_REQUIRES(Locks::mutator_lock_);
501 
502   // Can `referrer_class` access the resolved `member`?
503   // Dispatch call to mirror::Class::CanAccessResolvedField or
504   // mirror::Class::CanAccessResolvedMember depending on the value of
505   // ArtMember.
506   template <typename ArtMember>
507   static bool CanAccessResolvedMember(mirror::Class* referrer_class,
508                                       mirror::Class* access_to,
509                                       ArtMember* member,
510                                       mirror::DexCache* dex_cache,
511                                       uint32_t field_idx)
512       SHARED_REQUIRES(Locks::mutator_lock_);
513 
514   // Can we assume that the klass is initialized?
515   bool CanAssumeClassIsInitialized(mirror::Class* klass)
516       SHARED_REQUIRES(Locks::mutator_lock_);
517   bool CanReferrerAssumeClassIsInitialized(mirror::Class* referrer_class, mirror::Class* klass)
518       SHARED_REQUIRES(Locks::mutator_lock_);
519 
520   // These flags are internal to CompilerDriver for collecting INVOKE resolution statistics.
521   // The only external contract is that unresolved method has flags 0 and resolved non-0.
522   enum {
523     kBitMethodResolved = 0,
524     kBitVirtualMadeDirect,
525     kBitPreciseTypeDevirtualization,
526     kBitDirectCallToBoot,
527     kBitDirectMethodToBoot
528   };
529   static constexpr int kFlagMethodResolved              = 1 << kBitMethodResolved;
530   static constexpr int kFlagVirtualMadeDirect           = 1 << kBitVirtualMadeDirect;
531   static constexpr int kFlagPreciseTypeDevirtualization = 1 << kBitPreciseTypeDevirtualization;
532   static constexpr int kFlagDirectCallToBoot            = 1 << kBitDirectCallToBoot;
533   static constexpr int kFlagDirectMethodToBoot          = 1 << kBitDirectMethodToBoot;
534   static constexpr int kFlagsMethodResolvedVirtualMadeDirect =
535       kFlagMethodResolved | kFlagVirtualMadeDirect;
536   static constexpr int kFlagsMethodResolvedPreciseTypeDevirtualization =
537       kFlagsMethodResolvedVirtualMadeDirect | kFlagPreciseTypeDevirtualization;
538 
539  public:  // TODO make private or eliminate.
540   // Compute constant code and method pointers when possible.
541   void GetCodeAndMethodForDirectCall(/*out*/InvokeType* type,
542                                      InvokeType sharp_type,
543                                      bool no_guarantee_of_dex_cache_entry,
544                                      const mirror::Class* referrer_class,
545                                      ArtMethod* method,
546                                      /*out*/int* stats_flags,
547                                      MethodReference* target_method,
548                                      uintptr_t* direct_code, uintptr_t* direct_method)
549       SHARED_REQUIRES(Locks::mutator_lock_);
550 
551  private:
552   void PreCompile(jobject class_loader,
553                   const std::vector<const DexFile*>& dex_files,
554                   TimingLogger* timings)
555       REQUIRES(!Locks::mutator_lock_, !compiled_classes_lock_);
556 
557   void LoadImageClasses(TimingLogger* timings) REQUIRES(!Locks::mutator_lock_);
558 
559   // Attempt to resolve all type, methods, fields, and strings
560   // referenced from code in the dex file following PathClassLoader
561   // ordering semantics.
562   void Resolve(jobject class_loader,
563                const std::vector<const DexFile*>& dex_files,
564                TimingLogger* timings)
565       REQUIRES(!Locks::mutator_lock_);
566   void ResolveDexFile(jobject class_loader,
567                       const DexFile& dex_file,
568                       const std::vector<const DexFile*>& dex_files,
569                       ThreadPool* thread_pool,
570                       size_t thread_count,
571                       TimingLogger* timings)
572       REQUIRES(!Locks::mutator_lock_);
573 
574   void Verify(jobject class_loader,
575               const std::vector<const DexFile*>& dex_files,
576               TimingLogger* timings);
577   void VerifyDexFile(jobject class_loader,
578                      const DexFile& dex_file,
579                      const std::vector<const DexFile*>& dex_files,
580                      ThreadPool* thread_pool,
581                      size_t thread_count,
582                      TimingLogger* timings)
583       REQUIRES(!Locks::mutator_lock_);
584 
585   void SetVerified(jobject class_loader,
586                    const std::vector<const DexFile*>& dex_files,
587                    TimingLogger* timings);
588   void SetVerifiedDexFile(jobject class_loader,
589                           const DexFile& dex_file,
590                           const std::vector<const DexFile*>& dex_files,
591                           ThreadPool* thread_pool,
592                           size_t thread_count,
593                           TimingLogger* timings)
594       REQUIRES(!Locks::mutator_lock_);
595 
596   void InitializeClasses(jobject class_loader,
597                          const std::vector<const DexFile*>& dex_files,
598                          TimingLogger* timings)
599       REQUIRES(!Locks::mutator_lock_, !compiled_classes_lock_);
600   void InitializeClasses(jobject class_loader,
601                          const DexFile& dex_file,
602                          const std::vector<const DexFile*>& dex_files,
603                          TimingLogger* timings)
604       REQUIRES(!Locks::mutator_lock_, !compiled_classes_lock_);
605 
606   void UpdateImageClasses(TimingLogger* timings) REQUIRES(!Locks::mutator_lock_);
607   static void FindClinitImageClassesCallback(mirror::Object* object, void* arg)
608       SHARED_REQUIRES(Locks::mutator_lock_);
609 
610   void Compile(jobject class_loader,
611                const std::vector<const DexFile*>& dex_files,
612                TimingLogger* timings) REQUIRES(!dex_to_dex_references_lock_);
613   void CompileDexFile(jobject class_loader,
614                       const DexFile& dex_file,
615                       const std::vector<const DexFile*>& dex_files,
616                       ThreadPool* thread_pool,
617                       size_t thread_count,
618                       TimingLogger* timings)
619       REQUIRES(!Locks::mutator_lock_);
620 
621   bool MayInlineInternal(const DexFile* inlined_from, const DexFile* inlined_into) const;
622 
623   void InitializeThreadPools();
624   void FreeThreadPools();
625   void CheckThreadPools();
626 
627   bool RequiresConstructorBarrier(const DexFile& dex_file, uint16_t class_def_idx) const;
628 
629   const CompilerOptions* const compiler_options_;
630   VerificationResults* const verification_results_;
631   DexFileToMethodInlinerMap* const method_inliner_map_;
632 
633   std::unique_ptr<Compiler> compiler_;
634   Compiler::Kind compiler_kind_;
635 
636   const InstructionSet instruction_set_;
637   const InstructionSetFeatures* const instruction_set_features_;
638 
639   // All class references that require constructor barriers. If the class reference is not in the
640   // set then the result has not yet been computed.
641   mutable ReaderWriterMutex requires_constructor_barrier_lock_ DEFAULT_MUTEX_ACQUIRED_AFTER;
642   std::map<ClassReference, bool> requires_constructor_barrier_
643       GUARDED_BY(requires_constructor_barrier_lock_);
644 
645   typedef SafeMap<const ClassReference, CompiledClass*> ClassTable;
646   // All class references that this compiler has compiled.
647   mutable Mutex compiled_classes_lock_ DEFAULT_MUTEX_ACQUIRED_AFTER;
648   ClassTable compiled_classes_ GUARDED_BY(compiled_classes_lock_);
649 
650   typedef SafeMap<const MethodReference, CompiledMethod*, MethodReferenceComparator> MethodTable;
651 
652  public:
653   // Lock is public so that non-members can have lock annotations.
654   mutable Mutex compiled_methods_lock_ DEFAULT_MUTEX_ACQUIRED_AFTER;
655 
656  private:
657   // All method references that this compiler has compiled.
658   MethodTable compiled_methods_ GUARDED_BY(compiled_methods_lock_);
659   // Number of non-relative patches in all compiled methods. These patches need space
660   // in the .oat_patches ELF section if requested in the compiler options.
661   size_t non_relative_linker_patch_count_ GUARDED_BY(compiled_methods_lock_);
662 
663   const bool boot_image_;
664   const bool app_image_;
665 
666   // If image_ is true, specifies the classes that will be included in the image.
667   // Note if image_classes_ is null, all classes are included in the image.
668   std::unique_ptr<std::unordered_set<std::string>> image_classes_;
669 
670   // Specifies the classes that will be compiled. Note that if classes_to_compile_ is null,
671   // all classes are eligible for compilation (duplication filters etc. will still apply).
672   // This option may be restricted to the boot image, depending on a flag in the implementation.
673   std::unique_ptr<std::unordered_set<std::string>> classes_to_compile_;
674 
675   // Specifies the methods that will be compiled. Note that if methods_to_compile_ is null,
676   // all methods are eligible for compilation (compilation filters etc. will still apply).
677   // This option may be restricted to the boot image, depending on a flag in the implementation.
678   std::unique_ptr<std::unordered_set<std::string>> methods_to_compile_;
679 
680   bool had_hard_verifier_failure_;
681 
682   // A thread pool that can (potentially) run tasks in parallel.
683   std::unique_ptr<ThreadPool> parallel_thread_pool_;
684   size_t parallel_thread_count_;
685 
686   // A thread pool that guarantees running single-threaded on the main thread.
687   std::unique_ptr<ThreadPool> single_thread_pool_;
688 
689   class AOTCompilationStats;
690   std::unique_ptr<AOTCompilationStats> stats_;
691 
692   bool dump_stats_;
693   const bool dump_passes_;
694 
695   CumulativeLogger* const timings_logger_;
696 
697   typedef void (*CompilerCallbackFn)(CompilerDriver& driver);
698   typedef MutexLock* (*CompilerMutexLockFn)(CompilerDriver& driver);
699 
700   void* compiler_context_;
701 
702   bool support_boot_image_fixup_;
703 
704   // List of dex files that will be stored in the oat file.
705   const std::vector<const DexFile*>* dex_files_for_oat_file_;
706 
707   CompiledMethodStorage compiled_method_storage_;
708 
709   // Info for profile guided compilation.
710   const ProfileCompilationInfo* const profile_compilation_info_;
711 
712   size_t max_arena_alloc_;
713 
714   // Data for delaying dex-to-dex compilation.
715   Mutex dex_to_dex_references_lock_;
716   // In the first phase, dex_to_dex_references_ collects methods for dex-to-dex compilation.
717   class DexFileMethodSet;
718   std::vector<DexFileMethodSet> dex_to_dex_references_ GUARDED_BY(dex_to_dex_references_lock_);
719   // In the second phase, current_dex_to_dex_methods_ points to the BitVector with method
720   // indexes for dex-to-dex compilation in the current dex file.
721   const BitVector* current_dex_to_dex_methods_;
722 
723   friend class CompileClassVisitor;
724   DISALLOW_COPY_AND_ASSIGN(CompilerDriver);
725 };
726 
727 }  // namespace art
728 
729 #endif  // ART_COMPILER_DRIVER_COMPILER_DRIVER_H_
730