blob: c87fefda16cae38477e52dfbc022db775caac322 [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"
Ian Rogers04d7aa92013-03-16 14:29:17 -070032#include "mirror/object-inl.h"
buzbeec143c552011-08-20 17:38:58 -070033
34namespace art {
35
Ian Rogers1212a022013-03-04 10:48:41 -080036class CompilerDriverTest : public CommonTest {
Brian Carlstrombffb1552011-08-25 12:23:53 -070037 protected:
Ian Rogersb726dcb2012-09-05 08:57:23 -070038 void CompileAll(jobject class_loader) LOCKS_EXCLUDED(Locks::mutator_lock_) {
Ian Rogers1212a022013-03-04 10:48:41 -080039 compiler_driver_->CompileAll(class_loader, Runtime::Current()->GetCompileTimeClassPath(class_loader));
Elliott Hughes1240dad2011-09-09 16:24:50 -070040 MakeAllExecutable(class_loader);
41 }
42
Ian Rogers00f7d0e2012-07-19 15:28:27 -070043 void EnsureCompiled(jobject class_loader, const char* class_name, const char* method,
44 const char* signature, bool is_virtual)
Ian Rogersb726dcb2012-09-05 08:57:23 -070045 LOCKS_EXCLUDED(Locks::mutator_lock_) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070046 CompileAll(class_loader);
Ian Rogers00f7d0e2012-07-19 15:28:27 -070047 Thread::Current()->TransitionFromSuspendedToRunnable();
Brian Carlstrombd86bcc2013-03-10 20:26:16 -070048 bool started = runtime_->Start();
49 CHECK(started);
Elliott Hughes1240dad2011-09-09 16:24:50 -070050 env_ = Thread::Current()->GetJniEnv();
51 class_ = env_->FindClass(class_name);
52 CHECK(class_ != NULL) << "Class not found: " << class_name;
Shih-wei Liao303b01e2011-09-14 00:46:13 -070053 if (is_virtual) {
54 mid_ = env_->GetMethodID(class_, method, signature);
55 } else {
56 mid_ = env_->GetStaticMethodID(class_, method, signature);
57 }
Elliott Hughes1240dad2011-09-09 16:24:50 -070058 CHECK(mid_ != NULL) << "Method not found: " << class_name << "." << method << signature;
59 }
60
Ian Rogers00f7d0e2012-07-19 15:28:27 -070061 void MakeAllExecutable(jobject class_loader) {
Brian Carlstromaded5f72011-10-07 17:15:04 -070062 const std::vector<const DexFile*>& class_path
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080063 = Runtime::Current()->GetCompileTimeClassPath(class_loader);
Elliott Hughes1240dad2011-09-09 16:24:50 -070064 for (size_t i = 0; i != class_path.size(); ++i) {
65 const DexFile* dex_file = class_path[i];
66 CHECK(dex_file != NULL);
67 MakeDexFileExecutable(class_loader, *dex_file);
68 }
69 }
70
Ian Rogers00f7d0e2012-07-19 15:28:27 -070071 void MakeDexFileExecutable(jobject class_loader, const DexFile& dex_file) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070072 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
73 for (size_t i = 0; i < dex_file.NumClassDefs(); i++) {
74 const DexFile::ClassDef& class_def = dex_file.GetClassDef(i);
75 const char* descriptor = dex_file.GetClassDescriptor(class_def);
Ian Rogers00f7d0e2012-07-19 15:28:27 -070076 ScopedObjectAccess soa(Thread::Current());
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080077 mirror::Class* c = class_linker->FindClass(descriptor, soa.Decode<mirror::ClassLoader*>(class_loader));
Elliott Hughes1240dad2011-09-09 16:24:50 -070078 CHECK(c != NULL);
79 for (size_t i = 0; i < c->NumDirectMethods(); i++) {
Brian Carlstrom3320cf42011-10-04 14:58:28 -070080 MakeExecutable(c->GetDirectMethod(i));
Elliott Hughes1240dad2011-09-09 16:24:50 -070081 }
82 for (size_t i = 0; i < c->NumVirtualMethods(); i++) {
Brian Carlstrom3320cf42011-10-04 14:58:28 -070083 MakeExecutable(c->GetVirtualMethod(i));
Elliott Hughes1240dad2011-09-09 16:24:50 -070084 }
85 }
86 }
87
Elliott Hughes1240dad2011-09-09 16:24:50 -070088 JNIEnv* env_;
89 jclass class_;
90 jmethodID mid_;
buzbeec143c552011-08-20 17:38:58 -070091};
92
Brian Carlstrom7540ff42011-09-04 16:38:46 -070093// Disabled due to 10 second runtime on host
Ian Rogers1212a022013-03-04 10:48:41 -080094TEST_F(CompilerDriverTest, DISABLED_LARGE_CompileDexLibCore) {
Elliott Hughes1240dad2011-09-09 16:24:50 -070095 CompileAll(NULL);
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -070096
97 // All libcore references should resolve
Ian Rogers00f7d0e2012-07-19 15:28:27 -070098 ScopedObjectAccess soa(Thread::Current());
Brian Carlstroma004aa92012-02-08 18:05:09 -080099 const DexFile* dex = java_lang_dex_file_;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800100 mirror::DexCache* dex_cache = class_linker_->FindDexCache(*dex);
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700101 EXPECT_EQ(dex->NumStringIds(), dex_cache->NumStrings());
102 for (size_t i = 0; i < dex_cache->NumStrings(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800103 const mirror::String* string = dex_cache->GetResolvedString(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700104 EXPECT_TRUE(string != NULL) << "string_idx=" << i;
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700105 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700106 EXPECT_EQ(dex->NumTypeIds(), dex_cache->NumResolvedTypes());
107 for (size_t i = 0; i < dex_cache->NumResolvedTypes(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800108 mirror::Class* type = dex_cache->GetResolvedType(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700109 EXPECT_TRUE(type != NULL) << "type_idx=" << i
110 << " " << dex->GetTypeDescriptor(dex->GetTypeId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700111 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700112 EXPECT_EQ(dex->NumMethodIds(), dex_cache->NumResolvedMethods());
113 for (size_t i = 0; i < dex_cache->NumResolvedMethods(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800114 mirror::AbstractMethod* method = dex_cache->GetResolvedMethod(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700115 EXPECT_TRUE(method != NULL) << "method_idx=" << i
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700116 << " " << dex->GetMethodDeclaringClassDescriptor(dex->GetMethodId(i))
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700117 << " " << dex->GetMethodName(dex->GetMethodId(i));
Jeff Haoaa4a7932013-05-13 11:28:27 -0700118 EXPECT_TRUE(method->GetEntryPointFromCompiledCode() != NULL) << "method_idx=" << i
Shih-wei Liaoc486c112011-09-13 16:43:52 -0700119 << " "
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700120 << dex->GetMethodDeclaringClassDescriptor(dex->GetMethodId(i))
Shih-wei Liaoc486c112011-09-13 16:43:52 -0700121 << " " << dex->GetMethodName(dex->GetMethodId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700122 }
Brian Carlstrom1caa2c22011-08-28 13:02:33 -0700123 EXPECT_EQ(dex->NumFieldIds(), dex_cache->NumResolvedFields());
124 for (size_t i = 0; i < dex_cache->NumResolvedFields(); i++) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800125 mirror::Field* field = dex_cache->GetResolvedField(i);
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700126 EXPECT_TRUE(field != NULL) << "field_idx=" << i
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700127 << " " << dex->GetFieldDeclaringClassDescriptor(dex->GetFieldId(i))
Brian Carlstrom7540ff42011-09-04 16:38:46 -0700128 << " " << dex->GetFieldName(dex->GetFieldId(i));
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700129 }
130
Brian Carlstrom83db7722011-08-26 17:32:56 -0700131 // TODO check Class::IsVerified for all classes
132
133 // TODO: check that all Method::GetCode() values are non-null
Brian Carlstrom9ea1cb12011-08-24 23:18:18 -0700134}
135
Ian Rogers1212a022013-03-04 10:48:41 -0800136TEST_F(CompilerDriverTest, AbstractMethodErrorStub) {
Brian Carlstrom265091e2013-01-30 14:08:26 -0800137 TEST_DISABLED_FOR_PORTABLE();
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700138 jobject class_loader;
139 {
140 ScopedObjectAccess soa(Thread::Current());
141 CompileVirtualMethod(NULL, "java.lang.Class", "isFinalizable", "()Z");
142 CompileDirectMethod(NULL, "java.lang.Object", "<init>", "()V");
143 class_loader = LoadDex("AbstractMethod");
144 }
145 ASSERT_TRUE(class_loader != NULL);
146 EnsureCompiled(class_loader, "AbstractClass", "foo", "()V", true);
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700147
Ian Rogersa0841a82011-09-22 14:16:31 -0700148 // Create a jobj_ of ConcreteClass, NOT AbstractClass.
149 jclass c_class = env_->FindClass("ConcreteClass");
150 jmethodID constructor = env_->GetMethodID(c_class, "<init>", "()V");
151 jobject jobj_ = env_->NewObject(c_class, constructor);
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700152 ASSERT_TRUE(jobj_ != NULL);
153
Brian Carlstrom3320cf42011-10-04 14:58:28 -0700154 // Force non-virtual call to AbstractClass foo, will throw AbstractMethodError exception.
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700155 env_->CallNonvirtualVoidMethod(jobj_, class_, mid_);
Ian Rogers00f7d0e2012-07-19 15:28:27 -0700156 EXPECT_EQ(env_->ExceptionCheck(), JNI_TRUE);
157 jthrowable exception = env_->ExceptionOccurred();
158 env_->ExceptionClear();
159 jclass jlame = env_->FindClass("java/lang/AbstractMethodError");
160 EXPECT_TRUE(env_->IsInstanceOf(exception, jlame));
Ian Rogersa0841a82011-09-22 14:16:31 -0700161 Thread::Current()->ClearException();
Shih-wei Liao303b01e2011-09-14 00:46:13 -0700162}
163
buzbee2a475e72011-09-07 17:19:17 -0700164// TODO: need check-cast test (when stub complete & we can throw/catch
165
buzbeec143c552011-08-20 17:38:58 -0700166} // namespace art