blob: 19ccb358e80eadefccc4de3231d1b2fb640e07b1 [file] [log] [blame]
Elliott Hughes2faa5f12012-01-30 14:42:07 -08001/*
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 */
buzbeec143c552011-08-20 17:38:58 -070016
Ian Rogers1212a022013-03-04 10:48:41 -080017#include "compiler/driver/compiler_driver.h"
Elliott Hughes90a33692011-08-30 13:27:07 -070018
19#include <stdint.h>
20#include <stdio.h>
21
22#include "UniquePtr.h"
buzbeec143c552011-08-20 17:38:58 -070023#include "class_linker.h"
24#include "common_test.h"
25#include "dex_file.h"
26#include "heap.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080027#include "mirror/class.h"
28#include "mirror/class-inl.h"
29#include "mirror/dex_cache.h"
30#include "mirror/abstract_method-inl.h"
31#include "mirror/object_array-inl.h"
buzbeec143c552011-08-20 17:38:58 -070032
33namespace art {
34
Ian Rogers1212a022013-03-04 10:48:41 -080035class CompilerDriverTest : public CommonTest {
Brian Carlstrombffb1552011-08-25 12:23:53 -070036 protected:
Ian Rogersb726dcb2012-09-05 08:57:23 -070037 void CompileAll(jobject class_loader) LOCKS_EXCLUDED(Locks::mutator_lock_) {
Ian Rogers1212a022013-03-04 10:48:41 -080038 compiler_driver_->CompileAll(class_loader, Runtime::Current()->GetCompileTimeClassPath(class_loader));
Elliott Hughes1240dad2011-09-09 16:24:50 -070039 MakeAllExecutable(class_loader);
40 }
41
Ian Rogers00f7d0e2012-07-19 15:28:27 -070042 void EnsureCompiled(jobject class_loader, const char* class_name, const char* method,
43 const char* signature, bool is_virtual)
Ian Rogersb726dcb2012-09-05 08:57:23 -070044 LOCKS_EXCLUDED(Locks::mutator_lock_) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070045 CompileAll(class_loader);
Ian Rogers00f7d0e2012-07-19 15:28:27 -070046 Thread::Current()->TransitionFromSuspendedToRunnable();
Ian Rogersa0841a82011-09-22 14:16:31 -070047 runtime_->Start();
Elliott Hughes1240dad2011-09-09 16:24:50 -070048 env_ = Thread::Current()->GetJniEnv();
49 class_ = env_->FindClass(class_name);
50 CHECK(class_ != NULL) << "Class not found: " << class_name;
Shih-wei Liao303b01e2011-09-14 00:46:13 -070051 if (is_virtual) {
52 mid_ = env_->GetMethodID(class_, method, signature);
53 } else {
54 mid_ = env_->GetStaticMethodID(class_, method, signature);
55 }
Elliott Hughes1240dad2011-09-09 16:24:50 -070056 CHECK(mid_ != NULL) << "Method not found: " << class_name << "." << method << signature;
57 }
58
Ian Rogers00f7d0e2012-07-19 15:28:27 -070059 void MakeAllExecutable(jobject class_loader) {
Brian Carlstromaded5f72011-10-07 17:15:04 -070060 const std::vector<const DexFile*>& class_path
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080061 = Runtime::Current()->GetCompileTimeClassPath(class_loader);
Elliott Hughes1240dad2011-09-09 16:24:50 -070062 for (size_t i = 0; i != class_path.size(); ++i) {
63 const DexFile* dex_file = class_path[i];
64 CHECK(dex_file != NULL);
65 MakeDexFileExecutable(class_loader, *dex_file);
66 }
67 }
68
Ian Rogers00f7d0e2012-07-19 15:28:27 -070069 void MakeDexFileExecutable(jobject class_loader, const DexFile& dex_file) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070070 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
71 for (size_t i = 0; i < dex_file.NumClassDefs(); i++) {
72 const DexFile::ClassDef& class_def = dex_file.GetClassDef(i);
73 const char* descriptor = dex_file.GetClassDescriptor(class_def);
Ian Rogers00f7d0e2012-07-19 15:28:27 -070074 ScopedObjectAccess soa(Thread::Current());
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080075 mirror::Class* c = class_linker->FindClass(descriptor, soa.Decode<mirror::ClassLoader*>(class_loader));
Elliott Hughes1240dad2011-09-09 16:24:50 -070076 CHECK(c != NULL);
77 for (size_t i = 0; i < c->NumDirectMethods(); i++) {
Brian Carlstrom3320cf42011-10-04 14:58:28 -070078 MakeExecutable(c->GetDirectMethod(i));
Elliott Hughes1240dad2011-09-09 16:24:50 -070079 }
80 for (size_t i = 0; i < c->NumVirtualMethods(); i++) {
Brian Carlstrom3320cf42011-10-04 14:58:28 -070081 MakeExecutable(c->GetVirtualMethod(i));
Elliott Hughes1240dad2011-09-09 16:24:50 -070082 }
83 }
84 }
85
Elliott Hughes1240dad2011-09-09 16:24:50 -070086 JNIEnv* env_;
87 jclass class_;
88 jmethodID mid_;
buzbeec143c552011-08-20 17:38:58 -070089};
90
Brian Carlstrom7540ff42011-09-04 16:38:46 -070091// Disabled due to 10 second runtime on host
Ian Rogers1212a022013-03-04 10:48:41 -080092TEST_F(CompilerDriverTest, DISABLED_LARGE_CompileDexLibCore) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070093 CompileAll(NULL);
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -070094
95 // All libcore references should resolve
Ian Rogers00f7d0e2012-07-19 15:28:27 -070096 ScopedObjectAccess soa(Thread::Current());
Brian Carlstroma004aa92012-02-08 18:05:09 -080097 const DexFile* dex = java_lang_dex_file_;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080098 mirror::DexCache* dex_cache = class_linker_->FindDexCache(*dex);
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -070099 EXPECT_EQ(dex->NumStringIds(), dex_cache->NumStrings());
100 for (size_t i = 0; i < dex_cache->NumStrings(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800101 const mirror::String* string = dex_cache->GetResolvedString(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700102 EXPECT_TRUE(string != NULL) << "string_idx=" << i;
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700103 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700104 EXPECT_EQ(dex->NumTypeIds(), dex_cache->NumResolvedTypes());
105 for (size_t i = 0; i < dex_cache->NumResolvedTypes(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800106 mirror::Class* type = dex_cache->GetResolvedType(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700107 EXPECT_TRUE(type != NULL) << "type_idx=" << i
108 << " " << dex->GetTypeDescriptor(dex->GetTypeId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700109 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700110 EXPECT_EQ(dex->NumMethodIds(), dex_cache->NumResolvedMethods());
111 for (size_t i = 0; i < dex_cache->NumResolvedMethods(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800112 mirror::AbstractMethod* method = dex_cache->GetResolvedMethod(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700113 EXPECT_TRUE(method != NULL) << "method_idx=" << i
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700114 << " " << dex->GetMethodDeclaringClassDescriptor(dex->GetMethodId(i))
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700115 << " " << dex->GetMethodName(dex->GetMethodId(i));
Shih-wei Liaoc486c112011-09-13 16:43:52 -0700116 EXPECT_TRUE(method->GetCode() != NULL) << "method_idx=" << i
117 << " "
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700118 << dex->GetMethodDeclaringClassDescriptor(dex->GetMethodId(i))
Shih-wei Liaoc486c112011-09-13 16:43:52 -0700119 << " " << dex->GetMethodName(dex->GetMethodId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700120 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700121 EXPECT_EQ(dex->NumFieldIds(), dex_cache->NumResolvedFields());
122 for (size_t i = 0; i < dex_cache->NumResolvedFields(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800123 mirror::Field* field = dex_cache->GetResolvedField(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700124 EXPECT_TRUE(field != NULL) << "field_idx=" << i
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700125 << " " << dex->GetFieldDeclaringClassDescriptor(dex->GetFieldId(i))
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700126 << " " << dex->GetFieldName(dex->GetFieldId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700127 }
128
Brian Carlstrom83db7722011-08-26 17:32:56 -0700129 // TODO check Class::IsVerified for all classes
130
131 // TODO: check that all Method::GetCode() values are non-null
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700132}
133
Ian Rogers1212a022013-03-04 10:48:41 -0800134TEST_F(CompilerDriverTest, AbstractMethodErrorStub) {
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700135 jobject class_loader;
136 {
137 ScopedObjectAccess soa(Thread::Current());
138 CompileVirtualMethod(NULL, "java.lang.Class", "isFinalizable", "()Z");
139 CompileDirectMethod(NULL, "java.lang.Object", "<init>", "()V");
140 class_loader = LoadDex("AbstractMethod");
141 }
142 ASSERT_TRUE(class_loader != NULL);
143 EnsureCompiled(class_loader, "AbstractClass", "foo", "()V", true);
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700144
Ian Rogersa0841a82011-09-22 14:16:31 -0700145 // Create a jobj_ of ConcreteClass, NOT AbstractClass.
146 jclass c_class = env_->FindClass("ConcreteClass");
147 jmethodID constructor = env_->GetMethodID(c_class, "<init>", "()V");
148 jobject jobj_ = env_->NewObject(c_class, constructor);
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700149 ASSERT_TRUE(jobj_ != NULL);
150
Brian Carlstrom3320cf42011-10-04 14:58:28 -0700151 // Force non-virtual call to AbstractClass foo, will throw AbstractMethodError exception.
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700152 env_->CallNonvirtualVoidMethod(jobj_, class_, mid_);
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700153 EXPECT_EQ(env_->ExceptionCheck(), JNI_TRUE);
154 jthrowable exception = env_->ExceptionOccurred();
155 env_->ExceptionClear();
156 jclass jlame = env_->FindClass("java/lang/AbstractMethodError");
157 EXPECT_TRUE(env_->IsInstanceOf(exception, jlame));
Ian Rogersa0841a82011-09-22 14:16:31 -0700158 Thread::Current()->ClearException();
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700159}
160
buzbee2a475e72011-09-07 17:19:17 -0700161// TODO: need check-cast test (when stub complete & we can throw/catch
162
buzbeec143c552011-08-20 17:38:58 -0700163} // namespace art