blob: 8a7defd36246fd134d47cd37c8a010086b92f894 [file] [log] [blame]
Ian Rogers2dd0e2c2013-01-24 12:42:14 -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 */
16
17#include "class.h"
18
Andreas Gampe46ee31b2016-12-14 10:11:49 -080019#include "android-base/stringprintf.h"
20
Brian Carlstromea46f952013-07-30 01:26:50 -070021#include "art_field-inl.h"
22#include "art_method-inl.h"
Andreas Gampe170331f2017-12-07 18:41:03 -080023#include "base/logging.h" // For VLOG.
Andreas Gampe8cf9cb32017-07-19 09:28:38 -070024#include "class-inl.h"
Alex Lightd6251582016-10-31 11:12:30 -070025#include "class_ext.h"
Vladimir Marko3481ba22015-04-13 12:22:36 +010026#include "class_linker-inl.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080027#include "class_loader.h"
David Sehr9e734c72018-01-04 17:56:19 -080028#include "dex/dex_file-inl.h"
29#include "dex/dex_file_annotations.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080030#include "dex_cache.h"
Ian Rogers1d54e732013-05-02 21:10:01 -070031#include "gc/accounting/card_table-inl.h"
Mathieu Chartiereb8167a2014-05-07 15:43:14 -070032#include "handle_scope-inl.h"
Igor Murashkin86083f72017-10-27 10:59:04 -070033#include "subtype_check.h"
Mathieu Chartierfc58af42015-04-16 18:00:39 -070034#include "method.h"
Ian Rogers22d5e732014-07-15 22:23:51 -070035#include "object-inl.h"
Andreas Gampec6ea7d02017-02-01 16:46:28 -080036#include "object-refvisitor-inl.h"
Andreas Gampe8cf9cb32017-07-19 09:28:38 -070037#include "object_array-inl.h"
Alex Lightd6251582016-10-31 11:12:30 -070038#include "object_lock.h"
Ian Rogers22d5e732014-07-15 22:23:51 -070039#include "runtime.h"
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080040#include "thread.h"
41#include "throwable.h"
42#include "utils.h"
43#include "well_known_classes.h"
44
45namespace art {
Igor Murashkin86083f72017-10-27 10:59:04 -070046
47// TODO: move to own CC file?
48constexpr size_t BitString::kBitSizeAtPosition[BitString::kCapacity];
49constexpr size_t BitString::kCapacity;
50
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080051namespace mirror {
52
Andreas Gampe46ee31b2016-12-14 10:11:49 -080053using android::base::StringPrintf;
54
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070055GcRoot<Class> Class::java_lang_Class_;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080056
Mathieu Chartier28bd2e42016-10-04 13:54:57 -070057void Class::SetClassClass(ObjPtr<Class> java_lang_Class) {
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070058 CHECK(java_lang_Class_.IsNull())
59 << java_lang_Class_.Read()
Hiroshi Yamauchi4f1ebc22014-06-25 14:30:41 -070060 << " " << java_lang_Class;
Brian Carlstrom004644f2014-06-18 08:34:01 -070061 CHECK(java_lang_Class != nullptr);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -070062 java_lang_Class->SetClassFlags(kClassFlagClass);
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070063 java_lang_Class_ = GcRoot<Class>(java_lang_Class);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080064}
65
66void Class::ResetClass() {
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070067 CHECK(!java_lang_Class_.IsNull());
68 java_lang_Class_ = GcRoot<Class>(nullptr);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080069}
70
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -070071void Class::VisitRoots(RootVisitor* visitor) {
72 java_lang_Class_.VisitRootIfNonNull(visitor, RootInfo(kRootStickyClass));
Mathieu Chartierc528dba2013-11-26 12:00:11 -080073}
74
Alex Light0273ad12016-11-02 11:19:31 -070075ClassExt* Class::EnsureExtDataPresent(Thread* self) {
76 ObjPtr<ClassExt> existing(GetExtData());
77 if (!existing.IsNull()) {
78 return existing.Ptr();
79 }
80 StackHandleScope<3> hs(self);
81 // Handlerize 'this' since we are allocating here.
82 Handle<Class> h_this(hs.NewHandle(this));
83 // Clear exception so we can allocate.
84 Handle<Throwable> throwable(hs.NewHandle(self->GetException()));
85 self->ClearException();
86 // Allocate the ClassExt
87 Handle<ClassExt> new_ext(hs.NewHandle(ClassExt::Alloc(self)));
Andreas Gampefa4333d2017-02-14 11:10:34 -080088 if (new_ext == nullptr) {
Alex Light0273ad12016-11-02 11:19:31 -070089 // OOM allocating the classExt.
90 // TODO Should we restore the suppressed exception?
91 self->AssertPendingOOMException();
92 return nullptr;
Andreas Gampe99babb62015-11-02 16:20:00 -080093 } else {
Alex Light0273ad12016-11-02 11:19:31 -070094 MemberOffset ext_offset(OFFSET_OF_OBJECT_MEMBER(Class, ext_data_));
95 bool set;
96 // Set the ext_data_ field using CAS semantics.
97 if (Runtime::Current()->IsActiveTransaction()) {
98 set = h_this->CasFieldStrongSequentiallyConsistentObject<true>(ext_offset,
99 ObjPtr<ClassExt>(nullptr),
100 new_ext.Get());
101 } else {
102 set = h_this->CasFieldStrongSequentiallyConsistentObject<false>(ext_offset,
103 ObjPtr<ClassExt>(nullptr),
104 new_ext.Get());
105 }
106 ObjPtr<ClassExt> ret(set ? new_ext.Get() : h_this->GetExtData());
107 DCHECK(!set || h_this->GetExtData() == new_ext.Get());
108 CHECK(!ret.IsNull());
109 // Restore the exception if there was one.
Andreas Gampefa4333d2017-02-14 11:10:34 -0800110 if (throwable != nullptr) {
Alex Light0273ad12016-11-02 11:19:31 -0700111 self->SetException(throwable.Get());
112 }
113 return ret.Ptr();
Andreas Gampe99babb62015-11-02 16:20:00 -0800114 }
115}
116
Vladimir Marko2c64a832018-01-04 11:31:56 +0000117void Class::SetStatus(Handle<Class> h_this, ClassStatus new_status, Thread* self) {
118 ClassStatus old_status = h_this->GetStatus();
Mathieu Chartier590fee92013-09-13 13:46:47 -0700119 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
120 bool class_linker_initialized = class_linker != nullptr && class_linker->IsInitialized();
Ian Rogers7dfb28c2013-08-22 08:18:36 -0700121 if (LIKELY(class_linker_initialized)) {
Vladimir Marko72ab6842017-01-20 19:32:50 +0000122 if (UNLIKELY(new_status <= old_status &&
Vladimir Marko2c64a832018-01-04 11:31:56 +0000123 new_status != ClassStatus::kErrorUnresolved &&
124 new_status != ClassStatus::kErrorResolved &&
125 new_status != ClassStatus::kRetired)) {
David Sehr709b0702016-10-13 09:12:37 -0700126 LOG(FATAL) << "Unexpected change back of class status for " << h_this->PrettyClass()
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700127 << " " << old_status << " -> " << new_status;
Ian Rogers8f3c9ae2013-08-20 17:26:41 -0700128 }
Vladimir Marko2c64a832018-01-04 11:31:56 +0000129 if (new_status >= ClassStatus::kResolved || old_status >= ClassStatus::kResolved) {
Ian Rogers7dfb28c2013-08-22 08:18:36 -0700130 // When classes are being resolved the resolution code should hold the lock.
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700131 CHECK_EQ(h_this->GetLockOwnerThreadId(), self->GetThreadId())
Ian Rogers7dfb28c2013-08-22 08:18:36 -0700132 << "Attempt to change status of class while not holding its lock: "
David Sehr709b0702016-10-13 09:12:37 -0700133 << h_this->PrettyClass() << " " << old_status << " -> " << new_status;
Ian Rogers7dfb28c2013-08-22 08:18:36 -0700134 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800135 }
Vladimir Marko72ab6842017-01-20 19:32:50 +0000136 if (UNLIKELY(IsErroneous(new_status))) {
137 CHECK(!h_this->IsErroneous())
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700138 << "Attempt to set as erroneous an already erroneous class "
Vladimir Marko72ab6842017-01-20 19:32:50 +0000139 << h_this->PrettyClass()
140 << " old_status: " << old_status << " new_status: " << new_status;
Vladimir Marko2c64a832018-01-04 11:31:56 +0000141 CHECK_EQ(new_status == ClassStatus::kErrorResolved, old_status >= ClassStatus::kResolved);
Andreas Gampe31decb12015-08-24 21:09:05 -0700142 if (VLOG_IS_ON(class_linker)) {
David Sehr709b0702016-10-13 09:12:37 -0700143 LOG(ERROR) << "Setting " << h_this->PrettyDescriptor() << " to erroneous.";
Andreas Gampe31decb12015-08-24 21:09:05 -0700144 if (self->IsExceptionPending()) {
145 LOG(ERROR) << "Exception: " << self->GetException()->Dump();
146 }
147 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800148
Alex Light0273ad12016-11-02 11:19:31 -0700149 ObjPtr<ClassExt> ext(h_this->EnsureExtDataPresent(self));
150 if (!ext.IsNull()) {
151 self->AssertPendingException();
152 ext->SetVerifyError(self->GetException());
153 } else {
154 self->AssertPendingOOMException();
Alex Lightd6251582016-10-31 11:12:30 -0700155 }
156 self->AssertPendingException();
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800157 }
Alex Light0273ad12016-11-02 11:19:31 -0700158
Igor Murashkin86083f72017-10-27 10:59:04 -0700159 {
160 ObjPtr<mirror::Class> h_this_ptr = h_this.Get();
161 SubtypeCheck<ObjPtr<mirror::Class>>::WriteStatus(h_this_ptr, new_status);
Mathieu Chartier93bbee02016-08-31 09:38:40 -0700162 }
163
164 // Setting the object size alloc fast path needs to be after the status write so that if the
165 // alloc path sees a valid object size, we would know that it's initialized as long as it has a
166 // load-acquire/fake dependency.
Vladimir Marko2c64a832018-01-04 11:31:56 +0000167 if (new_status == ClassStatus::kInitialized && !h_this->IsVariableSize()) {
Mathieu Chartier161db1d2016-09-01 14:06:54 -0700168 DCHECK_EQ(h_this->GetObjectSizeAllocFastPath(), std::numeric_limits<uint32_t>::max());
169 // Finalizable objects must always go slow path.
170 if (!h_this->IsFinalizable()) {
171 h_this->SetObjectSizeAllocFastPath(RoundUp(h_this->GetObjectSize(), kObjectAlignment));
Mathieu Chartier93bbee02016-08-31 09:38:40 -0700172 }
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100173 }
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700174
175 if (!class_linker_initialized) {
176 // When the class linker is being initialized its single threaded and by definition there can be
177 // no waiters. During initialization classes may appear temporary but won't be retired as their
178 // size was statically computed.
179 } else {
180 // Classes that are being resolved or initialized need to notify waiters that the class status
181 // changed. See ClassLinker::EnsureResolved and ClassLinker::WaitForInitializeClass.
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700182 if (h_this->IsTemp()) {
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700183 // Class is a temporary one, ensure that waiters for resolution get notified of retirement
184 // so that they can grab the new version of the class from the class linker's table.
Vladimir Marko2c64a832018-01-04 11:31:56 +0000185 CHECK_LT(new_status, ClassStatus::kResolved) << h_this->PrettyDescriptor();
186 if (new_status == ClassStatus::kRetired || new_status == ClassStatus::kErrorUnresolved) {
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700187 h_this->NotifyAll(self);
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700188 }
189 } else {
Vladimir Marko2c64a832018-01-04 11:31:56 +0000190 CHECK_NE(new_status, ClassStatus::kRetired);
191 if (old_status >= ClassStatus::kResolved || new_status >= ClassStatus::kResolved) {
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -0700192 h_this->NotifyAll(self);
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700193 }
194 }
Ian Rogers7dfb28c2013-08-22 08:18:36 -0700195 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800196}
197
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700198void Class::SetDexCache(ObjPtr<DexCache> new_dex_cache) {
Chang Xing6d3e7682017-07-11 10:31:29 -0700199 SetFieldObjectTransaction(OFFSET_OF_OBJECT_MEMBER(Class, dex_cache_), new_dex_cache);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800200}
201
Ian Rogersef7d42f2014-01-06 12:55:46 -0800202void Class::SetClassSize(uint32_t new_class_size) {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700203 if (kIsDebugBuild && new_class_size < GetClassSize()) {
Andreas Gampe3fec9ac2016-09-13 10:47:28 -0700204 DumpClass(LOG_STREAM(FATAL_WITHOUT_ABORT), kDumpClassFullDetail);
205 LOG(FATAL_WITHOUT_ABORT) << new_class_size << " vs " << GetClassSize();
David Sehr709b0702016-10-13 09:12:37 -0700206 LOG(FATAL) << "class=" << PrettyTypeOf();
Ian Rogers8b2c0b92013-09-19 02:56:49 -0700207 }
Chang Xing6d3e7682017-07-11 10:31:29 -0700208 SetField32Transaction(OFFSET_OF_OBJECT_MEMBER(Class, class_size_), new_class_size);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800209}
210
211// Return the class' name. The exact format is bizarre, but it's the specified behavior for
212// Class.getName: keywords for primitive types, regular "[I" form for primitive arrays (so "int"
213// but "[I"), and arrays of reference types written between "L" and ";" but with dots rather than
214// slashes (so "java.lang.String" but "[Ljava.lang.String;"). Madness.
Mathieu Chartierf8322842014-05-16 10:59:25 -0700215String* Class::ComputeName(Handle<Class> h_this) {
216 String* name = h_this->GetName();
Mathieu Chartier692fafd2013-11-29 17:24:40 -0800217 if (name != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800218 return name;
219 }
Ian Rogers1ff3c982014-08-12 02:30:58 -0700220 std::string temp;
221 const char* descriptor = h_this->GetDescriptor(&temp);
Mathieu Chartier692fafd2013-11-29 17:24:40 -0800222 Thread* self = Thread::Current();
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800223 if ((descriptor[0] != 'L') && (descriptor[0] != '[')) {
224 // The descriptor indicates that this is the class for
225 // a primitive type; special-case the return value.
Brian Carlstrom004644f2014-06-18 08:34:01 -0700226 const char* c_name = nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800227 switch (descriptor[0]) {
228 case 'Z': c_name = "boolean"; break;
229 case 'B': c_name = "byte"; break;
230 case 'C': c_name = "char"; break;
231 case 'S': c_name = "short"; break;
232 case 'I': c_name = "int"; break;
233 case 'J': c_name = "long"; break;
234 case 'F': c_name = "float"; break;
235 case 'D': c_name = "double"; break;
236 case 'V': c_name = "void"; break;
237 default:
238 LOG(FATAL) << "Unknown primitive type: " << PrintableChar(descriptor[0]);
239 }
Mathieu Chartier692fafd2013-11-29 17:24:40 -0800240 name = String::AllocFromModifiedUtf8(self, c_name);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800241 } else {
242 // Convert the UTF-8 name to a java.lang.String. The name must use '.' to separate package
243 // components.
Ian Rogers1ff3c982014-08-12 02:30:58 -0700244 name = String::AllocFromModifiedUtf8(self, DescriptorToDot(descriptor).c_str());
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800245 }
Mathieu Chartierf8322842014-05-16 10:59:25 -0700246 h_this->SetName(name);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800247 return name;
248}
249
Ian Rogersef7d42f2014-01-06 12:55:46 -0800250void Class::DumpClass(std::ostream& os, int flags) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800251 if ((flags & kDumpClassFullDetail) == 0) {
David Sehr709b0702016-10-13 09:12:37 -0700252 os << PrettyClass();
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800253 if ((flags & kDumpClassClassLoader) != 0) {
254 os << ' ' << GetClassLoader();
255 }
256 if ((flags & kDumpClassInitialized) != 0) {
257 os << ' ' << GetStatus();
258 }
259 os << "\n";
260 return;
261 }
262
Mathieu Chartiere401d142015-04-22 13:56:20 -0700263 Thread* const self = Thread::Current();
Mathieu Chartierf8322842014-05-16 10:59:25 -0700264 StackHandleScope<2> hs(self);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700265 Handle<Class> h_this(hs.NewHandle(this));
266 Handle<Class> h_super(hs.NewHandle(GetSuperClass()));
Mathieu Chartiere401d142015-04-22 13:56:20 -0700267 auto image_pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize();
Mathieu Chartierf8322842014-05-16 10:59:25 -0700268
Ian Rogers1ff3c982014-08-12 02:30:58 -0700269 std::string temp;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800270 os << "----- " << (IsInterface() ? "interface" : "class") << " "
Ian Rogers1ff3c982014-08-12 02:30:58 -0700271 << "'" << GetDescriptor(&temp) << "' cl=" << GetClassLoader() << " -----\n",
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800272 os << " objectSize=" << SizeOf() << " "
Andreas Gampefa4333d2017-02-14 11:10:34 -0800273 << "(" << (h_super != nullptr ? h_super->SizeOf() : -1) << " from super)\n",
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800274 os << StringPrintf(" access=0x%04x.%04x\n",
275 GetAccessFlags() >> 16, GetAccessFlags() & kAccJavaFlagsMask);
Andreas Gampefa4333d2017-02-14 11:10:34 -0800276 if (h_super != nullptr) {
David Sehr709b0702016-10-13 09:12:37 -0700277 os << " super='" << h_super->PrettyClass() << "' (cl=" << h_super->GetClassLoader()
Mathieu Chartierf8322842014-05-16 10:59:25 -0700278 << ")\n";
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800279 }
280 if (IsArrayClass()) {
281 os << " componentType=" << PrettyClass(GetComponentType()) << "\n";
282 }
Mathieu Chartierf8322842014-05-16 10:59:25 -0700283 const size_t num_direct_interfaces = NumDirectInterfaces();
284 if (num_direct_interfaces > 0) {
285 os << " interfaces (" << num_direct_interfaces << "):\n";
286 for (size_t i = 0; i < num_direct_interfaces; ++i) {
Vladimir Marko19a4d372016-12-08 14:41:46 +0000287 ObjPtr<Class> interface = GetDirectInterface(self, h_this.Get(), i);
Andreas Gampe16f149c2015-03-23 10:10:20 -0700288 if (interface == nullptr) {
289 os << StringPrintf(" %2zd: nullptr!\n", i);
290 } else {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700291 ObjPtr<ClassLoader> cl = interface->GetClassLoader();
292 os << StringPrintf(" %2zd: %s (cl=%p)\n", i, PrettyClass(interface).c_str(), cl.Ptr());
Andreas Gampe16f149c2015-03-23 10:10:20 -0700293 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800294 }
295 }
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700296 if (!IsLoaded()) {
297 os << " class not yet loaded";
298 } else {
299 // After this point, this may have moved due to GetDirectInterface.
300 os << " vtable (" << h_this->NumVirtualMethods() << " entries, "
Andreas Gampefa4333d2017-02-14 11:10:34 -0800301 << (h_super != nullptr ? h_super->NumVirtualMethods() : 0) << " in super):\n";
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700302 for (size_t i = 0; i < NumVirtualMethods(); ++i) {
David Sehr709b0702016-10-13 09:12:37 -0700303 os << StringPrintf(" %2zd: %s\n", i, ArtMethod::PrettyMethod(
Mathieu Chartiere401d142015-04-22 13:56:20 -0700304 h_this->GetVirtualMethodDuringLinking(i, image_pointer_size)).c_str());
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800305 }
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700306 os << " direct methods (" << h_this->NumDirectMethods() << " entries):\n";
307 for (size_t i = 0; i < h_this->NumDirectMethods(); ++i) {
David Sehr709b0702016-10-13 09:12:37 -0700308 os << StringPrintf(" %2zd: %s\n", i, ArtMethod::PrettyMethod(
Mathieu Chartiere401d142015-04-22 13:56:20 -0700309 h_this->GetDirectMethod(i, image_pointer_size)).c_str());
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700310 }
311 if (h_this->NumStaticFields() > 0) {
312 os << " static fields (" << h_this->NumStaticFields() << " entries):\n";
Vladimir Marko72ab6842017-01-20 19:32:50 +0000313 if (h_this->IsResolved()) {
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700314 for (size_t i = 0; i < h_this->NumStaticFields(); ++i) {
David Sehr709b0702016-10-13 09:12:37 -0700315 os << StringPrintf(" %2zd: %s\n", i,
316 ArtField::PrettyField(h_this->GetStaticField(i)).c_str());
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700317 }
318 } else {
319 os << " <not yet available>";
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800320 }
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700321 }
322 if (h_this->NumInstanceFields() > 0) {
323 os << " instance fields (" << h_this->NumInstanceFields() << " entries):\n";
Vladimir Marko72ab6842017-01-20 19:32:50 +0000324 if (h_this->IsResolved()) {
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700325 for (size_t i = 0; i < h_this->NumInstanceFields(); ++i) {
David Sehr709b0702016-10-13 09:12:37 -0700326 os << StringPrintf(" %2zd: %s\n", i,
327 ArtField::PrettyField(h_this->GetInstanceField(i)).c_str());
Mingyao Yang98d1cc82014-05-15 17:02:16 -0700328 }
329 } else {
330 os << " <not yet available>";
331 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800332 }
333 }
334}
335
336void Class::SetReferenceInstanceOffsets(uint32_t new_reference_offsets) {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700337 if (kIsDebugBuild && new_reference_offsets != kClassWalkSuper) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800338 // Sanity check that the number of bits set in the reference offset bitmap
339 // agrees with the number of references
Ian Rogerscdc1aaf2014-10-09 13:21:38 -0700340 uint32_t count = 0;
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700341 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800342 count += c->NumReferenceInstanceFieldsDuringLinking();
343 }
Ian Rogerscdc1aaf2014-10-09 13:21:38 -0700344 // +1 for the Class in Object.
345 CHECK_EQ(static_cast<uint32_t>(POPCOUNT(new_reference_offsets)) + 1, count);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800346 }
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100347 // Not called within a transaction.
348 SetField32<false>(OFFSET_OF_OBJECT_MEMBER(Class, reference_instance_offsets_),
Ian Rogersb0fa5dc2014-04-28 16:47:08 -0700349 new_reference_offsets);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800350}
351
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800352bool Class::IsInSamePackage(const StringPiece& descriptor1, const StringPiece& descriptor2) {
353 size_t i = 0;
Ian Rogers6b604a12014-09-25 15:35:37 -0700354 size_t min_length = std::min(descriptor1.size(), descriptor2.size());
355 while (i < min_length && descriptor1[i] == descriptor2[i]) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800356 ++i;
357 }
358 if (descriptor1.find('/', i) != StringPiece::npos ||
359 descriptor2.find('/', i) != StringPiece::npos) {
360 return false;
361 } else {
362 return true;
363 }
364}
365
Mathieu Chartier3398c782016-09-30 10:27:43 -0700366bool Class::IsInSamePackage(ObjPtr<Class> that) {
367 ObjPtr<Class> klass1 = this;
368 ObjPtr<Class> klass2 = that;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800369 if (klass1 == klass2) {
370 return true;
371 }
372 // Class loaders must match.
373 if (klass1->GetClassLoader() != klass2->GetClassLoader()) {
374 return false;
375 }
376 // Arrays are in the same package when their element classes are.
377 while (klass1->IsArrayClass()) {
378 klass1 = klass1->GetComponentType();
379 }
380 while (klass2->IsArrayClass()) {
381 klass2 = klass2->GetComponentType();
382 }
Anwar Ghuloum9fa3f202013-03-26 14:32:54 -0700383 // trivial check again for array types
384 if (klass1 == klass2) {
385 return true;
386 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800387 // Compare the package part of the descriptor string.
Ian Rogers1ff3c982014-08-12 02:30:58 -0700388 std::string temp1, temp2;
389 return IsInSamePackage(klass1->GetDescriptor(&temp1), klass2->GetDescriptor(&temp2));
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800390}
391
Ian Rogersef7d42f2014-01-06 12:55:46 -0800392bool Class::IsThrowableClass() {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800393 return WellKnownClasses::ToClass(WellKnownClasses::java_lang_Throwable)->IsAssignableFrom(this);
394}
395
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700396void Class::SetClassLoader(ObjPtr<ClassLoader> new_class_loader) {
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100397 if (Runtime::Current()->IsActiveTransaction()) {
Ian Rogersb0fa5dc2014-04-28 16:47:08 -0700398 SetFieldObject<true>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100399 } else {
Ian Rogersb0fa5dc2014-04-28 16:47:08 -0700400 SetFieldObject<false>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100401 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800402}
403
Vladimir Markoba118822017-06-12 15:41:56 +0100404template <typename SignatureType>
405static inline ArtMethod* FindInterfaceMethodWithSignature(ObjPtr<Class> klass,
406 const StringPiece& name,
407 const SignatureType& signature,
408 PointerSize pointer_size)
409 REQUIRES_SHARED(Locks::mutator_lock_) {
410 // If the current class is not an interface, skip the search of its declared methods;
411 // such lookup is used only to distinguish between IncompatibleClassChangeError and
412 // NoSuchMethodError and the caller has already tried to search methods in the class.
413 if (LIKELY(klass->IsInterface())) {
414 // Search declared methods, both direct and virtual.
415 // (This lookup is used also for invoke-static on interface classes.)
416 for (ArtMethod& method : klass->GetDeclaredMethodsSlice(pointer_size)) {
417 if (method.GetName() == name && method.GetSignature() == signature) {
418 return &method;
419 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800420 }
421 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700422
Vladimir Markoba118822017-06-12 15:41:56 +0100423 // TODO: If there is a unique maximally-specific non-abstract superinterface method,
424 // we should return it, otherwise an arbitrary one can be returned.
425 ObjPtr<IfTable> iftable = klass->GetIfTable();
426 for (int32_t i = 0, iftable_count = iftable->Count(); i < iftable_count; ++i) {
427 ObjPtr<Class> iface = iftable->GetInterface(i);
428 for (ArtMethod& method : iface->GetVirtualMethodsSlice(pointer_size)) {
429 if (method.GetName() == name && method.GetSignature() == signature) {
430 return &method;
431 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700432 }
433 }
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800434
Vladimir Markoba118822017-06-12 15:41:56 +0100435 // Then search for public non-static methods in the java.lang.Object.
436 if (LIKELY(klass->IsInterface())) {
437 ObjPtr<Class> object_class = klass->GetSuperClass();
438 DCHECK(object_class->IsObjectClass());
439 for (ArtMethod& method : object_class->GetDeclaredMethodsSlice(pointer_size)) {
440 if (method.IsPublic() && !method.IsStatic() &&
441 method.GetName() == name && method.GetSignature() == signature) {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700442 return &method;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800443 }
444 }
445 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700446 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800447}
448
Vladimir Markoba118822017-06-12 15:41:56 +0100449ArtMethod* Class::FindInterfaceMethod(const StringPiece& name,
450 const StringPiece& signature,
451 PointerSize pointer_size) {
452 return FindInterfaceMethodWithSignature(this, name, signature, pointer_size);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800453}
454
Vladimir Markoba118822017-06-12 15:41:56 +0100455ArtMethod* Class::FindInterfaceMethod(const StringPiece& name,
456 const Signature& signature,
457 PointerSize pointer_size) {
458 return FindInterfaceMethodWithSignature(this, name, signature, pointer_size);
Ian Rogersd91d6d62013-09-25 20:26:14 -0700459}
460
Vladimir Markoba118822017-06-12 15:41:56 +0100461ArtMethod* Class::FindInterfaceMethod(ObjPtr<DexCache> dex_cache,
462 uint32_t dex_method_idx,
463 PointerSize pointer_size) {
464 // We always search by name and signature, ignoring the type index in the MethodId.
465 const DexFile& dex_file = *dex_cache->GetDexFile();
466 const DexFile::MethodId& method_id = dex_file.GetMethodId(dex_method_idx);
467 StringPiece name = dex_file.StringDataByIdx(method_id.name_idx_);
468 const Signature signature = dex_file.GetMethodSignature(method_id);
469 return FindInterfaceMethod(name, signature, pointer_size);
470}
471
Alex Lightafb66472017-08-01 09:54:49 -0700472static inline bool IsValidInheritanceCheck(ObjPtr<mirror::Class> klass,
473 ObjPtr<mirror::Class> declaring_class)
474 REQUIRES_SHARED(Locks::mutator_lock_) {
475 if (klass->IsArrayClass()) {
476 return declaring_class->IsObjectClass();
477 } else if (klass->IsInterface()) {
478 return declaring_class->IsObjectClass() || declaring_class == klass;
479 } else {
480 return klass->IsSubClass(declaring_class);
481 }
482}
483
Vladimir Markoba118822017-06-12 15:41:56 +0100484static inline bool IsInheritedMethod(ObjPtr<mirror::Class> klass,
485 ObjPtr<mirror::Class> declaring_class,
486 ArtMethod& method)
487 REQUIRES_SHARED(Locks::mutator_lock_) {
488 DCHECK_EQ(declaring_class, method.GetDeclaringClass());
489 DCHECK_NE(klass, declaring_class);
Alex Lightafb66472017-08-01 09:54:49 -0700490 DCHECK(IsValidInheritanceCheck(klass, declaring_class));
Vladimir Markoba118822017-06-12 15:41:56 +0100491 uint32_t access_flags = method.GetAccessFlags();
492 if ((access_flags & (kAccPublic | kAccProtected)) != 0) {
493 return true;
494 }
495 if ((access_flags & kAccPrivate) != 0) {
496 return false;
497 }
498 for (; klass != declaring_class; klass = klass->GetSuperClass()) {
499 if (!klass->IsInSamePackage(declaring_class)) {
500 return false;
501 }
502 }
503 return true;
504}
505
506template <typename SignatureType>
507static inline ArtMethod* FindClassMethodWithSignature(ObjPtr<Class> this_klass,
508 const StringPiece& name,
509 const SignatureType& signature,
510 PointerSize pointer_size)
511 REQUIRES_SHARED(Locks::mutator_lock_) {
512 // Search declared methods first.
513 for (ArtMethod& method : this_klass->GetDeclaredMethodsSlice(pointer_size)) {
514 ArtMethod* np_method = method.GetInterfaceMethodIfProxy(pointer_size);
515 if (np_method->GetName() == name && np_method->GetSignature() == signature) {
516 return &method;
517 }
518 }
519
520 // Then search the superclass chain. If we find an inherited method, return it.
521 // If we find a method that's not inherited because of access restrictions,
522 // try to find a method inherited from an interface in copied methods.
523 ObjPtr<Class> klass = this_klass->GetSuperClass();
524 ArtMethod* uninherited_method = nullptr;
525 for (; klass != nullptr; klass = klass->GetSuperClass()) {
526 DCHECK(!klass->IsProxyClass());
527 for (ArtMethod& method : klass->GetDeclaredMethodsSlice(pointer_size)) {
528 if (method.GetName() == name && method.GetSignature() == signature) {
529 if (IsInheritedMethod(this_klass, klass, method)) {
530 return &method;
531 }
532 uninherited_method = &method;
533 break;
534 }
535 }
536 if (uninherited_method != nullptr) {
537 break;
538 }
539 }
540
541 // Then search copied methods.
542 // If we found a method that's not inherited, stop the search in its declaring class.
543 ObjPtr<Class> end_klass = klass;
544 DCHECK_EQ(uninherited_method != nullptr, end_klass != nullptr);
545 klass = this_klass;
546 if (UNLIKELY(klass->IsProxyClass())) {
547 DCHECK(klass->GetCopiedMethodsSlice(pointer_size).empty());
548 klass = klass->GetSuperClass();
549 }
550 for (; klass != end_klass; klass = klass->GetSuperClass()) {
551 DCHECK(!klass->IsProxyClass());
552 for (ArtMethod& method : klass->GetCopiedMethodsSlice(pointer_size)) {
553 if (method.GetName() == name && method.GetSignature() == signature) {
554 return &method; // No further check needed, copied methods are inherited by definition.
555 }
556 }
557 }
558 return uninherited_method; // Return the `uninherited_method` if any.
559}
560
561
562ArtMethod* Class::FindClassMethod(const StringPiece& name,
563 const StringPiece& signature,
564 PointerSize pointer_size) {
565 return FindClassMethodWithSignature(this, name, signature, pointer_size);
566}
567
568ArtMethod* Class::FindClassMethod(const StringPiece& name,
569 const Signature& signature,
570 PointerSize pointer_size) {
571 return FindClassMethodWithSignature(this, name, signature, pointer_size);
572}
573
574ArtMethod* Class::FindClassMethod(ObjPtr<DexCache> dex_cache,
575 uint32_t dex_method_idx,
576 PointerSize pointer_size) {
577 // FIXME: Hijacking a proxy class by a custom class loader can break this assumption.
578 DCHECK(!IsProxyClass());
579
580 // First try to find a declared method by dex_method_idx if we have a dex_cache match.
581 ObjPtr<DexCache> this_dex_cache = GetDexCache();
582 if (this_dex_cache == dex_cache) {
583 // Lookup is always performed in the class referenced by the MethodId.
584 DCHECK_EQ(dex_type_idx_, GetDexFile().GetMethodId(dex_method_idx).class_idx_.index_);
585 for (ArtMethod& method : GetDeclaredMethodsSlice(pointer_size)) {
586 if (method.GetDexMethodIndex() == dex_method_idx) {
587 return &method;
588 }
589 }
590 }
591 // If not found, we need to search by name and signature.
592 const DexFile& dex_file = *dex_cache->GetDexFile();
593 const DexFile::MethodId& method_id = dex_file.GetMethodId(dex_method_idx);
594 const Signature signature = dex_file.GetMethodSignature(method_id);
595 StringPiece name; // Delay strlen() until actually needed.
596 // If we do not have a dex_cache match, try to find the declared method in this class now.
597 if (this_dex_cache != dex_cache && !GetDeclaredMethodsSlice(pointer_size).empty()) {
598 DCHECK(name.empty());
599 name = dex_file.StringDataByIdx(method_id.name_idx_);
600 for (ArtMethod& method : GetDeclaredMethodsSlice(pointer_size)) {
601 if (method.GetName() == name && method.GetSignature() == signature) {
602 return &method;
603 }
604 }
605 }
606
607 // Then search the superclass chain. If we find an inherited method, return it.
608 // If we find a method that's not inherited because of access restrictions,
609 // try to find a method inherited from an interface in copied methods.
610 ArtMethod* uninherited_method = nullptr;
611 ObjPtr<Class> klass = GetSuperClass();
612 for (; klass != nullptr; klass = klass->GetSuperClass()) {
613 ArtMethod* candidate_method = nullptr;
614 ArraySlice<ArtMethod> declared_methods = klass->GetDeclaredMethodsSlice(pointer_size);
615 if (klass->GetDexCache() == dex_cache) {
616 // Matching dex_cache. We cannot compare the `dex_method_idx` anymore because
617 // the type index differs, so compare the name index and proto index.
618 for (ArtMethod& method : declared_methods) {
619 const DexFile::MethodId& cmp_method_id = dex_file.GetMethodId(method.GetDexMethodIndex());
620 if (cmp_method_id.name_idx_ == method_id.name_idx_ &&
621 cmp_method_id.proto_idx_ == method_id.proto_idx_) {
622 candidate_method = &method;
623 break;
624 }
625 }
626 } else {
627 if (!declared_methods.empty() && name.empty()) {
628 name = dex_file.StringDataByIdx(method_id.name_idx_);
629 }
630 for (ArtMethod& method : declared_methods) {
631 if (method.GetName() == name && method.GetSignature() == signature) {
632 candidate_method = &method;
633 break;
634 }
635 }
636 }
637 if (candidate_method != nullptr) {
638 if (IsInheritedMethod(this, klass, *candidate_method)) {
639 return candidate_method;
640 } else {
641 uninherited_method = candidate_method;
642 break;
643 }
644 }
645 }
646
647 // Then search copied methods.
648 // If we found a method that's not inherited, stop the search in its declaring class.
649 ObjPtr<Class> end_klass = klass;
650 DCHECK_EQ(uninherited_method != nullptr, end_klass != nullptr);
651 // After we have searched the declared methods of the super-class chain,
652 // search copied methods which can contain methods from interfaces.
653 for (klass = this; klass != end_klass; klass = klass->GetSuperClass()) {
654 ArraySlice<ArtMethod> copied_methods = klass->GetCopiedMethodsSlice(pointer_size);
655 if (!copied_methods.empty() && name.empty()) {
656 name = dex_file.StringDataByIdx(method_id.name_idx_);
657 }
658 for (ArtMethod& method : copied_methods) {
659 if (method.GetName() == name && method.GetSignature() == signature) {
660 return &method; // No further check needed, copied methods are inherited by definition.
661 }
662 }
663 }
664 return uninherited_method; // Return the `uninherited_method` if any.
665}
666
667ArtMethod* Class::FindConstructor(const StringPiece& signature, PointerSize pointer_size) {
668 // Internal helper, never called on proxy classes. We can skip GetInterfaceMethodIfProxy().
669 DCHECK(!IsProxyClass());
670 StringPiece name("<init>");
671 for (ArtMethod& method : GetDirectMethodsSliceUnchecked(pointer_size)) {
672 if (method.GetName() == name && method.GetSignature() == signature) {
673 return &method;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800674 }
675 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700676 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800677}
678
Andreas Gampe542451c2016-07-26 09:02:02 -0700679ArtMethod* Class::FindDeclaredDirectMethodByName(const StringPiece& name,
680 PointerSize pointer_size) {
Nicolas Geoffraya42363f2015-12-17 14:57:09 +0000681 for (auto& method : GetDirectMethods(pointer_size)) {
682 ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
683 if (name == np_method->GetName()) {
684 return &method;
685 }
686 }
687 return nullptr;
688}
689
Andreas Gampe542451c2016-07-26 09:02:02 -0700690ArtMethod* Class::FindDeclaredVirtualMethodByName(const StringPiece& name,
691 PointerSize pointer_size) {
Jeff Hao13e748b2015-08-25 20:44:19 +0000692 for (auto& method : GetVirtualMethods(pointer_size)) {
693 ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
694 if (name == np_method->GetName()) {
695 return &method;
696 }
697 }
698 return nullptr;
699}
700
Andreas Gampe542451c2016-07-26 09:02:02 -0700701ArtMethod* Class::FindVirtualMethodForInterfaceSuper(ArtMethod* method, PointerSize pointer_size) {
Alex Light705ad492015-09-21 11:36:30 -0700702 DCHECK(method->GetDeclaringClass()->IsInterface());
703 DCHECK(IsInterface()) << "Should only be called on a interface class";
704 // Check if we have one defined on this interface first. This includes searching copied ones to
705 // get any conflict methods. Conflict methods are copied into each subtype from the supertype. We
706 // don't do any indirect method checks here.
707 for (ArtMethod& iface_method : GetVirtualMethods(pointer_size)) {
708 if (method->HasSameNameAndSignature(&iface_method)) {
709 return &iface_method;
710 }
711 }
712
713 std::vector<ArtMethod*> abstract_methods;
714 // Search through the IFTable for a working version. We don't need to check for conflicts
715 // because if there was one it would appear in this classes virtual_methods_ above.
716
717 Thread* self = Thread::Current();
718 StackHandleScope<2> hs(self);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700719 MutableHandle<IfTable> iftable(hs.NewHandle(GetIfTable()));
720 MutableHandle<Class> iface(hs.NewHandle<Class>(nullptr));
Alex Light705ad492015-09-21 11:36:30 -0700721 size_t iftable_count = GetIfTableCount();
722 // Find the method. We don't need to check for conflicts because they would have been in the
723 // copied virtuals of this interface. Order matters, traverse in reverse topological order; most
724 // subtypiest interfaces get visited first.
725 for (size_t k = iftable_count; k != 0;) {
726 k--;
727 DCHECK_LT(k, iftable->Count());
728 iface.Assign(iftable->GetInterface(k));
729 // Iterate through every declared method on this interface. Each direct method's name/signature
730 // is unique so the order of the inner loop doesn't matter.
731 for (auto& method_iter : iface->GetDeclaredVirtualMethods(pointer_size)) {
732 ArtMethod* current_method = &method_iter;
733 if (current_method->HasSameNameAndSignature(method)) {
734 if (current_method->IsDefault()) {
735 // Handle JLS soft errors, a default method from another superinterface tree can
736 // "override" an abstract method(s) from another superinterface tree(s). To do this,
737 // ignore any [default] method which are dominated by the abstract methods we've seen so
738 // far. Check if overridden by any in abstract_methods. We do not need to check for
739 // default_conflicts because we would hit those before we get to this loop.
740 bool overridden = false;
741 for (ArtMethod* possible_override : abstract_methods) {
742 DCHECK(possible_override->HasSameNameAndSignature(current_method));
743 if (iface->IsAssignableFrom(possible_override->GetDeclaringClass())) {
744 overridden = true;
745 break;
746 }
747 }
748 if (!overridden) {
749 return current_method;
750 }
751 } else {
752 // Is not default.
753 // This might override another default method. Just stash it for now.
754 abstract_methods.push_back(current_method);
755 }
756 }
757 }
758 }
759 // If we reach here we either never found any declaration of the method (in which case
760 // 'abstract_methods' is empty or we found no non-overriden default methods in which case
761 // 'abstract_methods' contains a number of abstract implementations of the methods. We choose one
762 // of these arbitrarily.
763 return abstract_methods.empty() ? nullptr : abstract_methods[0];
764}
765
Andreas Gampe542451c2016-07-26 09:02:02 -0700766ArtMethod* Class::FindClassInitializer(PointerSize pointer_size) {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700767 for (ArtMethod& method : GetDirectMethods(pointer_size)) {
768 if (method.IsClassInitializer()) {
769 DCHECK_STREQ(method.GetName(), "<clinit>");
770 DCHECK_STREQ(method.GetSignature().ToString().c_str(), "()V");
771 return &method;
Ian Rogersd91d6d62013-09-25 20:26:14 -0700772 }
773 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700774 return nullptr;
Ian Rogersd91d6d62013-09-25 20:26:14 -0700775}
776
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700777// Custom binary search to avoid double comparisons from std::binary_search.
778static ArtField* FindFieldByNameAndType(LengthPrefixedArray<ArtField>* fields,
779 const StringPiece& name,
780 const StringPiece& type)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700781 REQUIRES_SHARED(Locks::mutator_lock_) {
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700782 if (fields == nullptr) {
783 return nullptr;
784 }
785 size_t low = 0;
Vladimir Marko35831e82015-09-11 11:59:18 +0100786 size_t high = fields->size();
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700787 ArtField* ret = nullptr;
788 while (low < high) {
789 size_t mid = (low + high) / 2;
790 ArtField& field = fields->At(mid);
791 // Fields are sorted by class, then name, then type descriptor. This is verified in dex file
792 // verifier. There can be multiple fields with the same in the same class name due to proguard.
793 int result = StringPiece(field.GetName()).Compare(name);
794 if (result == 0) {
795 result = StringPiece(field.GetTypeDescriptor()).Compare(type);
796 }
797 if (result < 0) {
798 low = mid + 1;
799 } else if (result > 0) {
800 high = mid;
801 } else {
802 ret = &field;
803 break;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800804 }
805 }
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700806 if (kIsDebugBuild) {
807 ArtField* found = nullptr;
808 for (ArtField& field : MakeIterationRangeFromLengthPrefixedArray(fields)) {
809 if (name == field.GetName() && type == field.GetTypeDescriptor()) {
810 found = &field;
811 break;
812 }
813 }
David Sehr709b0702016-10-13 09:12:37 -0700814 CHECK_EQ(found, ret) << "Found " << found->PrettyField() << " vs " << ret->PrettyField();
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700815 }
816 return ret;
817}
818
819ArtField* Class::FindDeclaredInstanceField(const StringPiece& name, const StringPiece& type) {
820 // Binary search by name. Interfaces are not relevant because they can't contain instance fields.
821 return FindFieldByNameAndType(GetIFieldsPtr(), name, type);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800822}
823
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700824ArtField* Class::FindDeclaredInstanceField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800825 if (GetDexCache() == dex_cache) {
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700826 for (ArtField& field : GetIFields()) {
827 if (field.GetDexFieldIndex() == dex_field_idx) {
828 return &field;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800829 }
830 }
831 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700832 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800833}
834
Brian Carlstromea46f952013-07-30 01:26:50 -0700835ArtField* Class::FindInstanceField(const StringPiece& name, const StringPiece& type) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800836 // Is the field in this class, or any of its superclasses?
837 // Interfaces are not relevant because they can't contain instance fields.
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700838 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
Brian Carlstromea46f952013-07-30 01:26:50 -0700839 ArtField* f = c->FindDeclaredInstanceField(name, type);
Brian Carlstrom004644f2014-06-18 08:34:01 -0700840 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800841 return f;
842 }
843 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700844 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800845}
846
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700847ArtField* Class::FindInstanceField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800848 // Is the field in this class, or any of its superclasses?
849 // Interfaces are not relevant because they can't contain instance fields.
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700850 for (ObjPtr<Class> c = this; c != nullptr; c = c->GetSuperClass()) {
Brian Carlstromea46f952013-07-30 01:26:50 -0700851 ArtField* f = c->FindDeclaredInstanceField(dex_cache, dex_field_idx);
Brian Carlstrom004644f2014-06-18 08:34:01 -0700852 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800853 return f;
854 }
855 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700856 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800857}
858
Brian Carlstromea46f952013-07-30 01:26:50 -0700859ArtField* Class::FindDeclaredStaticField(const StringPiece& name, const StringPiece& type) {
Brian Carlstrom004644f2014-06-18 08:34:01 -0700860 DCHECK(type != nullptr);
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700861 return FindFieldByNameAndType(GetSFieldsPtr(), name, type);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800862}
863
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700864ArtField* Class::FindDeclaredStaticField(ObjPtr<DexCache> dex_cache, uint32_t dex_field_idx) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800865 if (dex_cache == GetDexCache()) {
Mathieu Chartiere2aa3262015-10-20 18:30:03 -0700866 for (ArtField& field : GetSFields()) {
867 if (field.GetDexFieldIndex() == dex_field_idx) {
868 return &field;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800869 }
870 }
871 }
Brian Carlstrom004644f2014-06-18 08:34:01 -0700872 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800873}
874
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700875ArtField* Class::FindStaticField(Thread* self,
Vladimir Marko19a4d372016-12-08 14:41:46 +0000876 ObjPtr<Class> klass,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700877 const StringPiece& name,
Mathieu Chartierf8322842014-05-16 10:59:25 -0700878 const StringPiece& type) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800879 // Is the field in this class (or its interfaces), or any of its
880 // superclasses (or their interfaces)?
Vladimir Marko19a4d372016-12-08 14:41:46 +0000881 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800882 // Is the field in this class?
Brian Carlstromea46f952013-07-30 01:26:50 -0700883 ArtField* f = k->FindDeclaredStaticField(name, type);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700884 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800885 return f;
886 }
887 // Is this field in any of this class' interfaces?
Vladimir Marko19a4d372016-12-08 14:41:46 +0000888 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
889 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
890 DCHECK(interface != nullptr);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700891 f = FindStaticField(self, interface, name, type);
892 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800893 return f;
894 }
895 }
896 }
Mathieu Chartierf8322842014-05-16 10:59:25 -0700897 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800898}
899
Vladimir Markobb268b12016-06-30 15:52:56 +0100900ArtField* Class::FindStaticField(Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700901 ObjPtr<Class> klass,
902 ObjPtr<DexCache> dex_cache,
Mathieu Chartierf8322842014-05-16 10:59:25 -0700903 uint32_t dex_field_idx) {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700904 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800905 // Is the field in this class?
Brian Carlstromea46f952013-07-30 01:26:50 -0700906 ArtField* f = k->FindDeclaredStaticField(dex_cache, dex_field_idx);
Brian Carlstrom004644f2014-06-18 08:34:01 -0700907 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800908 return f;
909 }
Vladimir Markobb268b12016-06-30 15:52:56 +0100910 // Though GetDirectInterface() should not cause thread suspension when called
911 // from here, it takes a Handle as an argument, so we need to wrap `k`.
Mathieu Chartier268764d2016-09-13 12:09:38 -0700912 ScopedAssertNoThreadSuspension ants(__FUNCTION__);
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800913 // Is this field in any of this class' interfaces?
Vladimir Marko19a4d372016-12-08 14:41:46 +0000914 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
915 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
916 DCHECK(interface != nullptr);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700917 f = FindStaticField(self, interface, dex_cache, dex_field_idx);
918 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800919 return f;
920 }
921 }
922 }
Mathieu Chartierf8322842014-05-16 10:59:25 -0700923 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800924}
925
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700926ArtField* Class::FindField(Thread* self,
Vladimir Marko19a4d372016-12-08 14:41:46 +0000927 ObjPtr<Class> klass,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -0700928 const StringPiece& name,
Mathieu Chartierf8322842014-05-16 10:59:25 -0700929 const StringPiece& type) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800930 // Find a field using the JLS field resolution order
Vladimir Marko19a4d372016-12-08 14:41:46 +0000931 for (ObjPtr<Class> k = klass; k != nullptr; k = k->GetSuperClass()) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800932 // Is the field in this class?
Brian Carlstromea46f952013-07-30 01:26:50 -0700933 ArtField* f = k->FindDeclaredInstanceField(name, type);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700934 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800935 return f;
936 }
937 f = k->FindDeclaredStaticField(name, type);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700938 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800939 return f;
940 }
941 // Is this field in any of this class' interfaces?
Vladimir Marko19a4d372016-12-08 14:41:46 +0000942 for (uint32_t i = 0, num_interfaces = k->NumDirectInterfaces(); i != num_interfaces; ++i) {
943 ObjPtr<Class> interface = GetDirectInterface(self, k, i);
944 DCHECK(interface != nullptr);
945 f = FindStaticField(self, interface, name, type);
Mathieu Chartierf8322842014-05-16 10:59:25 -0700946 if (f != nullptr) {
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800947 return f;
948 }
949 }
950 }
Mathieu Chartierf8322842014-05-16 10:59:25 -0700951 return nullptr;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -0800952}
953
Andreas Gampe542451c2016-07-26 09:02:02 -0700954void Class::SetSkipAccessChecksFlagOnAllMethods(PointerSize pointer_size) {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700955 DCHECK(IsVerified());
Alex Lighte64300b2015-12-15 15:02:47 -0800956 for (auto& m : GetMethods(pointer_size)) {
Alex Light9139e002015-10-09 15:59:48 -0700957 if (!m.IsNative() && m.IsInvokable()) {
Igor Murashkindf707e42016-02-02 16:56:50 -0800958 m.SetSkipAccessChecks();
Mathieu Chartiere401d142015-04-22 13:56:20 -0700959 }
960 }
Sebastien Hertz233ea8e2013-06-06 11:57:09 +0200961}
962
Ian Rogers1ff3c982014-08-12 02:30:58 -0700963const char* Class::GetDescriptor(std::string* storage) {
964 if (IsPrimitive()) {
Mathieu Chartierf8322842014-05-16 10:59:25 -0700965 return Primitive::Descriptor(GetPrimitiveType());
Ian Rogers1ff3c982014-08-12 02:30:58 -0700966 } else if (IsArrayClass()) {
967 return GetArrayDescriptor(storage);
Nicolas Geoffray3a090922015-11-24 09:17:30 +0000968 } else if (IsProxyClass()) {
969 *storage = Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this);
Ian Rogers1ff3c982014-08-12 02:30:58 -0700970 return storage->c_str();
Mathieu Chartierf8322842014-05-16 10:59:25 -0700971 } else {
972 const DexFile& dex_file = GetDexFile();
973 const DexFile::TypeId& type_id = dex_file.GetTypeId(GetClassDef()->class_idx_);
974 return dex_file.GetTypeDescriptor(type_id);
975 }
976}
977
Ian Rogers1ff3c982014-08-12 02:30:58 -0700978const char* Class::GetArrayDescriptor(std::string* storage) {
979 std::string temp;
980 const char* elem_desc = GetComponentType()->GetDescriptor(&temp);
981 *storage = "[";
982 *storage += elem_desc;
983 return storage->c_str();
Mathieu Chartierf8322842014-05-16 10:59:25 -0700984}
985
986const DexFile::ClassDef* Class::GetClassDef() {
987 uint16_t class_def_idx = GetDexClassDefIndex();
988 if (class_def_idx == DexFile::kDexNoIndex16) {
989 return nullptr;
990 }
991 return &GetDexFile().GetClassDef(class_def_idx);
992}
993
Andreas Gampea5b09a62016-11-17 15:21:22 -0800994dex::TypeIndex Class::GetDirectInterfaceTypeIdx(uint32_t idx) {
Mathieu Chartierf8322842014-05-16 10:59:25 -0700995 DCHECK(!IsPrimitive());
996 DCHECK(!IsArrayClass());
997 return GetInterfaceTypeList()->GetTypeItem(idx).type_idx_;
998}
999
Vladimir Marko19a4d372016-12-08 14:41:46 +00001000ObjPtr<Class> Class::GetDirectInterface(Thread* self, ObjPtr<Class> klass, uint32_t idx) {
1001 DCHECK(klass != nullptr);
Mathieu Chartierf8322842014-05-16 10:59:25 -07001002 DCHECK(!klass->IsPrimitive());
1003 if (klass->IsArrayClass()) {
1004 ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
Vladimir Marko19a4d372016-12-08 14:41:46 +00001005 // Use ClassLinker::LookupClass(); avoid poisoning ObjPtr<>s by ClassLinker::FindSystemClass().
1006 ObjPtr<Class> interface;
Mathieu Chartierf8322842014-05-16 10:59:25 -07001007 if (idx == 0) {
Vladimir Marko19a4d372016-12-08 14:41:46 +00001008 interface = class_linker->LookupClass(self, "Ljava/lang/Cloneable;", nullptr);
Mathieu Chartierf8322842014-05-16 10:59:25 -07001009 } else {
1010 DCHECK_EQ(1U, idx);
Vladimir Marko19a4d372016-12-08 14:41:46 +00001011 interface = class_linker->LookupClass(self, "Ljava/io/Serializable;", nullptr);
Mathieu Chartierf8322842014-05-16 10:59:25 -07001012 }
Vladimir Marko19a4d372016-12-08 14:41:46 +00001013 DCHECK(interface != nullptr);
1014 return interface;
Nicolas Geoffray3a090922015-11-24 09:17:30 +00001015 } else if (klass->IsProxyClass()) {
Narayan Kamath6b2dc312017-03-14 13:26:12 +00001016 ObjPtr<ObjectArray<Class>> interfaces = klass->GetProxyInterfaces();
Mathieu Chartierf8322842014-05-16 10:59:25 -07001017 DCHECK(interfaces != nullptr);
1018 return interfaces->Get(idx);
1019 } else {
Andreas Gampea5b09a62016-11-17 15:21:22 -08001020 dex::TypeIndex type_idx = klass->GetDirectInterfaceTypeIdx(idx);
Vladimir Marko666ee3d2017-12-11 18:37:36 +00001021 ObjPtr<Class> interface = Runtime::Current()->GetClassLinker()->LookupResolvedType(
Vladimir Marko8d6768d2017-03-14 10:13:21 +00001022 type_idx, klass->GetDexCache(), klass->GetClassLoader());
Mathieu Chartierf8322842014-05-16 10:59:25 -07001023 return interface;
1024 }
1025}
1026
Vladimir Marko19a4d372016-12-08 14:41:46 +00001027ObjPtr<Class> Class::ResolveDirectInterface(Thread* self, Handle<Class> klass, uint32_t idx) {
1028 ObjPtr<Class> interface = GetDirectInterface(self, klass.Get(), idx);
1029 if (interface == nullptr) {
1030 DCHECK(!klass->IsArrayClass());
1031 DCHECK(!klass->IsProxyClass());
1032 dex::TypeIndex type_idx = klass->GetDirectInterfaceTypeIdx(idx);
Vladimir Marko666ee3d2017-12-11 18:37:36 +00001033 interface = Runtime::Current()->GetClassLinker()->ResolveType(type_idx, klass.Get());
Vladimir Marko19a4d372016-12-08 14:41:46 +00001034 CHECK(interface != nullptr || self->IsExceptionPending());
1035 }
1036 return interface;
1037}
1038
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001039ObjPtr<Class> Class::GetCommonSuperClass(Handle<Class> klass) {
Andreas Gampefa4333d2017-02-14 11:10:34 -08001040 DCHECK(klass != nullptr);
Calin Juravle52503d82015-11-11 16:58:31 +00001041 DCHECK(!klass->IsInterface());
1042 DCHECK(!IsInterface());
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001043 ObjPtr<Class> common_super_class = this;
Calin Juravle52503d82015-11-11 16:58:31 +00001044 while (!common_super_class->IsAssignableFrom(klass.Get())) {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001045 ObjPtr<Class> old_common = common_super_class;
Aart Bik22deed02016-04-04 14:19:01 -07001046 common_super_class = old_common->GetSuperClass();
David Sehr709b0702016-10-13 09:12:37 -07001047 DCHECK(common_super_class != nullptr) << old_common->PrettyClass();
Calin Juravle52503d82015-11-11 16:58:31 +00001048 }
Calin Juravle52503d82015-11-11 16:58:31 +00001049 return common_super_class;
1050}
1051
Mathieu Chartierf8322842014-05-16 10:59:25 -07001052const char* Class::GetSourceFile() {
Mathieu Chartierf8322842014-05-16 10:59:25 -07001053 const DexFile& dex_file = GetDexFile();
1054 const DexFile::ClassDef* dex_class_def = GetClassDef();
Sebastien Hertz4206eb52014-06-05 10:15:45 +02001055 if (dex_class_def == nullptr) {
1056 // Generated classes have no class def.
1057 return nullptr;
1058 }
Mathieu Chartierf8322842014-05-16 10:59:25 -07001059 return dex_file.GetSourceFile(*dex_class_def);
1060}
1061
1062std::string Class::GetLocation() {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001063 ObjPtr<DexCache> dex_cache = GetDexCache();
Nicolas Geoffray3a090922015-11-24 09:17:30 +00001064 if (dex_cache != nullptr && !IsProxyClass()) {
Mathieu Chartierf8322842014-05-16 10:59:25 -07001065 return dex_cache->GetLocation()->ToModifiedUtf8();
1066 }
1067 // Arrays and proxies are generated and have no corresponding dex file location.
1068 return "generated class";
1069}
1070
1071const DexFile::TypeList* Class::GetInterfaceTypeList() {
1072 const DexFile::ClassDef* class_def = GetClassDef();
1073 if (class_def == nullptr) {
1074 return nullptr;
1075 }
1076 return GetDexFile().GetInterfacesList(*class_def);
1077}
1078
Andreas Gampe542451c2016-07-26 09:02:02 -07001079void Class::PopulateEmbeddedVTable(PointerSize pointer_size) {
Mathieu Chartiere401d142015-04-22 13:56:20 -07001080 PointerArray* table = GetVTableDuringLinking();
David Sehr709b0702016-10-13 09:12:37 -07001081 CHECK(table != nullptr) << PrettyClass();
Mathieu Chartiere401d142015-04-22 13:56:20 -07001082 const size_t table_length = table->GetLength();
1083 SetEmbeddedVTableLength(table_length);
1084 for (size_t i = 0; i < table_length; i++) {
1085 SetEmbeddedVTableEntry(i, table->GetElementPtrSize<ArtMethod*>(i, pointer_size), pointer_size);
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001086 }
Mingyao Yang2cdbad72014-07-16 10:44:41 -07001087 // Keep java.lang.Object class's vtable around for since it's easier
1088 // to be reused by array classes during their linking.
1089 if (!IsObjectClass()) {
1090 SetVTable(nullptr);
1091 }
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001092}
1093
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001094class ReadBarrierOnNativeRootsVisitor {
1095 public:
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001096 void operator()(ObjPtr<Object> obj ATTRIBUTE_UNUSED,
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001097 MemberOffset offset ATTRIBUTE_UNUSED,
1098 bool is_static ATTRIBUTE_UNUSED) const {}
1099
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001100 void VisitRootIfNonNull(CompressedReference<Object>* root) const
Andreas Gampebdf7f1c2016-08-30 16:38:47 -07001101 REQUIRES_SHARED(Locks::mutator_lock_) {
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001102 if (!root->IsNull()) {
1103 VisitRoot(root);
1104 }
1105 }
1106
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001107 void VisitRoot(CompressedReference<Object>* root) const
Andreas Gampebdf7f1c2016-08-30 16:38:47 -07001108 REQUIRES_SHARED(Locks::mutator_lock_) {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001109 ObjPtr<Object> old_ref = root->AsMirrorPtr();
1110 ObjPtr<Object> new_ref = ReadBarrier::BarrierForRoot(root);
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001111 if (old_ref != new_ref) {
1112 // Update the field atomically. This may fail if mutator updates before us, but it's ok.
1113 auto* atomic_root =
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001114 reinterpret_cast<Atomic<CompressedReference<Object>>*>(root);
Orion Hodson4557b382018-01-03 11:47:54 +00001115 atomic_root->CompareAndSetStrongSequentiallyConsistent(
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001116 CompressedReference<Object>::FromMirrorPtr(old_ref.Ptr()),
1117 CompressedReference<Object>::FromMirrorPtr(new_ref.Ptr()));
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001118 }
1119 }
1120};
1121
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001122// The pre-fence visitor for Class::CopyOf().
1123class CopyClassVisitor {
1124 public:
Andreas Gampe542451c2016-07-26 09:02:02 -07001125 CopyClassVisitor(Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001126 Handle<Class>* orig,
Andreas Gampe542451c2016-07-26 09:02:02 -07001127 size_t new_length,
1128 size_t copy_bytes,
1129 ImTable* imt,
1130 PointerSize pointer_size)
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001131 : self_(self), orig_(orig), new_length_(new_length),
Mathieu Chartiere401d142015-04-22 13:56:20 -07001132 copy_bytes_(copy_bytes), imt_(imt), pointer_size_(pointer_size) {
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001133 }
1134
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001135 void operator()(ObjPtr<Object> obj, size_t usable_size ATTRIBUTE_UNUSED) const
Andreas Gampebdf7f1c2016-08-30 16:38:47 -07001136 REQUIRES_SHARED(Locks::mutator_lock_) {
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -07001137 StackHandleScope<1> hs(self_);
1138 Handle<mirror::Class> h_new_class_obj(hs.NewHandle(obj->AsClass()));
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001139 Object::CopyObject(h_new_class_obj.Get(), orig_->Get(), copy_bytes_);
Vladimir Marko2c64a832018-01-04 11:31:56 +00001140 Class::SetStatus(h_new_class_obj, ClassStatus::kResolving, self_);
Artem Udovichenkoa62cb9b2016-06-30 09:18:25 +00001141 h_new_class_obj->PopulateEmbeddedVTable(pointer_size_);
1142 h_new_class_obj->SetImt(imt_, pointer_size_);
Hiroshi Yamauchi5b783e62015-03-18 17:20:11 -07001143 h_new_class_obj->SetClassSize(new_length_);
Mathieu Chartier3ee25bb2015-08-10 10:13:02 -07001144 // Visit all of the references to make sure there is no from space references in the native
1145 // roots.
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001146 ObjPtr<Object>(h_new_class_obj.Get())->VisitReferences(
Mathieu Chartier059ef3d2015-08-18 13:54:21 -07001147 ReadBarrierOnNativeRootsVisitor(), VoidFunctor());
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001148 }
1149
1150 private:
1151 Thread* const self_;
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001152 Handle<Class>* const orig_;
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001153 const size_t new_length_;
1154 const size_t copy_bytes_;
Artem Udovichenkoa62cb9b2016-06-30 09:18:25 +00001155 ImTable* imt_;
Andreas Gampe542451c2016-07-26 09:02:02 -07001156 const PointerSize pointer_size_;
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001157 DISALLOW_COPY_AND_ASSIGN(CopyClassVisitor);
1158};
1159
Andreas Gampe542451c2016-07-26 09:02:02 -07001160Class* Class::CopyOf(Thread* self, int32_t new_length, ImTable* imt, PointerSize pointer_size) {
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001161 DCHECK_GE(new_length, static_cast<int32_t>(sizeof(Class)));
1162 // We may get copied by a compacting GC.
1163 StackHandleScope<1> hs(self);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001164 Handle<Class> h_this(hs.NewHandle(this));
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001165 gc::Heap* heap = Runtime::Current()->GetHeap();
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001166 // The num_bytes (3rd param) is sizeof(Class) as opposed to SizeOf()
1167 // to skip copying the tail part that we will overwrite here.
Mathieu Chartiere401d142015-04-22 13:56:20 -07001168 CopyClassVisitor visitor(self, &h_this, new_length, sizeof(Class), imt, pointer_size);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001169 ObjPtr<Object> new_class = kMovingClasses ?
Mathieu Chartiere401d142015-04-22 13:56:20 -07001170 heap->AllocObject<true>(self, java_lang_Class_.Read(), new_length, visitor) :
1171 heap->AllocNonMovableObject<true>(self, java_lang_Class_.Read(), new_length, visitor);
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001172 if (UNLIKELY(new_class == nullptr)) {
Mathieu Chartiere401d142015-04-22 13:56:20 -07001173 self->AssertPendingOOMException();
Mathieu Chartier2d2621a2014-10-23 16:48:06 -07001174 return nullptr;
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001175 }
Hiroshi Yamauchi0fbd6e62014-07-17 16:16:31 -07001176 return new_class->AsClass();
Mingyao Yang98d1cc82014-05-15 17:02:16 -07001177}
1178
Nicolas Geoffray3a090922015-11-24 09:17:30 +00001179bool Class::ProxyDescriptorEquals(const char* match) {
1180 DCHECK(IsProxyClass());
1181 return Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this) == match;
Vladimir Marko3481ba22015-04-13 12:22:36 +01001182}
1183
Mathieu Chartiere401d142015-04-22 13:56:20 -07001184// TODO: Move this to java_lang_Class.cc?
1185ArtMethod* Class::GetDeclaredConstructor(
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001186 Thread* self, Handle<ObjectArray<Class>> args, PointerSize pointer_size) {
Andreas Gampe6039e562016-04-05 18:18:43 -07001187 for (auto& m : GetDirectMethods(pointer_size)) {
Mathieu Chartierfc58af42015-04-16 18:00:39 -07001188 // Skip <clinit> which is a static constructor, as well as non constructors.
Mathieu Chartiere401d142015-04-22 13:56:20 -07001189 if (m.IsStatic() || !m.IsConstructor()) {
Mathieu Chartierfc58af42015-04-16 18:00:39 -07001190 continue;
1191 }
1192 // May cause thread suspension and exceptions.
Andreas Gampe542451c2016-07-26 09:02:02 -07001193 if (m.GetInterfaceMethodIfProxy(kRuntimePointerSize)->EqualParameters(args)) {
Mathieu Chartiere401d142015-04-22 13:56:20 -07001194 return &m;
Mathieu Chartierfc58af42015-04-16 18:00:39 -07001195 }
Mathieu Chartiere401d142015-04-22 13:56:20 -07001196 if (UNLIKELY(self->IsExceptionPending())) {
Mathieu Chartierfc58af42015-04-16 18:00:39 -07001197 return nullptr;
1198 }
1199 }
1200 return nullptr;
1201}
1202
Mathieu Chartiere401d142015-04-22 13:56:20 -07001203uint32_t Class::Depth() {
1204 uint32_t depth = 0;
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001205 for (ObjPtr<Class> klass = this; klass->GetSuperClass() != nullptr; klass = klass->GetSuperClass()) {
Mathieu Chartiere401d142015-04-22 13:56:20 -07001206 depth++;
1207 }
1208 return depth;
1209}
1210
Andreas Gampea5b09a62016-11-17 15:21:22 -08001211dex::TypeIndex Class::FindTypeIndexInOtherDexFile(const DexFile& dex_file) {
Nicolas Geoffraye4084a52016-02-18 14:43:42 +00001212 std::string temp;
1213 const DexFile::TypeId* type_id = dex_file.FindTypeId(GetDescriptor(&temp));
Andreas Gampe2722f382017-06-08 18:03:25 -07001214 return (type_id == nullptr) ? dex::TypeIndex() : dex_file.GetIndexForTypeId(*type_id);
Nicolas Geoffraye4084a52016-02-18 14:43:42 +00001215}
1216
Andreas Gampe542451c2016-07-26 09:02:02 -07001217template <PointerSize kPointerSize, bool kTransactionActive>
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001218ObjPtr<Method> Class::GetDeclaredMethodInternal(
1219 Thread* self,
1220 ObjPtr<Class> klass,
1221 ObjPtr<String> name,
1222 ObjPtr<ObjectArray<Class>> args) {
Andreas Gampebc4d2182016-02-22 10:03:12 -08001223 // Covariant return types permit the class to define multiple
1224 // methods with the same name and parameter types. Prefer to
1225 // return a non-synthetic method in such situations. We may
1226 // still return a synthetic method to handle situations like
1227 // escalated visibility. We never return miranda methods that
1228 // were synthesized by the runtime.
Andreas Gampebc4d2182016-02-22 10:03:12 -08001229 StackHandleScope<3> hs(self);
1230 auto h_method_name = hs.NewHandle(name);
Andreas Gampefa4333d2017-02-14 11:10:34 -08001231 if (UNLIKELY(h_method_name == nullptr)) {
Andreas Gampebc4d2182016-02-22 10:03:12 -08001232 ThrowNullPointerException("name == null");
1233 return nullptr;
1234 }
1235 auto h_args = hs.NewHandle(args);
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001236 Handle<Class> h_klass = hs.NewHandle(klass);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001237 ArtMethod* result = nullptr;
Andreas Gampee01e3642016-07-25 13:06:04 -07001238 for (auto& m : h_klass->GetDeclaredVirtualMethods(kPointerSize)) {
1239 auto* np_method = m.GetInterfaceMethodIfProxy(kPointerSize);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001240 // May cause thread suspension.
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001241 ObjPtr<String> np_name = np_method->GetNameAsString(self);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001242 if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1243 if (UNLIKELY(self->IsExceptionPending())) {
1244 return nullptr;
1245 }
1246 continue;
1247 }
Vladimir Markob0a6aee2017-10-27 10:34:04 +01001248 if (!m.IsMiranda()) {
1249 if (!m.IsSynthetic()) {
1250 return Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, &m);
1251 }
Andreas Gampebc4d2182016-02-22 10:03:12 -08001252 result = &m; // Remember as potential result if it's not a miranda method.
1253 }
1254 }
1255 if (result == nullptr) {
Andreas Gampee01e3642016-07-25 13:06:04 -07001256 for (auto& m : h_klass->GetDirectMethods(kPointerSize)) {
Andreas Gampebc4d2182016-02-22 10:03:12 -08001257 auto modifiers = m.GetAccessFlags();
1258 if ((modifiers & kAccConstructor) != 0) {
1259 continue;
1260 }
Andreas Gampee01e3642016-07-25 13:06:04 -07001261 auto* np_method = m.GetInterfaceMethodIfProxy(kPointerSize);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001262 // May cause thread suspension.
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001263 ObjPtr<String> np_name = np_method->GetNameAsString(self);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001264 if (np_name == nullptr) {
1265 self->AssertPendingException();
1266 return nullptr;
1267 }
1268 if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1269 if (UNLIKELY(self->IsExceptionPending())) {
1270 return nullptr;
1271 }
1272 continue;
1273 }
Vladimir Markob0a6aee2017-10-27 10:34:04 +01001274 DCHECK(!m.IsMiranda()); // Direct methods cannot be miranda methods.
1275 if ((modifiers & kAccSynthetic) == 0) {
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001276 return Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, &m);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001277 }
Vladimir Markob0a6aee2017-10-27 10:34:04 +01001278 result = &m; // Remember as potential result.
Andreas Gampebc4d2182016-02-22 10:03:12 -08001279 }
1280 }
1281 return result != nullptr
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001282 ? Method::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, result)
Andreas Gampebc4d2182016-02-22 10:03:12 -08001283 : nullptr;
1284}
1285
1286template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001287ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k32, false>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001288 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001289 ObjPtr<Class> klass,
1290 ObjPtr<String> name,
1291 ObjPtr<ObjectArray<Class>> args);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001292template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001293ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k32, true>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001294 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001295 ObjPtr<Class> klass,
1296 ObjPtr<String> name,
1297 ObjPtr<ObjectArray<Class>> args);
Andreas Gampee01e3642016-07-25 13:06:04 -07001298template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001299ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k64, false>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001300 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001301 ObjPtr<Class> klass,
1302 ObjPtr<String> name,
1303 ObjPtr<ObjectArray<Class>> args);
Andreas Gampee01e3642016-07-25 13:06:04 -07001304template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001305ObjPtr<Method> Class::GetDeclaredMethodInternal<PointerSize::k64, true>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001306 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001307 ObjPtr<Class> klass,
1308 ObjPtr<String> name,
1309 ObjPtr<ObjectArray<Class>> args);
Andreas Gampebc4d2182016-02-22 10:03:12 -08001310
Andreas Gampe542451c2016-07-26 09:02:02 -07001311template <PointerSize kPointerSize, bool kTransactionActive>
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001312ObjPtr<Constructor> Class::GetDeclaredConstructorInternal(
Andreas Gampe6039e562016-04-05 18:18:43 -07001313 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001314 ObjPtr<Class> klass,
1315 ObjPtr<ObjectArray<Class>> args) {
Andreas Gampe6039e562016-04-05 18:18:43 -07001316 StackHandleScope<1> hs(self);
Andreas Gampee01e3642016-07-25 13:06:04 -07001317 ArtMethod* result = klass->GetDeclaredConstructor(self, hs.NewHandle(args), kPointerSize);
Andreas Gampe6039e562016-04-05 18:18:43 -07001318 return result != nullptr
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001319 ? Constructor::CreateFromArtMethod<kPointerSize, kTransactionActive>(self, result)
Andreas Gampe6039e562016-04-05 18:18:43 -07001320 : nullptr;
1321}
1322
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001323// Constructor::CreateFromArtMethod<kTransactionActive>(self, result)
Andreas Gampe6039e562016-04-05 18:18:43 -07001324
Andreas Gampe542451c2016-07-26 09:02:02 -07001325template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001326ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k32, false>(
Andreas Gampe6039e562016-04-05 18:18:43 -07001327 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001328 ObjPtr<Class> klass,
1329 ObjPtr<ObjectArray<Class>> args);
Andreas Gampe542451c2016-07-26 09:02:02 -07001330template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001331ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k32, true>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001332 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001333 ObjPtr<Class> klass,
1334 ObjPtr<ObjectArray<Class>> args);
Andreas Gampe542451c2016-07-26 09:02:02 -07001335template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001336ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k64, false>(
Andreas Gampee01e3642016-07-25 13:06:04 -07001337 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001338 ObjPtr<Class> klass,
1339 ObjPtr<ObjectArray<Class>> args);
Andreas Gampe542451c2016-07-26 09:02:02 -07001340template
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001341ObjPtr<Constructor> Class::GetDeclaredConstructorInternal<PointerSize::k64, true>(
Andreas Gampe6039e562016-04-05 18:18:43 -07001342 Thread* self,
Mathieu Chartier28bd2e42016-10-04 13:54:57 -07001343 ObjPtr<Class> klass,
1344 ObjPtr<ObjectArray<Class>> args);
Andreas Gampe6039e562016-04-05 18:18:43 -07001345
Andreas Gampe715fdc22016-04-18 17:07:30 -07001346int32_t Class::GetInnerClassFlags(Handle<Class> h_this, int32_t default_value) {
1347 if (h_this->IsProxyClass() || h_this->GetDexCache() == nullptr) {
1348 return default_value;
1349 }
1350 uint32_t flags;
David Sehr9323e6e2016-09-13 08:58:35 -07001351 if (!annotations::GetInnerClassFlags(h_this, &flags)) {
Andreas Gampe715fdc22016-04-18 17:07:30 -07001352 return default_value;
1353 }
1354 return flags;
1355}
1356
Mathieu Chartier93bbee02016-08-31 09:38:40 -07001357void Class::SetObjectSizeAllocFastPath(uint32_t new_object_size) {
1358 if (Runtime::Current()->IsActiveTransaction()) {
1359 SetField32Volatile<true>(ObjectSizeAllocFastPathOffset(), new_object_size);
1360 } else {
1361 SetField32Volatile<false>(ObjectSizeAllocFastPathOffset(), new_object_size);
1362 }
1363}
1364
David Sehr709b0702016-10-13 09:12:37 -07001365std::string Class::PrettyDescriptor(ObjPtr<mirror::Class> klass) {
1366 if (klass == nullptr) {
1367 return "null";
1368 }
1369 return klass->PrettyDescriptor();
1370}
1371
1372std::string Class::PrettyDescriptor() {
1373 std::string temp;
1374 return art::PrettyDescriptor(GetDescriptor(&temp));
1375}
1376
1377std::string Class::PrettyClass(ObjPtr<mirror::Class> c) {
1378 if (c == nullptr) {
1379 return "null";
1380 }
1381 return c->PrettyClass();
1382}
1383
1384std::string Class::PrettyClass() {
1385 std::string result;
1386 result += "java.lang.Class<";
1387 result += PrettyDescriptor();
1388 result += ">";
1389 return result;
1390}
1391
1392std::string Class::PrettyClassAndClassLoader(ObjPtr<mirror::Class> c) {
1393 if (c == nullptr) {
1394 return "null";
1395 }
1396 return c->PrettyClassAndClassLoader();
1397}
1398
1399std::string Class::PrettyClassAndClassLoader() {
1400 std::string result;
1401 result += "java.lang.Class<";
1402 result += PrettyDescriptor();
1403 result += ",";
1404 result += mirror::Object::PrettyTypeOf(GetClassLoader());
1405 // TODO: add an identifying hash value for the loader
1406 result += ">";
1407 return result;
1408}
1409
Andreas Gampe90b936d2017-01-31 08:58:55 -08001410template<VerifyObjectFlags kVerifyFlags> void Class::GetAccessFlagsDCheck() {
1411 // Check class is loaded/retired or this is java.lang.String that has a
1412 // circularity issue during loading the names of its members
1413 DCHECK(IsIdxLoaded<kVerifyFlags>() || IsRetired<kVerifyFlags>() ||
1414 IsErroneous<static_cast<VerifyObjectFlags>(kVerifyFlags & ~kVerifyThis)>() ||
1415 this == String::GetJavaLangString())
1416 << "IsIdxLoaded=" << IsIdxLoaded<kVerifyFlags>()
1417 << " IsRetired=" << IsRetired<kVerifyFlags>()
1418 << " IsErroneous=" <<
1419 IsErroneous<static_cast<VerifyObjectFlags>(kVerifyFlags & ~kVerifyThis)>()
1420 << " IsString=" << (this == String::GetJavaLangString())
1421 << " status= " << GetStatus<kVerifyFlags>()
1422 << " descriptor=" << PrettyDescriptor();
1423}
1424// Instantiate the common cases.
1425template void Class::GetAccessFlagsDCheck<kVerifyNone>();
1426template void Class::GetAccessFlagsDCheck<kVerifyThis>();
1427template void Class::GetAccessFlagsDCheck<kVerifyReads>();
1428template void Class::GetAccessFlagsDCheck<kVerifyWrites>();
1429template void Class::GetAccessFlagsDCheck<kVerifyAll>();
1430
Ian Rogers2dd0e2c2013-01-24 12:42:14 -08001431} // namespace mirror
1432} // namespace art