/* * Copyright (C) 2011 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ART_COMPILER_COMMON_COMPILER_TEST_H_ #define ART_COMPILER_COMMON_COMPILER_TEST_H_ #include #include #include "arch/instruction_set.h" #include "arch/instruction_set_features.h" #include "base/hash_set.h" #include "common_runtime_test.h" #include "compiler.h" #include "oat_file.h" namespace art { namespace mirror { class ClassLoader; } // namespace mirror class CompilerDriver; class CompilerOptions; class CumulativeLogger; class DexFile; class ProfileCompilationInfo; class VerificationResults; template class Handle; class CommonCompilerTest : public CommonRuntimeTest { public: CommonCompilerTest(); ~CommonCompilerTest(); // Create an OatMethod based on pointers (for unit tests). OatFile::OatMethod CreateOatMethod(const void* code); void MakeExecutable(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_); static void MakeExecutable(const void* code_start, size_t code_length); void MakeExecutable(ObjPtr class_loader, const char* class_name) REQUIRES_SHARED(Locks::mutator_lock_); protected: void SetUp() OVERRIDE; void SetUpRuntimeOptions(RuntimeOptions* options) OVERRIDE; Compiler::Kind GetCompilerKind() const; void SetCompilerKind(Compiler::Kind compiler_kind); // Get the set of image classes given to the compiler-driver in SetUp. virtual std::unique_ptr> GetImageClasses(); virtual ProfileCompilationInfo* GetProfileCompilationInfo(); virtual CompilerFilter::Filter GetCompilerFilter() const { return CompilerFilter::kDefaultCompilerFilter; } void TearDown() OVERRIDE; void CompileClass(mirror::ClassLoader* class_loader, const char* class_name) REQUIRES_SHARED(Locks::mutator_lock_); void CompileMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_); void CompileDirectMethod(Handle class_loader, const char* class_name, const char* method_name, const char* signature) REQUIRES_SHARED(Locks::mutator_lock_); void CompileVirtualMethod(Handle class_loader, const char* class_name, const char* method_name, const char* signature) REQUIRES_SHARED(Locks::mutator_lock_); void ApplyInstructionSet(); void OverrideInstructionSetFeatures(InstructionSet instruction_set, const std::string& variant); void CreateCompilerDriver(); void ReserveImageSpace(); void UnreserveImageSpace(); void SetDexFilesForOatFile(const std::vector& dex_files); void ClearBootImageOption(); Compiler::Kind compiler_kind_ = Compiler::kOptimizing; size_t number_of_threads_ = 2u; InstructionSet instruction_set_ = (kRuntimeISA == InstructionSet::kArm) ? InstructionSet::kThumb2 : kRuntimeISA; // Take the default set of instruction features from the build. std::unique_ptr instruction_set_features_ = InstructionSetFeatures::FromCppDefines(); std::unique_ptr compiler_options_; std::unique_ptr verification_results_; std::unique_ptr compiler_driver_; private: MemMap image_reservation_; // Chunks must not move their storage after being created - use the node-based std::list. std::list> header_code_and_maps_chunks_; }; } // namespace art #endif // ART_COMPILER_COMMON_COMPILER_TEST_H_