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 #include "class.h"
18
19 #include "android-base/stringprintf.h"
20
21 #include "art_field-inl.h"
22 #include "art_method-inl.h"
23 #include "base/logging.h" // For VLOG.
24 #include "base/utils.h"
25 #include "class-inl.h"
26 #include "class_ext.h"
27 #include "class_linker-inl.h"
28 #include "class_loader.h"
29 #include "dex/descriptors_names.h"
30 #include "dex/dex_file-inl.h"
31 #include "dex/dex_file_annotations.h"
32 #include "dex_cache.h"
33 #include "gc/accounting/card_table-inl.h"
34 #include "handle_scope-inl.h"
35 #include "subtype_check.h"
36 #include "method.h"
37 #include "object-inl.h"
38 #include "object-refvisitor-inl.h"
39 #include "object_array-inl.h"
40 #include "object_lock.h"
41 #include "runtime.h"
42 #include "thread.h"
43 #include "throwable.h"
44 #include "well_known_classes.h"
45
46 namespace art {
47
48 // TODO: move to own CC file?
49 constexpr size_t BitString::kBitSizeAtPosition[BitString::kCapacity];
50 constexpr size_t BitString::kCapacity;
51
52 namespace mirror {
53
54 using android::base::StringPrintf;
55
56 GcRoot<Class> Class::java_lang_Class_;
57
SetClassClass(ObjPtr<Class> java_lang_Class)58 void Class::SetClassClass(ObjPtr<Class> java_lang_Class) {
59 CHECK(java_lang_Class_.IsNull())
60 << java_lang_Class_.Read()
61 << " " << java_lang_Class;
62 CHECK(java_lang_Class != nullptr);
63 java_lang_Class->SetClassFlags(kClassFlagClass);
64 java_lang_Class_ = GcRoot<Class>(java_lang_Class);
65 }
66
ResetClass()67 void Class::ResetClass() {
68 CHECK(!java_lang_Class_.IsNull());
69 java_lang_Class_ = GcRoot<Class>(nullptr);
70 }
71
VisitRoots(RootVisitor * visitor)72 void Class::VisitRoots(RootVisitor* visitor) {
73 java_lang_Class_.VisitRootIfNonNull(visitor, RootInfo(kRootStickyClass));
74 }
75
GetPrimitiveClass(ObjPtr<mirror::String> name)76 ObjPtr<mirror::Class> Class::GetPrimitiveClass(ObjPtr<mirror::String> name) {
77 const char* expected_name = nullptr;
78 ClassLinker::ClassRoot class_root = ClassLinker::kJavaLangObject; // Invalid.
79 if (name != nullptr && name->GetLength() >= 2) {
80 // Perfect hash for the expected values: from the second letters of the primitive types,
81 // only 'y' has the bit 0x10 set, so use it to change 'b' to 'B'.
82 char hash = name->CharAt(0) ^ ((name->CharAt(1) & 0x10) << 1);
83 switch (hash) {
84 case 'b': expected_name = "boolean"; class_root = ClassLinker::kPrimitiveBoolean; break;
85 case 'B': expected_name = "byte"; class_root = ClassLinker::kPrimitiveByte; break;
86 case 'c': expected_name = "char"; class_root = ClassLinker::kPrimitiveChar; break;
87 case 'd': expected_name = "double"; class_root = ClassLinker::kPrimitiveDouble; break;
88 case 'f': expected_name = "float"; class_root = ClassLinker::kPrimitiveFloat; break;
89 case 'i': expected_name = "int"; class_root = ClassLinker::kPrimitiveInt; break;
90 case 'l': expected_name = "long"; class_root = ClassLinker::kPrimitiveLong; break;
91 case 's': expected_name = "short"; class_root = ClassLinker::kPrimitiveShort; break;
92 case 'v': expected_name = "void"; class_root = ClassLinker::kPrimitiveVoid; break;
93 default: break;
94 }
95 }
96 if (expected_name != nullptr && name->Equals(expected_name)) {
97 ObjPtr<mirror::Class> klass = Runtime::Current()->GetClassLinker()->GetClassRoot(class_root);
98 DCHECK(klass != nullptr);
99 return klass;
100 } else {
101 Thread* self = Thread::Current();
102 if (name == nullptr) {
103 // Note: ThrowNullPointerException() requires a message which we deliberately want to omit.
104 self->ThrowNewException("Ljava/lang/NullPointerException;", /* msg */ nullptr);
105 } else {
106 self->ThrowNewException("Ljava/lang/ClassNotFoundException;", name->ToModifiedUtf8().c_str());
107 }
108 return nullptr;
109 }
110 }
111
EnsureExtDataPresent(Thread * self)112 ClassExt* Class::EnsureExtDataPresent(Thread* self) {
113 ObjPtr<ClassExt> existing(GetExtData());
114 if (!existing.IsNull()) {
115 return existing.Ptr();
116 }
117 StackHandleScope<3> hs(self);
118 // Handlerize 'this' since we are allocating here.
119 Handle<Class> h_this(hs.NewHandle(this));
120 // Clear exception so we can allocate.
121 Handle<Throwable> throwable(hs.NewHandle(self->GetException()));
122 self->ClearException();
123 // Allocate the ClassExt
124 Handle<ClassExt> new_ext(hs.NewHandle(ClassExt::Alloc(self)));
125 if (new_ext == nullptr) {
126 // OOM allocating the classExt.
127 // TODO Should we restore the suppressed exception?
128 self->AssertPendingOOMException();
129 return nullptr;
130 } else {
131 MemberOffset ext_offset(OFFSET_OF_OBJECT_MEMBER(Class, ext_data_));
132 bool set;
133 // Set the ext_data_ field using CAS semantics.
134 if (Runtime::Current()->IsActiveTransaction()) {
135 set = h_this->CasFieldStrongSequentiallyConsistentObject<true>(ext_offset,
136 ObjPtr<ClassExt>(nullptr),
137 new_ext.Get());
138 } else {
139 set = h_this->CasFieldStrongSequentiallyConsistentObject<false>(ext_offset,
140 ObjPtr<ClassExt>(nullptr),
141 new_ext.Get());
142 }
143 ObjPtr<ClassExt> ret(set ? new_ext.Get() : h_this->GetExtData());
144 DCHECK(!set || h_this->GetExtData() == new_ext.Get());
145 CHECK(!ret.IsNull());
146 // Restore the exception if there was one.
147 if (throwable != nullptr) {
148 self->SetException(throwable.Get());
149 }
150 return ret.Ptr();
151 }
152 }
153
SetStatus(Handle<Class> h_this,ClassStatus new_status,Thread * self)154 void Class::SetStatus(Handle<Class> h_this, ClassStatus new_status, Thread* self) {
155 ClassStatus old_status = h_this->GetStatus();
156 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
157 bool class_linker_initialized = class_linker != nullptr && class_linker->IsInitialized();
158 if (LIKELY(class_linker_initialized)) {
159 if (UNLIKELY(new_status <= old_status &&
160 new_status != ClassStatus::kErrorUnresolved &&
161 new_status != ClassStatus::kErrorResolved &&
162 new_status != ClassStatus::kRetired)) {
163 LOG(FATAL) << "Unexpected change back of class status for " << h_this->PrettyClass()
164 << " " << old_status << " -> " << new_status;
165 }
166 if (new_status >= ClassStatus::kResolved || old_status >= ClassStatus::kResolved) {
167 // When classes are being resolved the resolution code should hold the lock.
168 CHECK_EQ(h_this->GetLockOwnerThreadId(), self->GetThreadId())
169 << "Attempt to change status of class while not holding its lock: "
170 << h_this->PrettyClass() << " " << old_status << " -> " << new_status;
171 }
172 }
173 if (UNLIKELY(IsErroneous(new_status))) {
174 CHECK(!h_this->IsErroneous())
175 << "Attempt to set as erroneous an already erroneous class "
176 << h_this->PrettyClass()
177 << " old_status: " << old_status << " new_status: " << new_status;
178 CHECK_EQ(new_status == ClassStatus::kErrorResolved, old_status >= ClassStatus::kResolved);
179 if (VLOG_IS_ON(class_linker)) {
180 LOG(ERROR) << "Setting " << h_this->PrettyDescriptor() << " to erroneous.";
181 if (self->IsExceptionPending()) {
182 LOG(ERROR) << "Exception: " << self->GetException()->Dump();
183 }
184 }
185
186 ObjPtr<ClassExt> ext(h_this->EnsureExtDataPresent(self));
187 if (!ext.IsNull()) {
188 self->AssertPendingException();
189 ext->SetVerifyError(self->GetException());
190 } else {
191 self->AssertPendingOOMException();
192 }
193 self->AssertPendingException();
194 }
195
196 if (kBitstringSubtypeCheckEnabled) {
197 // FIXME: This looks broken with respect to aborted transactions.
198 ObjPtr<mirror::Class> h_this_ptr = h_this.Get();
199 SubtypeCheck<ObjPtr<mirror::Class>>::WriteStatus(h_this_ptr, new_status);
200 } else {
201 // The ClassStatus is always in the 4 most-significant bits of status_.
202 static_assert(sizeof(status_) == sizeof(uint32_t), "Size of status_ not equal to uint32");
203 uint32_t new_status_value = static_cast<uint32_t>(new_status) << (32 - kClassStatusBitSize);
204 if (Runtime::Current()->IsActiveTransaction()) {
205 h_this->SetField32Volatile<true>(StatusOffset(), new_status_value);
206 } else {
207 h_this->SetField32Volatile<false>(StatusOffset(), new_status_value);
208 }
209 }
210
211 // Setting the object size alloc fast path needs to be after the status write so that if the
212 // alloc path sees a valid object size, we would know that it's initialized as long as it has a
213 // load-acquire/fake dependency.
214 if (new_status == ClassStatus::kInitialized && !h_this->IsVariableSize()) {
215 DCHECK_EQ(h_this->GetObjectSizeAllocFastPath(), std::numeric_limits<uint32_t>::max());
216 // Finalizable objects must always go slow path.
217 if (!h_this->IsFinalizable()) {
218 h_this->SetObjectSizeAllocFastPath(RoundUp(h_this->GetObjectSize(), kObjectAlignment));
219 }
220 }
221
222 if (!class_linker_initialized) {
223 // When the class linker is being initialized its single threaded and by definition there can be
224 // no waiters. During initialization classes may appear temporary but won't be retired as their
225 // size was statically computed.
226 } else {
227 // Classes that are being resolved or initialized need to notify waiters that the class status
228 // changed. See ClassLinker::EnsureResolved and ClassLinker::WaitForInitializeClass.
229 if (h_this->IsTemp()) {
230 // Class is a temporary one, ensure that waiters for resolution get notified of retirement
231 // so that they can grab the new version of the class from the class linker's table.
232 CHECK_LT(new_status, ClassStatus::kResolved) << h_this->PrettyDescriptor();
233 if (new_status == ClassStatus::kRetired || new_status == ClassStatus::kErrorUnresolved) {
234 h_this->NotifyAll(self);
235 }
236 } else {
237 CHECK_NE(new_status, ClassStatus::kRetired);
238 if (old_status >= ClassStatus::kResolved || new_status >= ClassStatus::kResolved) {
239 h_this->NotifyAll(self);
240 }
241 }
242 }
243 }
244
SetDexCache(ObjPtr<DexCache> new_dex_cache)245 void Class::SetDexCache(ObjPtr<DexCache> new_dex_cache) {
246 SetFieldObjectTransaction(OFFSET_OF_OBJECT_MEMBER(Class, dex_cache_), new_dex_cache);
247 }
248
SetClassSize(uint32_t new_class_size)249 void Class::SetClassSize(uint32_t new_class_size) {
250 if (kIsDebugBuild && new_class_size < GetClassSize()) {
251 DumpClass(LOG_STREAM(FATAL_WITHOUT_ABORT), kDumpClassFullDetail);
252 LOG(FATAL_WITHOUT_ABORT) << new_class_size << " vs " << GetClassSize();
253 LOG(FATAL) << "class=" << PrettyTypeOf();
254 }
255 SetField32Transaction(OFFSET_OF_OBJECT_MEMBER(Class, class_size_), new_class_size);
256 }
257
258 // Return the class' name. The exact format is bizarre, but it's the specified behavior for
259 // Class.getName: keywords for primitive types, regular "[I" form for primitive arrays (so "int"
260 // but "[I"), and arrays of reference types written between "L" and ";" but with dots rather than
261 // slashes (so "java.lang.String" but "[Ljava.lang.String;"). Madness.
ComputeName(Handle<Class> h_this)262 String* Class::ComputeName(Handle<Class> h_this) {
263 String* name = h_this->GetName();
264 if (name != nullptr) {
265 return name;
266 }
267 std::string temp;
268 const char* descriptor = h_this->GetDescriptor(&temp);
269 Thread* self = Thread::Current();
270 if ((descriptor[0] != 'L') && (descriptor[0] != '[')) {
271 // The descriptor indicates that this is the class for
272 // a primitive type; special-case the return value.
273 const char* c_name = nullptr;
274 switch (descriptor[0]) {
275 case 'Z': c_name = "boolean"; break;
276 case 'B': c_name = "byte"; break;
277 case 'C': c_name = "char"; break;
278 case 'S': c_name = "short"; break;
279 case 'I': c_name = "int"; break;
280 case 'J': c_name = "long"; break;
281 case 'F': c_name = "float"; break;
282 case 'D': c_name = "double"; break;
283 case 'V': c_name = "void"; break;
284 default:
285 LOG(FATAL) << "Unknown primitive type: " << PrintableChar(descriptor[0]);
286 }
287 name = String::AllocFromModifiedUtf8(self, c_name);
288 } else {
289 // Convert the UTF-8 name to a java.lang.String. The name must use '.' to separate package
290 // components.
291 name = String::AllocFromModifiedUtf8(self, DescriptorToDot(descriptor).c_str());
292 }
293 h_this->SetName(name);
294 return name;
295 }
296
DumpClass(std::ostream & os,int flags)297 void Class::DumpClass(std::ostream& os, int flags) {
298 if ((flags & kDumpClassFullDetail) == 0) {
299 os << PrettyClass();
300 if ((flags & kDumpClassClassLoader) != 0) {
301 os << ' ' << GetClassLoader();
302 }
303 if ((flags & kDumpClassInitialized) != 0) {
304 os << ' ' << GetStatus();
305 }
306 os << "\n";
307 return;
308 }
309
310 Thread* const self = Thread::Current();
311 StackHandleScope<2> hs(self);
312 Handle<Class> h_this(hs.NewHandle(this));
313 Handle<Class> h_super(hs.NewHandle(GetSuperClass()));
314 auto image_pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize();
315
316 std::string temp;
317 os << "----- " << (IsInterface() ? "interface" : "class") << " "
318 << "'" << GetDescriptor(&temp) << "' cl=" << GetClassLoader() << " -----\n",
319 os << " objectSize=" << SizeOf() << " "
320 << "(" << (h_super != nullptr ? h_super->SizeOf() : -1) << " from super)\n",
321 os << StringPrintf(" access=0x%04x.%04x\n",
322 GetAccessFlags() >> 16, GetAccessFlags() & kAccJavaFlagsMask);
323 if (h_super != nullptr) {
324 os << " super='" << h_super->PrettyClass() << "' (cl=" << h_super->GetClassLoader()
325 << ")\n";
326 }
327 if (IsArrayClass()) {
328 os << " componentType=" << PrettyClass(GetComponentType()) << "\n";
329 }
330 const size_t num_direct_interfaces = NumDirectInterfaces();
331 if (num_direct_interfaces > 0) {
332 os << " interfaces (" << num_direct_interfaces << "):\n";
333 for (size_t i = 0; i < num_direct_interfaces; ++i) {
334 ObjPtr<Class> interface = GetDirectInterface(self, h_this.Get(), i);
335 if (interface == nullptr) {
336 os << StringPrintf(" %2zd: nullptr!\n", i);
337 } else {
338 ObjPtr<ClassLoader> cl = interface->GetClassLoader();
339 os << StringPrintf(" %2zd: %s (cl=%p)\n", i, PrettyClass(interface).c_str(), cl.Ptr());
340 }
341 }
342 }
343 if (!IsLoaded()) {
344 os << " class not yet loaded";
345 } else {
346 // After this point, this may have moved due to GetDirectInterface.
347 os << " vtable (" << h_this->NumVirtualMethods() << " entries, "
348 << (h_super != nullptr ? h_super->NumVirtualMethods() : 0) << " in super):\n";
349 for (size_t i = 0; i < NumVirtualMethods(); ++i) {
350 os << StringPrintf(" %2zd: %s\n", i, ArtMethod::PrettyMethod(
351 h_this->GetVirtualMethodDuringLinking(i, image_pointer_size)).c_str());
352 }
353 os << " direct methods (" << h_this->NumDirectMethods() << " entries):\n";
354 for (size_t i = 0; i < h_this->NumDirectMethods(); ++i) {
355 os << StringPrintf(" %2zd: %s\n", i, ArtMethod::PrettyMethod(
356 h_this->GetDirectMethod(i, image_pointer_size)).c_str());
357 }
358 if (h_this->NumStaticFields() > 0) {
359 os << " static fields (" << h_this->NumStaticFields() << " entries):\n";
360 if (h_this->IsResolved()) {
361 for (size_t i = 0; i < h_this->NumStaticFields(); ++i) {
362 os << StringPrintf(" %2zd: %s\n", i,
363 ArtField::PrettyField(h_this->GetStaticField(i)).c_str());
364 }
365 } else {
366 os << " <not yet available>";
367 }
368 }
369 if (h_this->NumInstanceFields() > 0) {
370 os << " instance fields (" << h_this->NumInstanceFields() << " entries):\n";
371 if (h_this->IsResolved()) {
372 for (size_t i = 0; i < h_this->NumInstanceFields(); ++i) {
373 os << StringPrintf(" %2zd: %s\n", i,
374 ArtField::PrettyField(h_this->GetInstanceField(i)).c_str());
375 }
376 } else {
377 os << " <not yet available>";
378 }
379 }
380 }
381 }
382
SetReferenceInstanceOffsets(uint32_t new_reference_offsets)383 void Class::SetReferenceInstanceOffsets(uint32_t new_reference_offsets) {
384 if (kIsDebugBuild && new_reference_offsets != kClassWalkSuper) {
385 // Sanity check that the number of bits set in the reference offset bitmap
386 // agrees with the number of references
387 uint32_t count = 0;
388 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
389 count += c->NumReferenceInstanceFieldsDuringLinking();
390 }
391 // +1 for the Class in Object.
392 CHECK_EQ(static_cast<uint32_t>(POPCOUNT(new_reference_offsets)) + 1, count);
393 }
394 // Not called within a transaction.
395 SetField32<false>(OFFSET_OF_OBJECT_MEMBER(Class, reference_instance_offsets_),
396 new_reference_offsets);
397 }
398
IsInSamePackage(const StringPiece & descriptor1,const StringPiece & descriptor2)399 bool Class::IsInSamePackage(const StringPiece& descriptor1, const StringPiece& descriptor2) {
400 size_t i = 0;
401 size_t min_length = std::min(descriptor1.size(), descriptor2.size());
402 while (i < min_length && descriptor1[i] == descriptor2[i]) {
403 ++i;
404 }
405 if (descriptor1.find('/', i) != StringPiece::npos ||
406 descriptor2.find('/', i) != StringPiece::npos) {
407 return false;
408 } else {
409 return true;
410 }
411 }
412
IsInSamePackage(ObjPtr<Class> that)413 bool Class::IsInSamePackage(ObjPtr<Class> that) {
414 ObjPtr<Class> klass1 = this;
415 ObjPtr<Class> klass2 = that;
416 if (klass1 == klass2) {
417 return true;
418 }
419 // Class loaders must match.
420 if (klass1->GetClassLoader() != klass2->GetClassLoader()) {
421 return false;
422 }
423 // Arrays are in the same package when their element classes are.
424 while (klass1->IsArrayClass()) {
425 klass1 = klass1->GetComponentType();
426 }
427 while (klass2->IsArrayClass()) {
428 klass2 = klass2->GetComponentType();
429 }
430 // trivial check again for array types
431 if (klass1 == klass2) {
432 return true;
433 }
434 // Compare the package part of the descriptor string.
435 std::string temp1, temp2;
436 return IsInSamePackage(klass1->GetDescriptor(&temp1), klass2->GetDescriptor(&temp2));
437 }
438
IsThrowableClass()439 bool Class::IsThrowableClass() {
440 return WellKnownClasses::ToClass(WellKnownClasses::java_lang_Throwable)->IsAssignableFrom(this);
441 }
442
SetClassLoader(ObjPtr<ClassLoader> new_class_loader)443 void Class::SetClassLoader(ObjPtr<ClassLoader> new_class_loader) {
444 if (Runtime::Current()->IsActiveTransaction()) {
445 SetFieldObject<true>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
446 } else {
447 SetFieldObject<false>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
448 }
449 }
450
451 template <typename SignatureType>
FindInterfaceMethodWithSignature(ObjPtr<Class> klass,const StringPiece & name,const SignatureType & signature,PointerSize pointer_size)452 static inline ArtMethod* FindInterfaceMethodWithSignature(ObjPtr<Class> klass,
453 const StringPiece& name,
454 const SignatureType& signature,
455 PointerSize pointer_size)
456 REQUIRES_SHARED(Locks::mutator_lock_) {
457 // If the current class is not an interface, skip the search of its declared methods;
458 // such lookup is used only to distinguish between IncompatibleClassChangeError and
459 // NoSuchMethodError and the caller has already tried to search methods in the class.
460 if (LIKELY(klass->IsInterface())) {
461 // Search declared methods, both direct and virtual.
462 // (This lookup is used also for invoke-static on interface classes.)
463 for (ArtMethod& method : klass->GetDeclaredMethodsSlice(pointer_size)) {
464 if (method.GetName() == name && method.GetSignature() == signature) {
465 return &method;
466 }
467 }
468 }
469
470 // TODO: If there is a unique maximally-specific non-abstract superinterface method,
471 // we should return it, otherwise an arbitrary one can be returned.
472 ObjPtr<IfTable> iftable = klass->GetIfTable();
473 for (int32_t i = 0, iftable_count = iftable->Count(); i < iftable_count; ++i) {
474 ObjPtr<Class> iface = iftable->GetInterface(i);
475 for (ArtMethod& method : iface->GetVirtualMethodsSlice(pointer_size)) {
476 if (method.GetName() == name && method.GetSignature() == signature) {
477 return &method;
478 }
479 }
480 }
481
482 // Then search for public non-static methods in the java.lang.Object.
483 if (LIKELY(klass->IsInterface())) {
484 ObjPtr<Class> object_class = klass->GetSuperClass();
485 DCHECK(object_class->IsObjectClass());
486 for (ArtMethod& method : object_class->GetDeclaredMethodsSlice(pointer_size)) {
487 if (method.IsPublic() && !method.IsStatic() &&
488 method.GetName() == name && method.GetSignature() == signature) {
489 return &method;
490 }
491 }
492 }
493 return nullptr;
494 }
495
FindInterfaceMethod(const StringPiece & name,const StringPiece & signature,PointerSize pointer_size)496 ArtMethod* Class::FindInterfaceMethod(const StringPiece& name,
497 const StringPiece& signature,
498 PointerSize pointer_size) {
499 return FindInterfaceMethodWithSignature(this, name, signature, pointer_size);
500 }
501
FindInterfaceMethod(const StringPiece & name,const Signature & signature,PointerSize pointer_size)502 ArtMethod* Class::FindInterfaceMethod(const StringPiece& name,
503 const Signature& signature,
504 PointerSize pointer_size) {
505 return FindInterfaceMethodWithSignature(this, name, signature, pointer_size);
506 }
507
FindInterfaceMethod(ObjPtr<DexCache> dex_cache,uint32_t dex_method_idx,PointerSize pointer_size)508 ArtMethod* Class::FindInterfaceMethod(ObjPtr<DexCache> dex_cache,
509 uint32_t dex_method_idx,
510 PointerSize pointer_size) {
511 // We always search by name and signature, ignoring the type index in the MethodId.
512 const DexFile& dex_file = *dex_cache->GetDexFile();
513 const DexFile::MethodId& method_id = dex_file.GetMethodId(dex_method_idx);
514 StringPiece name = dex_file.StringDataByIdx(method_id.name_idx_);
515 const Signature signature = dex_file.GetMethodSignature(method_id);
516 return FindInterfaceMethod(name, signature, pointer_size);
517 }
518
IsValidInheritanceCheck(ObjPtr<mirror::Class> klass,ObjPtr<mirror::Class> declaring_class)519 static inline bool IsValidInheritanceCheck(ObjPtr<mirror::Class> klass,
520 ObjPtr<mirror::Class> declaring_class)
521 REQUIRES_SHARED(Locks::mutator_lock_) {
522 if (klass->IsArrayClass()) {
523 return declaring_class->IsObjectClass();
524 } else if (klass->IsInterface()) {
525 return declaring_class->IsObjectClass() || declaring_class == klass;
526 } else {
527 return klass->IsSubClass(declaring_class);
528 }
529 }
530
IsInheritedMethod(ObjPtr<mirror::Class> klass,ObjPtr<mirror::Class> declaring_class,ArtMethod & method)531 static inline bool IsInheritedMethod(ObjPtr<mirror::Class> klass,
532 ObjPtr<mirror::Class> declaring_class,
533 ArtMethod& method)
534 REQUIRES_SHARED(Locks::mutator_lock_) {
535 DCHECK_EQ(declaring_class, method.GetDeclaringClass());
536 DCHECK_NE(klass, declaring_class);
537 DCHECK(IsValidInheritanceCheck(klass, declaring_class));
538 uint32_t access_flags = method.GetAccessFlags();
539 if ((access_flags & (kAccPublic | kAccProtected)) != 0) {
540 return true;
541 }
542 if ((access_flags & kAccPrivate) != 0) {
543 return false;
544 }
545 for (; klass != declaring_class; klass = klass->GetSuperClass()) {
546 if (!klass->IsInSamePackage(declaring_class)) {
547 return false;
548 }
549 }
550 return true;
551 }
552
553 template <typename SignatureType>
FindClassMethodWithSignature(ObjPtr<Class> this_klass,const StringPiece & name,const SignatureType & signature,PointerSize pointer_size)554 static inline ArtMethod* FindClassMethodWithSignature(ObjPtr<Class> this_klass,
555 const StringPiece& name,
556 const SignatureType& signature,
557 PointerSize pointer_size)
558 REQUIRES_SHARED(Locks::mutator_lock_) {
559 // Search declared methods first.
560 for (ArtMethod& method : this_klass->GetDeclaredMethodsSlice(pointer_size)) {
561 ArtMethod* np_method = method.GetInterfaceMethodIfProxy(pointer_size);
562 if (np_method->GetName() == name && np_method->GetSignature() == signature) {
563 return &method;
564 }
565 }
566
567 // Then search the superclass chain. If we find an inherited method, return it.
568 // If we find a method that's not inherited because of access restrictions,
569 // try to find a method inherited from an interface in copied methods.
570 ObjPtr<Class> klass = this_klass->GetSuperClass();
571 ArtMethod* uninherited_method = nullptr;
572 for (; klass != nullptr; klass = klass->GetSuperClass()) {
573 DCHECK(!klass->IsProxyClass());
574 for (ArtMethod& method : klass->GetDeclaredMethodsSlice(pointer_size)) {
575 if (method.GetName() == name && method.GetSignature() == signature) {
576 if (IsInheritedMethod(this_klass, klass, method)) {
577 return &method;
578 }
579 uninherited_method = &method;
580 break;
581 }
582 }
583 if (uninherited_method != nullptr) {
584 break;
585 }
586 }
587
588 // Then search copied methods.
589 // If we found a method that's not inherited, stop the search in its declaring class.
590 ObjPtr<Class> end_klass = klass;
591 DCHECK_EQ(uninherited_method != nullptr, end_klass != nullptr);
592 klass = this_klass;
593 if (UNLIKELY(klass->IsProxyClass())) {
594 DCHECK(klass->GetCopiedMethodsSlice(pointer_size).empty());
595 klass = klass->GetSuperClass();
596 }
597 for (; klass != end_klass; klass = klass->GetSuperClass()) {
598 DCHECK(!klass->IsProxyClass());
599 for (ArtMethod& method : klass->GetCopiedMethodsSlice(pointer_size)) {
600 if (method.GetName() == name && method.GetSignature() == signature) {
601 return &method; // No further check needed, copied methods are inherited by definition.
602 }
603 }
604 }
605 return uninherited_method; // Return the `uninherited_method` if any.
606 }
607
608
FindClassMethod(const StringPiece & name,const StringPiece & signature,PointerSize pointer_size)609 ArtMethod* Class::FindClassMethod(const StringPiece& name,
610 const StringPiece& signature,
611 PointerSize pointer_size) {
612 return FindClassMethodWithSignature(this, name, signature, pointer_size);
613 }
614
FindClassMethod(const StringPiece & name,const Signature & signature,PointerSize pointer_size)615 ArtMethod* Class::FindClassMethod(const StringPiece& name,
616 const Signature& signature,
617 PointerSize pointer_size) {
618 return FindClassMethodWithSignature(this, name, signature, pointer_size);
619 }
620
FindClassMethod(ObjPtr<DexCache> dex_cache,uint32_t dex_method_idx,PointerSize pointer_size)621 ArtMethod* Class::FindClassMethod(ObjPtr<DexCache> dex_cache,
622 uint32_t dex_method_idx,
623 PointerSize pointer_size) {
624 // FIXME: Hijacking a proxy class by a custom class loader can break this assumption.
625 DCHECK(!IsProxyClass());
626
627 // First try to find a declared method by dex_method_idx if we have a dex_cache match.
628 ObjPtr<DexCache> this_dex_cache = GetDexCache();
629 if (this_dex_cache == dex_cache) {
630 // Lookup is always performed in the class referenced by the MethodId.
631 DCHECK_EQ(dex_type_idx_, GetDexFile().GetMethodId(dex_method_idx).class_idx_.index_);
632 for (ArtMethod& method : GetDeclaredMethodsSlice(pointer_size)) {
633 if (method.GetDexMethodIndex() == dex_method_idx) {
634 return &method;
635 }
636 }
637 }
638 // If not found, we need to search by name and signature.
639 const DexFile& dex_file = *dex_cache->GetDexFile();
640 const DexFile::MethodId& method_id = dex_file.GetMethodId(dex_method_idx);
641 const Signature signature = dex_file.GetMethodSignature(method_id);
642 StringPiece name; // Delay strlen() until actually needed.
643 // If we do not have a dex_cache match, try to find the declared method in this class now.
644 if (this_dex_cache != dex_cache && !GetDeclaredMethodsSlice(pointer_size).empty()) {
645 DCHECK(name.empty());
646 name = dex_file.StringDataByIdx(method_id.name_idx_);
647 for (ArtMethod& method : GetDeclaredMethodsSlice(pointer_size)) {
648 if (method.GetName() == name && method.GetSignature() == signature) {
649 return &method;
650 }
651 }
652 }
653
654 // Then search the superclass chain. If we find an inherited method, return it.
655 // If we find a method that's not inherited because of access restrictions,
656 // try to find a method inherited from an interface in copied methods.
657 ArtMethod* uninherited_method = nullptr;
658 ObjPtr<Class> klass = GetSuperClass();
659 for (; klass != nullptr; klass = klass->GetSuperClass()) {
660 ArtMethod* candidate_method = nullptr;
661 ArraySlice<ArtMethod> declared_methods = klass->GetDeclaredMethodsSlice(pointer_size);
662 if (klass->GetDexCache() == dex_cache) {
663 // Matching dex_cache. We cannot compare the `dex_method_idx` anymore because
664 // the type index differs, so compare the name index and proto index.
665 for (ArtMethod& method : declared_methods) {
666 const DexFile::MethodId& cmp_method_id = dex_file.GetMethodId(method.GetDexMethodIndex());
667 if (cmp_method_id.name_idx_ == method_id.name_idx_ &&
668 cmp_method_id.proto_idx_ == method_id.proto_idx_) {
669 candidate_method = &method;
670 break;
671 }
672 }
673 } else {
674 if (!declared_methods.empty() && name.empty()) {
675 name = dex_file.StringDataByIdx(method_id.name_idx_);
676 }
677 for (ArtMethod& method : declared_methods) {
678 if (method.GetName() == name && method.GetSignature() == signature) {
679 candidate_method = &method;
680 break;
681 }
682 }
683 }
684 if (candidate_method != nullptr) {
685 if (IsInheritedMethod(this, klass, *candidate_method)) {
686 return candidate_method;
687 } else {
688 uninherited_method = candidate_method;
689 break;
690 }
691 }
692 }
693
694 // Then search copied methods.
695 // If we found a method that's not inherited, stop the search in its declaring class.
696 ObjPtr<Class> end_klass = klass;
697 DCHECK_EQ(uninherited_method != nullptr, end_klass != nullptr);
698 // After we have searched the declared methods of the super-class chain,
699 // search copied methods which can contain methods from interfaces.
700 for (klass = this; klass != end_klass; klass = klass->GetSuperClass()) {
701 ArraySlice<ArtMethod> copied_methods = klass->GetCopiedMethodsSlice(pointer_size);
702 if (!copied_methods.empty() && name.empty()) {
703 name = dex_file.StringDataByIdx(method_id.name_idx_);
704 }
705 for (ArtMethod& method : copied_methods) {
706 if (method.GetName() == name && method.GetSignature() == signature) {
707 return &method; // No further check needed, copied methods are inherited by definition.
708 }
709 }
710 }
711 return uninherited_method; // Return the `uninherited_method` if any.
712 }
713
FindConstructor(const StringPiece & signature,PointerSize pointer_size)714 ArtMethod* Class::FindConstructor(const StringPiece& signature, PointerSize pointer_size) {
715 // Internal helper, never called on proxy classes. We can skip GetInterfaceMethodIfProxy().
716 DCHECK(!IsProxyClass());
717 StringPiece name("<init>");
718 for (ArtMethod& method : GetDirectMethodsSliceUnchecked(pointer_size)) {
719 if (method.GetName() == name && method.GetSignature() == signature) {
720 return &method;
721 }
722 }
723 return nullptr;
724 }
725
FindDeclaredDirectMethodByName(const StringPiece & name,PointerSize pointer_size)726 ArtMethod* Class::FindDeclaredDirectMethodByName(const StringPiece& name,
727 PointerSize pointer_size) {
728 for (auto& method : GetDirectMethods(pointer_size)) {
729 ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
730 if (name == np_method->GetName()) {
731 return &method;
732 }
733 }
734 return nullptr;
735 }
736
FindDeclaredVirtualMethodByName(const StringPiece & name,PointerSize pointer_size)737 ArtMethod* Class::FindDeclaredVirtualMethodByName(const StringPiece& name,
738 PointerSize pointer_size) {
739 for (auto& method : GetVirtualMethods(pointer_size)) {
740 ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
741 if (name == np_method->GetName()) {
742 return &method;
743 }
744 }
745 return nullptr;
746 }
747
FindVirtualMethodForInterfaceSuper(ArtMethod * method,PointerSize pointer_size)748 ArtMethod* Class::FindVirtualMethodForInterfaceSuper(ArtMethod* method, PointerSize pointer_size) {
749 DCHECK(method->GetDeclaringClass()->IsInterface());
750 DCHECK(IsInterface()) << "Should only be called on a interface class";
751 // Check if we have one defined on this interface first. This includes searching copied ones to
752 // get any conflict methods. Conflict methods are copied into each subtype from the supertype. We
753 // don't do any indirect method checks here.
754 for (ArtMethod& iface_method : GetVirtualMethods(pointer_size)) {
755 if (method->HasSameNameAndSignature(&iface_method)) {
756 return &iface_method;
757 }
758 }
759
760 std::vector<ArtMethod*> abstract_methods;
761 // Search through the IFTable for a working version. We don't need to check for conflicts
762 // because if there was one it would appear in this classes virtual_methods_ above.
763
764 Thread* self = Thread::Current();
765 StackHandleScope<2> hs(self);
766 MutableHandle<IfTable> iftable(hs.NewHandle(GetIfTable()));
767 MutableHandle<Class> iface(hs.NewHandle<Class>(nullptr));
768 size_t iftable_count = GetIfTableCount();
769 // Find the method. We don't need to check for conflicts because they would have been in the
770 // copied virtuals of this interface. Order matters, traverse in reverse topological order; most
771 // subtypiest interfaces get visited first.
772 for (size_t k = iftable_count; k != 0;) {
773 k--;
774 DCHECK_LT(k, iftable->Count());
775 iface.Assign(iftable->GetInterface(k));
776 // Iterate through every declared method on this interface. Each direct method's name/signature
777 // is unique so the order of the inner loop doesn't matter.
778 for (auto& method_iter : iface->GetDeclaredVirtualMethods(pointer_size)) {
779 ArtMethod* current_method = &method_iter;
780 if (current_method->HasSameNameAndSignature(method)) {
781 if (current_method->IsDefault()) {
782 // Handle JLS soft errors, a default method from another superinterface tree can
783 // "override" an abstract method(s) from another superinterface tree(s). To do this,
784 // ignore any [default] method which are dominated by the abstract methods we've seen so
785 // far. Check if overridden by any in abstract_methods. We do not need to check for
786 // default_conflicts because we would hit those before we get to this loop.
787 bool overridden = false;
788 for (ArtMethod* possible_override : abstract_methods) {
789 DCHECK(possible_override->HasSameNameAndSignature(current_method));
790 if (iface->IsAssignableFrom(possible_override->GetDeclaringClass())) {
791 overridden = true;
792 break;
793 }
794 }
795 if (!overridden) {
796 return current_method;
797 }
798 } else {
799 // Is not default.
800 // This might override another default method. Just stash it for now.
801 abstract_methods.push_back(current_method);
802 }
803 }
804 }
805 }
806 // If we reach here we either never found any declaration of the method (in which case
807 // 'abstract_methods' is empty or we found no non-overriden default methods in which case
808 // 'abstract_methods' contains a number of abstract implementations of the methods. We choose one
809 // of these arbitrarily.
810 return abstract_methods.empty() ? nullptr : abstract_methods[0];
811 }
812
FindClassInitializer(PointerSize pointer_size)813 ArtMethod* Class::FindClassInitializer(PointerSize pointer_size) {
814 for (ArtMethod& method : GetDirectMethods(pointer_size)) {
815 if (method.IsClassInitializer()) {
816 DCHECK_STREQ(method.GetName(), "<clinit>");
817 DCHECK_STREQ(method.GetSignature().ToString().c_str(), "()V");
818 return &method;
819 }
820 }
821 return nullptr;
822 }
823
824 // Custom binary search to avoid double comparisons from std::binary_search.
FindFieldByNameAndType(LengthPrefixedArray<ArtField> * fields,const StringPiece & name,const StringPiece & type)825 static ArtField* FindFieldByNameAndType(LengthPrefixedArray<ArtField>* fields,
826 const StringPiece& name,
827 const StringPiece& type)
828 REQUIRES_SHARED(Locks::mutator_lock_) {
829 if (fields == nullptr) {
830 return nullptr;
831 }
832 size_t low = 0;
833 size_t high = fields->size();
834 ArtField* ret = nullptr;
835 while (low < high) {
836 size_t mid = (low + high) / 2;
837 ArtField& field = fields->At(mid);
838 // Fields are sorted by class, then name, then type descriptor. This is verified in dex file
839 // verifier. There can be multiple fields with the same in the same class name due to proguard.
840 int result = StringPiece(field.GetName()).Compare(name);
841 if (result == 0) {
842 result = StringPiece(field.GetTypeDescriptor()).Compare(type);
843 }
844 if (result < 0) {
845 low = mid + 1;
846 } else if (result > 0) {
847 high = mid;
848 } else {
849 ret = &field;
850 break;
851 }
852 }
853 if (kIsDebugBuild) {
854 ArtField* found = nullptr;
855 for (ArtField& field : MakeIterationRangeFromLengthPrefixedArray(fields)) {
856 if (name == field.GetName() && type == field.GetTypeDescriptor()) {
857 found = &field;
858 break;
859 }
860 }
861 CHECK_EQ(found, ret) << "Found " << found->PrettyField() << " vs " << ret->PrettyField();
862 }
863 return ret;
864 }
865
FindDeclaredInstanceField(const StringPiece & name,const StringPiece & type)866 ArtField* Class::FindDeclaredInstanceField(const StringPiece& name, const StringPiece& type) {
867 // Binary search by name. Interfaces are not relevant because they can't contain instance fields.
868 return FindFieldByNameAndType(GetIFieldsPtr(), name, type);
869 }
870
FindDeclaredInstanceField(ObjPtr<DexCache> dex_cache,uint32_t dex_field_idx)871 ArtField* Class::FindDeclaredInstanceField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
872 if (GetDexCache() == dex_cache) {
873 for (ArtField& field : GetIFields()) {
874 if (field.GetDexFieldIndex() == dex_field_idx) {
875 return &field;
876 }
877 }
878 }
879 return nullptr;
880 }
881
FindInstanceField(const StringPiece & name,const StringPiece & type)882 ArtField* Class::FindInstanceField(const StringPiece& name, const StringPiece& type) {
883 // Is the field in this class, or any of its superclasses?
884 // Interfaces are not relevant because they can't contain instance fields.
885 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
886 ArtField* f = c->FindDeclaredInstanceField(name, type);
887 if (f != nullptr) {
888 return f;
889 }
890 }
891 return nullptr;
892 }
893
FindInstanceField(ObjPtr<DexCache> dex_cache,uint32_t dex_field_idx)894 ArtField* Class::FindInstanceField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
895 // Is the field in this class, or any of its superclasses?
896 // Interfaces are not relevant because they can't contain instance fields.
897 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
898 ArtField* f = c->FindDeclaredInstanceField(dex_cache, dex_field_idx);
899 if (f != nullptr) {
900 return f;
901 }
902 }
903 return nullptr;
904 }
905
FindDeclaredStaticField(const StringPiece & name,const StringPiece & type)906 ArtField* Class::FindDeclaredStaticField(const StringPiece& name, const StringPiece& type) {
907 DCHECK(type != nullptr);
908 return FindFieldByNameAndType(GetSFieldsPtr(), name, type);
909 }
910
FindDeclaredStaticField(ObjPtr<DexCache> dex_cache,uint32_t dex_field_idx)911 ArtField* Class::FindDeclaredStaticField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
912 if (dex_cache == GetDexCache()) {
913 for (ArtField& field : GetSFields()) {
914 if (field.GetDexFieldIndex() == dex_field_idx) {
915 return &field;
916 }
917 }
918 }
919 return nullptr;
920 }
921
FindStaticField(Thread * self,ObjPtr<Class> klass,const StringPiece & name,const StringPiece & type)922 ArtField* Class::FindStaticField(Thread* self,
923 ObjPtr<Class> klass,
924 const StringPiece& name,
925 const StringPiece& type) {
926 // Is the field in this class (or its interfaces), or any of its
927 // superclasses (or their interfaces)?
928 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
929 // Is the field in this class?
930 ArtField* f = k->FindDeclaredStaticField(name, type);
931 if (f != nullptr) {
932 return f;
933 }
934 // Is this field in any of this class' interfaces?
935 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
936 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
937 DCHECK(interface != nullptr);
938 f = FindStaticField(self, interface, name, type);
939 if (f != nullptr) {
940 return f;
941 }
942 }
943 }
944 return nullptr;
945 }
946
FindStaticField(Thread * self,ObjPtr<Class> klass,ObjPtr<DexCache> dex_cache,uint32_t dex_field_idx)947 ArtField* Class::FindStaticField(Thread* self,
948 ObjPtr<Class> klass,
949 ObjPtr<DexCache> dex_cache,
950 uint32_t dex_field_idx) {
951 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
952 // Is the field in this class?
953 ArtField* f = k->FindDeclaredStaticField(dex_cache, dex_field_idx);
954 if (f != nullptr) {
955 return f;
956 }
957 // Though GetDirectInterface() should not cause thread suspension when called
958 // from here, it takes a Handle as an argument, so we need to wrap `k`.
959 ScopedAssertNoThreadSuspension ants(__FUNCTION__);
960 // Is this field in any of this class' interfaces?
961 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
962 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
963 DCHECK(interface != nullptr);
964 f = FindStaticField(self, interface, dex_cache, dex_field_idx);
965 if (f != nullptr) {
966 return f;
967 }
968 }
969 }
970 return nullptr;
971 }
972
FindField(Thread * self,ObjPtr<Class> klass,const StringPiece & name,const StringPiece & type)973 ArtField* Class::FindField(Thread* self,
974 ObjPtr<Class> klass,
975 const StringPiece& name,
976 const StringPiece& type) {
977 // Find a field using the JLS field resolution order
978 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
979 // Is the field in this class?
980 ArtField* f = k->FindDeclaredInstanceField(name, type);
981 if (f != nullptr) {
982 return f;
983 }
984 f = k->FindDeclaredStaticField(name, type);
985 if (f != nullptr) {
986 return f;
987 }
988 // Is this field in any of this class' interfaces?
989 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
990 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
991 DCHECK(interface != nullptr);
992 f = FindStaticField(self, interface, name, type);
993 if (f != nullptr) {
994 return f;
995 }
996 }
997 }
998 return nullptr;
999 }
1000
SetSkipAccessChecksFlagOnAllMethods(PointerSize pointer_size)1001 void Class::SetSkipAccessChecksFlagOnAllMethods(PointerSize pointer_size) {
1002 DCHECK(IsVerified());
1003 for (auto& m : GetMethods(pointer_size)) {
1004 if (!m.IsNative() && m.IsInvokable()) {
1005 m.SetSkipAccessChecks();
1006 }
1007 }
1008 }
1009
GetDescriptor(std::string * storage)1010 const char* Class::GetDescriptor(std::string* storage) {
1011 if (IsPrimitive()) {
1012 return Primitive::Descriptor(GetPrimitiveType());
1013 } else if (IsArrayClass()) {
1014 return GetArrayDescriptor(storage);
1015 } else if (IsProxyClass()) {
1016 *storage = Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this);
1017 return storage->c_str();
1018 } else {
1019 const DexFile& dex_file = GetDexFile();
1020 const DexFile::TypeId& type_id = dex_file.GetTypeId(GetClassDef()->class_idx_);
1021 return dex_file.GetTypeDescriptor(type_id);
1022 }
1023 }
1024
GetArrayDescriptor(std::string * storage)1025 const char* Class::GetArrayDescriptor(std::string* storage) {
1026 std::string temp;
1027 const char* elem_desc = GetComponentType()->GetDescriptor(&temp);
1028 *storage = "[";
1029 *storage += elem_desc;
1030 return storage->c_str();
1031 }
1032
GetClassDef()1033 const DexFile::ClassDef* Class::GetClassDef() {
1034 uint16_t class_def_idx = GetDexClassDefIndex();
1035 if (class_def_idx == DexFile::kDexNoIndex16) {
1036 return nullptr;
1037 }
1038 return &GetDexFile().GetClassDef(class_def_idx);
1039 }
1040
GetDirectInterfaceTypeIdx(uint32_t idx)1041 dex::TypeIndex Class::GetDirectInterfaceTypeIdx(uint32_t idx) {
1042 DCHECK(!IsPrimitive());
1043 DCHECK(!IsArrayClass());
1044 return GetInterfaceTypeList()->GetTypeItem(idx).type_idx_;
1045 }
1046
GetDirectInterface(Thread * self,ObjPtr<Class> klass,uint32_t idx)1047 ObjPtr<Class> Class::GetDirectInterface(Thread* self, ObjPtr<Class> klass, uint32_t idx) {
1048 DCHECK(klass != nullptr);
1049 DCHECK(!klass->IsPrimitive());
1050 if (klass->IsArrayClass()) {
1051 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
1052 // Use ClassLinker::LookupClass(); avoid poisoning ObjPtr<>s by ClassLinker::FindSystemClass().
1053 ObjPtr<Class> interface;
1054 if (idx == 0) {
1055 interface = class_linker->LookupClass(self, "Ljava/lang/Cloneable;", nullptr);
1056 } else {
1057 DCHECK_EQ(1U, idx);
1058 interface = class_linker->LookupClass(self, "Ljava/io/Serializable;", nullptr);
1059 }
1060 DCHECK(interface != nullptr);
1061 return interface;
1062 } else if (klass->IsProxyClass()) {
1063 ObjPtr<ObjectArray<Class>> interfaces = klass->GetProxyInterfaces();
1064 DCHECK(interfaces != nullptr);
1065 return interfaces->Get(idx);
1066 } else {
1067 dex::TypeIndex type_idx = klass->GetDirectInterfaceTypeIdx(idx);
1068 ObjPtr<Class> interface = Runtime::Current()->GetClassLinker()->LookupResolvedType(
1069 type_idx, klass->GetDexCache(), klass->GetClassLoader());
1070 return interface;
1071 }
1072 }
1073
ResolveDirectInterface(Thread * self,Handle<Class> klass,uint32_t idx)1074 ObjPtr<Class> Class::ResolveDirectInterface(Thread* self, Handle<Class> klass, uint32_t idx) {
1075 ObjPtr<Class> interface = GetDirectInterface(self, klass.Get(), idx);
1076 if (interface == nullptr) {
1077 DCHECK(!klass->IsArrayClass());
1078 DCHECK(!klass->IsProxyClass());
1079 dex::TypeIndex type_idx = klass->GetDirectInterfaceTypeIdx(idx);
1080 interface = Runtime::Current()->GetClassLinker()->ResolveType(type_idx, klass.Get());
1081 CHECK(interface != nullptr || self->IsExceptionPending());
1082 }
1083 return interface;
1084 }
1085
GetCommonSuperClass(Handle<Class> klass)1086 ObjPtr<Class> Class::GetCommonSuperClass(Handle<Class> klass) {
1087 DCHECK(klass != nullptr);
1088 DCHECK(!klass->IsInterface());
1089 DCHECK(!IsInterface());
1090 ObjPtr<Class> common_super_class = this;
1091 while (!common_super_class->IsAssignableFrom(klass.Get())) {
1092 ObjPtr<Class> old_common = common_super_class;
1093 common_super_class = old_common->GetSuperClass();
1094 DCHECK(common_super_class != nullptr) << old_common->PrettyClass();
1095 }
1096 return common_super_class;
1097 }
1098
GetSourceFile()1099 const char* Class::GetSourceFile() {
1100 const DexFile& dex_file = GetDexFile();
1101 const DexFile::ClassDef* dex_class_def = GetClassDef();
1102 if (dex_class_def == nullptr) {
1103 // Generated classes have no class def.
1104 return nullptr;
1105 }
1106 return dex_file.GetSourceFile(*dex_class_def);
1107 }
1108
GetLocation()1109 std::string Class::GetLocation() {
1110 ObjPtr<DexCache> dex_cache = GetDexCache();
1111 if (dex_cache != nullptr && !IsProxyClass()) {
1112 return dex_cache->GetLocation()->ToModifiedUtf8();
1113 }
1114 // Arrays and proxies are generated and have no corresponding dex file location.
1115 return "generated class";
1116 }
1117
GetInterfaceTypeList()1118 const DexFile::TypeList* Class::GetInterfaceTypeList() {
1119 const DexFile::ClassDef* class_def = GetClassDef();
1120 if (class_def == nullptr) {
1121 return nullptr;
1122 }
1123 return GetDexFile().GetInterfacesList(*class_def);
1124 }
1125
PopulateEmbeddedVTable(PointerSize pointer_size)1126 void Class::PopulateEmbeddedVTable(PointerSize pointer_size) {
1127 PointerArray* table = GetVTableDuringLinking();
1128 CHECK(table != nullptr) << PrettyClass();
1129 const size_t table_length = table->GetLength();
1130 SetEmbeddedVTableLength(table_length);
1131 for (size_t i = 0; i < table_length; i++) {
1132 SetEmbeddedVTableEntry(i, table->GetElementPtrSize<ArtMethod*>(i, pointer_size), pointer_size);
1133 }
1134 // Keep java.lang.Object class's vtable around for since it's easier
1135 // to be reused by array classes during their linking.
1136 if (!IsObjectClass()) {
1137 SetVTable(nullptr);
1138 }
1139 }
1140
1141 class ReadBarrierOnNativeRootsVisitor {
1142 public:
operator ()(ObjPtr<Object> obj ATTRIBUTE_UNUSED,MemberOffset offset ATTRIBUTE_UNUSED,bool is_static ATTRIBUTE_UNUSED) const1143 void operator()(ObjPtr<Object> obj ATTRIBUTE_UNUSED,
1144 MemberOffset offset ATTRIBUTE_UNUSED,
1145 bool is_static ATTRIBUTE_UNUSED) const {}
1146
VisitRootIfNonNull(CompressedReference<Object> * root) const1147 void VisitRootIfNonNull(CompressedReference<Object>* root) const
1148 REQUIRES_SHARED(Locks::mutator_lock_) {
1149 if (!root->IsNull()) {
1150 VisitRoot(root);
1151 }
1152 }
1153
VisitRoot(CompressedReference<Object> * root) const1154 void VisitRoot(CompressedReference<Object>* root) const
1155 REQUIRES_SHARED(Locks::mutator_lock_) {
1156 ObjPtr<Object> old_ref = root->AsMirrorPtr();
1157 ObjPtr<Object> new_ref = ReadBarrier::BarrierForRoot(root);
1158 if (old_ref != new_ref) {
1159 // Update the field atomically. This may fail if mutator updates before us, but it's ok.
1160 auto* atomic_root =
1161 reinterpret_cast<Atomic<CompressedReference<Object>>*>(root);
1162 atomic_root->CompareAndSetStrongSequentiallyConsistent(
1163 CompressedReference<Object>::FromMirrorPtr(old_ref.Ptr()),
1164 CompressedReference<Object>::FromMirrorPtr(new_ref.Ptr()));
1165 }
1166 }
1167 };
1168
1169 // The pre-fence visitor for Class::CopyOf().
1170 class CopyClassVisitor {
1171 public:
CopyClassVisitor(Thread * self,Handle<Class> * orig,size_t new_length,size_t copy_bytes,ImTable * imt,PointerSize pointer_size)1172 CopyClassVisitor(Thread* self,
1173 Handle<Class>* orig,
1174 size_t new_length,
1175 size_t copy_bytes,
1176 ImTable* imt,
1177 PointerSize pointer_size)
1178 : self_(self), orig_(orig), new_length_(new_length),
1179 copy_bytes_(copy_bytes), imt_(imt), pointer_size_(pointer_size) {
1180 }
1181
operator ()(ObjPtr<Object> obj,size_t usable_size ATTRIBUTE_UNUSED) const1182 void operator()(ObjPtr<Object> obj, size_t usable_size ATTRIBUTE_UNUSED) const
1183 REQUIRES_SHARED(Locks::mutator_lock_) {
1184 StackHandleScope<1> hs(self_);
1185 Handle<mirror::Class> h_new_class_obj(hs.NewHandle(obj->AsClass()));
1186 Object::CopyObject(h_new_class_obj.Get(), orig_->Get(), copy_bytes_);
1187 Class::SetStatus(h_new_class_obj, ClassStatus::kResolving, self_);
1188 h_new_class_obj->PopulateEmbeddedVTable(pointer_size_);
1189 h_new_class_obj->SetImt(imt_, pointer_size_);
1190 h_new_class_obj->SetClassSize(new_length_);
1191 // Visit all of the references to make sure there is no from space references in the native
1192 // roots.
1193 ObjPtr<Object>(h_new_class_obj.Get())->VisitReferences(
1194 ReadBarrierOnNativeRootsVisitor(), VoidFunctor());
1195 }
1196
1197 private:
1198 Thread* const self_;
1199 Handle<Class>* const orig_;
1200 const size_t new_length_;
1201 const size_t copy_bytes_;
1202 ImTable* imt_;
1203 const PointerSize pointer_size_;
1204 DISALLOW_COPY_AND_ASSIGN(CopyClassVisitor);
1205 };
1206
CopyOf(Thread * self,int32_t new_length,ImTable * imt,PointerSize pointer_size)1207 Class* Class::CopyOf(Thread* self, int32_t new_length, ImTable* imt, PointerSize pointer_size) {
1208 DCHECK_GE(new_length, static_cast<int32_t>(sizeof(Class)));
1209 // We may get copied by a compacting GC.
1210 StackHandleScope<1> hs(self);
1211 Handle<Class> h_this(hs.NewHandle(this));
1212 gc::Heap* heap = Runtime::Current()->GetHeap();
1213 // The num_bytes (3rd param) is sizeof(Class) as opposed to SizeOf()
1214 // to skip copying the tail part that we will overwrite here.
1215 CopyClassVisitor visitor(self, &h_this, new_length, sizeof(Class), imt, pointer_size);
1216 ObjPtr<Object> new_class = kMovingClasses ?
1217 heap->AllocObject<true>(self, java_lang_Class_.Read(), new_length, visitor) :
1218 heap->AllocNonMovableObject<true>(self, java_lang_Class_.Read(), new_length, visitor);
1219 if (UNLIKELY(new_class == nullptr)) {
1220 self->AssertPendingOOMException();
1221 return nullptr;
1222 }
1223 return new_class->AsClass();
1224 }
1225
ProxyDescriptorEquals(const char * match)1226 bool Class::ProxyDescriptorEquals(const char* match) {
1227 DCHECK(IsProxyClass());
1228 return Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this) == match;
1229 }
1230
1231 // TODO: Move this to java_lang_Class.cc?
GetDeclaredConstructor(Thread * self,Handle<ObjectArray<Class>> args,PointerSize pointer_size)1232 ArtMethod* Class::GetDeclaredConstructor(
1233 Thread* self, Handle<ObjectArray<Class>> args, PointerSize pointer_size) {
1234 for (auto& m : GetDirectMethods(pointer_size)) {
1235 // Skip <clinit> which is a static constructor, as well as non constructors.
1236 if (m.IsStatic() || !m.IsConstructor()) {
1237 continue;
1238 }
1239 // May cause thread suspension and exceptions.
1240 if (m.GetInterfaceMethodIfProxy(kRuntimePointerSize)->EqualParameters(args)) {
1241 return &m;
1242 }
1243 if (UNLIKELY(self->IsExceptionPending())) {
1244 return nullptr;
1245 }
1246 }
1247 return nullptr;
1248 }
1249
Depth()1250 uint32_t Class::Depth() {
1251 uint32_t depth = 0;
1252 for (ObjPtr<Class> klass = this; klass->GetSuperClass() != nullptr; klass = klass->GetSuperClass()) {
1253 depth++;
1254 }
1255 return depth;
1256 }
1257
FindTypeIndexInOtherDexFile(const DexFile & dex_file)1258 dex::TypeIndex Class::FindTypeIndexInOtherDexFile(const DexFile& dex_file) {
1259 std::string temp;
1260 const DexFile::TypeId* type_id = dex_file.FindTypeId(GetDescriptor(&temp));
1261 return (type_id == nullptr) ? dex::TypeIndex() : dex_file.GetIndexForTypeId(*type_id);
1262 }
1263
1264 template <PointerSize kPointerSize, bool kTransactionActive>
GetDeclaredMethodInternal(Thread * self,ObjPtr<Class> klass,ObjPtr<String> name,ObjPtr<ObjectArray<Class>> args)1265 ObjPtr<Method> Class::GetDeclaredMethodInternal(
1266 Thread* self,
1267 ObjPtr<Class> klass,
1268 ObjPtr<String> name,
1269 ObjPtr<ObjectArray<Class>> args) {
1270 // Covariant return types permit the class to define multiple
1271 // methods with the same name and parameter types. Prefer to
1272 // return a non-synthetic method in such situations. We may
1273 // still return a synthetic method to handle situations like
1274 // escalated visibility. We never return miranda methods that
1275 // were synthesized by the runtime.
1276 StackHandleScope<3> hs(self);
1277 auto h_method_name = hs.NewHandle(name);
1278 if (UNLIKELY(h_method_name == nullptr)) {
1279 ThrowNullPointerException("name == null");
1280 return nullptr;
1281 }
1282 auto h_args = hs.NewHandle(args);
1283 Handle<Class> h_klass = hs.NewHandle(klass);
1284 ArtMethod* result = nullptr;
1285 for (auto& m : h_klass->GetDeclaredVirtualMethods(kPointerSize)) {
1286 auto* np_method = m.GetInterfaceMethodIfProxy(kPointerSize);
1287 // May cause thread suspension.
1288 ObjPtr<String> np_name = np_method->GetNameAsString(self);
1289 if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1290 if (UNLIKELY(self->IsExceptionPending())) {
1291 return nullptr;
1292 }
1293 continue;
1294 }
1295 if (!m.IsMiranda()) {
1296 if (!m.IsSynthetic()) {
1297 return Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, &m);
1298 }
1299 result = &m; // Remember as potential result if it's not a miranda method.
1300 }
1301 }
1302 if (result == nullptr) {
1303 for (auto& m : h_klass->GetDirectMethods(kPointerSize)) {
1304 auto modifiers = m.GetAccessFlags();
1305 if ((modifiers & kAccConstructor) != 0) {
1306 continue;
1307 }
1308 auto* np_method = m.GetInterfaceMethodIfProxy(kPointerSize);
1309 // May cause thread suspension.
1310 ObjPtr<String> np_name = np_method->GetNameAsString(self);
1311 if (np_name == nullptr) {
1312 self->AssertPendingException();
1313 return nullptr;
1314 }
1315 if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1316 if (UNLIKELY(self->IsExceptionPending())) {
1317 return nullptr;
1318 }
1319 continue;
1320 }
1321 DCHECK(!m.IsMiranda()); // Direct methods cannot be miranda methods.
1322 if ((modifiers & kAccSynthetic) == 0) {
1323 return Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, &m);
1324 }
1325 result = &m; // Remember as potential result.
1326 }
1327 }
1328 return result != nullptr
1329 ? Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, result)
1330 : nullptr;
1331 }
1332
1333 template
1334 ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k32, false>(
1335 Thread* self,
1336 ObjPtr<Class> klass,
1337 ObjPtr<String> name,
1338 ObjPtr<ObjectArray<Class>> args);
1339 template
1340 ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k32, true>(
1341 Thread* self,
1342 ObjPtr<Class> klass,
1343 ObjPtr<String> name,
1344 ObjPtr<ObjectArray<Class>> args);
1345 template
1346 ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k64, false>(
1347 Thread* self,
1348 ObjPtr<Class> klass,
1349 ObjPtr<String> name,
1350 ObjPtr<ObjectArray<Class>> args);
1351 template
1352 ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k64, true>(
1353 Thread* self,
1354 ObjPtr<Class> klass,
1355 ObjPtr<String> name,
1356 ObjPtr<ObjectArray<Class>> args);
1357
1358 template <PointerSize kPointerSize, bool kTransactionActive>
GetDeclaredConstructorInternal(Thread * self,ObjPtr<Class> klass,ObjPtr<ObjectArray<Class>> args)1359 ObjPtr<Constructor> Class::GetDeclaredConstructorInternal(
1360 Thread* self,
1361 ObjPtr<Class> klass,
1362 ObjPtr<ObjectArray<Class>> args) {
1363 StackHandleScope<1> hs(self);
1364 ArtMethod* result = klass->GetDeclaredConstructor(self, hs.NewHandle(args), kPointerSize);
1365 return result != nullptr
1366 ? Constructor::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, result)
1367 : nullptr;
1368 }
1369
1370 // Constructor::CreateFromArtMethod<kTransactionActive>(self, result)
1371
1372 template
1373 ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k32, false>(
1374 Thread* self,
1375 ObjPtr<Class> klass,
1376 ObjPtr<ObjectArray<Class>> args);
1377 template
1378 ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k32, true>(
1379 Thread* self,
1380 ObjPtr<Class> klass,
1381 ObjPtr<ObjectArray<Class>> args);
1382 template
1383 ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k64, false>(
1384 Thread* self,
1385 ObjPtr<Class> klass,
1386 ObjPtr<ObjectArray<Class>> args);
1387 template
1388 ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k64, true>(
1389 Thread* self,
1390 ObjPtr<Class> klass,
1391 ObjPtr<ObjectArray<Class>> args);
1392
GetInnerClassFlags(Handle<Class> h_this,int32_t default_value)1393 int32_t Class::GetInnerClassFlags(Handle<Class> h_this, int32_t default_value) {
1394 if (h_this->IsProxyClass() || h_this->GetDexCache() == nullptr) {
1395 return default_value;
1396 }
1397 uint32_t flags;
1398 if (!annotations::GetInnerClassFlags(h_this, &flags)) {
1399 return default_value;
1400 }
1401 return flags;
1402 }
1403
SetObjectSizeAllocFastPath(uint32_t new_object_size)1404 void Class::SetObjectSizeAllocFastPath(uint32_t new_object_size) {
1405 if (Runtime::Current()->IsActiveTransaction()) {
1406 SetField32Volatile<true>(ObjectSizeAllocFastPathOffset(), new_object_size);
1407 } else {
1408 SetField32Volatile<false>(ObjectSizeAllocFastPathOffset(), new_object_size);
1409 }
1410 }
1411
PrettyDescriptor(ObjPtr<mirror::Class> klass)1412 std::string Class::PrettyDescriptor(ObjPtr<mirror::Class> klass) {
1413 if (klass == nullptr) {
1414 return "null";
1415 }
1416 return klass->PrettyDescriptor();
1417 }
1418
PrettyDescriptor()1419 std::string Class::PrettyDescriptor() {
1420 std::string temp;
1421 return art::PrettyDescriptor(GetDescriptor(&temp));
1422 }
1423
PrettyClass(ObjPtr<mirror::Class> c)1424 std::string Class::PrettyClass(ObjPtr<mirror::Class> c) {
1425 if (c == nullptr) {
1426 return "null";
1427 }
1428 return c->PrettyClass();
1429 }
1430
PrettyClass()1431 std::string Class::PrettyClass() {
1432 std::string result;
1433 result += "java.lang.Class<";
1434 result += PrettyDescriptor();
1435 result += ">";
1436 return result;
1437 }
1438
PrettyClassAndClassLoader(ObjPtr<mirror::Class> c)1439 std::string Class::PrettyClassAndClassLoader(ObjPtr<mirror::Class> c) {
1440 if (c == nullptr) {
1441 return "null";
1442 }
1443 return c->PrettyClassAndClassLoader();
1444 }
1445
PrettyClassAndClassLoader()1446 std::string Class::PrettyClassAndClassLoader() {
1447 std::string result;
1448 result += "java.lang.Class<";
1449 result += PrettyDescriptor();
1450 result += ",";
1451 result += mirror::Object::PrettyTypeOf(GetClassLoader());
1452 // TODO: add an identifying hash value for the loader
1453 result += ">";
1454 return result;
1455 }
1456
GetAccessFlagsDCheck()1457 template<VerifyObjectFlags kVerifyFlags> void Class::GetAccessFlagsDCheck() {
1458 // Check class is loaded/retired or this is java.lang.String that has a
1459 // circularity issue during loading the names of its members
1460 DCHECK(IsIdxLoaded<kVerifyFlags>() || IsRetired<kVerifyFlags>() ||
1461 IsErroneous<static_cast<VerifyObjectFlags>(kVerifyFlags & ~kVerifyThis)>() ||
1462 this == String::GetJavaLangString())
1463 << "IsIdxLoaded=" << IsIdxLoaded<kVerifyFlags>()
1464 << " IsRetired=" << IsRetired<kVerifyFlags>()
1465 << " IsErroneous=" <<
1466 IsErroneous<static_cast<VerifyObjectFlags>(kVerifyFlags & ~kVerifyThis)>()
1467 << " IsString=" << (this == String::GetJavaLangString())
1468 << " status= " << GetStatus<kVerifyFlags>()
1469 << " descriptor=" << PrettyDescriptor();
1470 }
1471 // Instantiate the common cases.
1472 template void Class::GetAccessFlagsDCheck<kVerifyNone>();
1473 template void Class::GetAccessFlagsDCheck<kVerifyThis>();
1474 template void Class::GetAccessFlagsDCheck<kVerifyReads>();
1475 template void Class::GetAccessFlagsDCheck<kVerifyWrites>();
1476 template void Class::GetAccessFlagsDCheck<kVerifyAll>();
1477
1478 } // namespace mirror
1479 } // namespace art
1480