12dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers/*
22dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * Copyright (C) 2011 The Android Open Source Project
32dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers *
42dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * Licensed under the Apache License, Version 2.0 (the "License");
52dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * you may not use this file except in compliance with the License.
62dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * You may obtain a copy of the License at
72dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers *
82dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers *      http://www.apache.org/licenses/LICENSE-2.0
92dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers *
102dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * Unless required by applicable law or agreed to in writing, software
112dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * distributed under the License is distributed on an "AS IS" BASIS,
122dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
132dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * See the License for the specific language governing permissions and
142dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers * limitations under the License.
152dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers */
162dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
172dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "class.h"
182dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
19ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom#include "art_field-inl.h"
20ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom#include "art_method-inl.h"
213481ba2c4e4f3aa80d8c6d50a9f85dacb56b508bVladimir Marko#include "class_linker-inl.h"
222dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "class_loader.h"
2322d5e735f403c57525fe868304c7123f0ce66399Ian Rogers#include "class-inl.h"
242dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "dex_cache.h"
254f6ad8ab428038129b2d0d6c40b7fd625cca15e1Ian Rogers#include "dex_file-inl.h"
261d54e73444e017d3a65234e0f193846f3e27472bIan Rogers#include "gc/accounting/card_table-inl.h"
2722d5e735f403c57525fe868304c7123f0ce66399Ian Rogers#include "handle_scope-inl.h"
28fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier#include "method.h"
292dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "object_array-inl.h"
3022d5e735f403c57525fe868304c7123f0ce66399Ian Rogers#include "object-inl.h"
312dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "runtime.h"
322dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "thread.h"
332dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "throwable.h"
342dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "utils.h"
352dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers#include "well_known_classes.h"
362dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
372dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersnamespace art {
382dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersnamespace mirror {
392dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
4094f7b49578b6aaa80de8ffed230648d601393905Hiroshi YamauchiGcRoot<Class> Class::java_lang_Class_;
412dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
422dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersvoid Class::SetClassClass(Class* java_lang_Class) {
4394f7b49578b6aaa80de8ffed230648d601393905Hiroshi Yamauchi  CHECK(java_lang_Class_.IsNull())
4494f7b49578b6aaa80de8ffed230648d601393905Hiroshi Yamauchi      << java_lang_Class_.Read()
454f1ebc2b86c8467d1ecb3ec655316e6d7ee8b8b5Hiroshi Yamauchi      << " " << java_lang_Class;
46004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  CHECK(java_lang_Class != nullptr);
4766c2d2d64d7ea75602eb63de7ae9bd2eaeb0a3c2Mathieu Chartier  java_lang_Class->SetClassFlags(mirror::kClassFlagClass);
4894f7b49578b6aaa80de8ffed230648d601393905Hiroshi Yamauchi  java_lang_Class_ = GcRoot<Class>(java_lang_Class);
492dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
502dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
512dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersvoid Class::ResetClass() {
5294f7b49578b6aaa80de8ffed230648d601393905Hiroshi Yamauchi  CHECK(!java_lang_Class_.IsNull());
5394f7b49578b6aaa80de8ffed230648d601393905Hiroshi Yamauchi  java_lang_Class_ = GcRoot<Class>(nullptr);
542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
552dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
56bb87e0f1a52de656bc77cb01cb887e51a0e5198bMathieu Chartiervoid Class::VisitRoots(RootVisitor* visitor) {
57bb87e0f1a52de656bc77cb01cb887e51a0e5198bMathieu Chartier  java_lang_Class_.VisitRootIfNonNull(visitor, RootInfo(kRootStickyClass));
58c528dba35b5faece51ca658fc008b688f8b690adMathieu Chartier}
59c528dba35b5faece51ca658fc008b688f8b690adMathieu Chartier
6099babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampeinline void Class::SetVerifyError(mirror::Object* error) {
6199babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe  CHECK(error != nullptr) << PrettyClass(this);
6299babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe  if (Runtime::Current()->IsActiveTransaction()) {
6399babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe    SetFieldObject<true>(OFFSET_OF_OBJECT_MEMBER(Class, verify_error_), error);
6499babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe  } else {
6599babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe    SetFieldObject<false>(OFFSET_OF_OBJECT_MEMBER(Class, verify_error_), error);
6699babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe  }
6799babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe}
6899babb6add7db19ce7605f6d5e4aee79d52e386fAndreas Gampe
695b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchivoid Class::SetStatus(Handle<Class> h_this, Status new_status, Thread* self) {
705b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi  Status old_status = h_this->GetStatus();
71590fee9e8972f872301c2d16a575d579ee564beeMathieu Chartier  ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
72590fee9e8972f872301c2d16a575d579ee564beeMathieu Chartier  bool class_linker_initialized = class_linker != nullptr && class_linker->IsInitialized();
737dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers  if (LIKELY(class_linker_initialized)) {
7498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    if (UNLIKELY(new_status <= old_status && new_status != kStatusError &&
7598d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang                 new_status != kStatusRetired)) {
765b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi      LOG(FATAL) << "Unexpected change back of class status for " << PrettyClass(h_this.Get())
775b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi                 << " " << old_status << " -> " << new_status;
787dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers    }
797dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers    if (new_status >= kStatusResolved || old_status >= kStatusResolved) {
807dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers      // When classes are being resolved the resolution code should hold the lock.
815b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi      CHECK_EQ(h_this->GetLockOwnerThreadId(), self->GetThreadId())
827dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers            << "Attempt to change status of class while not holding its lock: "
835b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi            << PrettyClass(h_this.Get()) << " " << old_status << " -> " << new_status;
848f3c9ae38df2460940a26dff889a84430b6c38d3Ian Rogers    }
852dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
869837939678bb5dcba178e5fb00ed59b5d14c8d9bIan Rogers  if (UNLIKELY(new_status == kStatusError)) {
875b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    CHECK_NE(h_this->GetStatus(), kStatusError)
885b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi        << "Attempt to set as erroneous an already erroneous class "
895b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi        << PrettyClass(h_this.Get());
9031decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe    if (VLOG_IS_ON(class_linker)) {
9131decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe      LOG(ERROR) << "Setting " << PrettyDescriptor(h_this.Get()) << " to erroneous.";
9231decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe      if (self->IsExceptionPending()) {
9331decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe        LOG(ERROR) << "Exception: " << self->GetException()->Dump();
9431decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe      }
9531decb12db33cb9ed3fdb0de60ca18c6da077fe4Andreas Gampe    }
962dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
97cb086955c2a21270cd2f53a8bce71e577d776506Andreas Gampe    // Remember the current exception.
98cb086955c2a21270cd2f53a8bce71e577d776506Andreas Gampe    CHECK(self->GetException() != nullptr);
99cb086955c2a21270cd2f53a8bce71e577d776506Andreas Gampe    h_this->SetVerifyError(self->GetException());
1002dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
101575e78c41ece0dec969d31f46be563d4eb7ae43bAndreas Gampe  static_assert(sizeof(Status) == sizeof(uint32_t), "Size of status not equal to uint32");
102d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  if (Runtime::Current()->IsActiveTransaction()) {
1035b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    h_this->SetField32Volatile<true>(OFFSET_OF_OBJECT_MEMBER(Class, status_), new_status);
104d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  } else {
1055b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    h_this->SetField32Volatile<false>(OFFSET_OF_OBJECT_MEMBER(Class, status_), new_status);
106d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  }
10798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang
10898d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  if (!class_linker_initialized) {
10998d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // When the class linker is being initialized its single threaded and by definition there can be
11098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // no waiters. During initialization classes may appear temporary but won't be retired as their
11198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // size was statically computed.
11298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  } else {
11398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // Classes that are being resolved or initialized need to notify waiters that the class status
11498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // changed. See ClassLinker::EnsureResolved and ClassLinker::WaitForInitializeClass.
1155b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    if (h_this->IsTemp()) {
11698d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      // Class is a temporary one, ensure that waiters for resolution get notified of retirement
11798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      // so that they can grab the new version of the class from the class linker's table.
1185b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi      CHECK_LT(new_status, kStatusResolved) << PrettyDescriptor(h_this.Get());
11998d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      if (new_status == kStatusRetired || new_status == kStatusError) {
1205b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi        h_this->NotifyAll(self);
12198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      }
12298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    } else {
12398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      CHECK_NE(new_status, kStatusRetired);
12498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      if (old_status >= kStatusResolved || new_status >= kStatusResolved) {
1255b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi        h_this->NotifyAll(self);
12698d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      }
12798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    }
1287dfb28c066159e6cde8181720f0c451a700ef966Ian Rogers  }
1292dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
1302dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
1312dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersvoid Class::SetDexCache(DexCache* new_dex_cache) {
132b0fa5dc7769c1e054032f39de0a3f6d6dd06f8cfIan Rogers  SetFieldObject<false>(OFFSET_OF_OBJECT_MEMBER(Class, dex_cache_), new_dex_cache);
13391a6dc41003cdd22073e72fd5425df8e95b1c172Mathieu Chartier  SetDexCacheStrings(new_dex_cache != nullptr ? new_dex_cache->GetStrings() : nullptr);
1342dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
1352dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
136ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogersvoid Class::SetClassSize(uint32_t new_class_size) {
137e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  if (kIsDebugBuild && new_class_size < GetClassSize()) {
138e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    DumpClass(LOG(INTERNAL_FATAL), kDumpClassFullDetail);
139e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    LOG(INTERNAL_FATAL) << new_class_size << " vs " << GetClassSize();
140e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    LOG(FATAL) << " class=" << PrettyTypeOf(this);
1418b2c0b9abc3f520495f4387ea040132ba85cae69Ian Rogers  }
142d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  // Not called within a transaction.
143b0fa5dc7769c1e054032f39de0a3f6d6dd06f8cfIan Rogers  SetField32<false>(OFFSET_OF_OBJECT_MEMBER(Class, class_size_), new_class_size);
1442dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
1452dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
1462dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers// Return the class' name. The exact format is bizarre, but it's the specified behavior for
1472dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers// Class.getName: keywords for primitive types, regular "[I" form for primitive arrays (so "int"
1482dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers// but "[I"), and arrays of reference types written between "L" and ";" but with dots rather than
1492dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers// slashes (so "java.lang.String" but "[Ljava.lang.String;"). Madness.
150f832284dd847ff077577bb5712225430bbbb3b67Mathieu ChartierString* Class::ComputeName(Handle<Class> h_this) {
151f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  String* name = h_this->GetName();
152692fafd9778141fa6ef0048c9569abd7ee0253bfMathieu Chartier  if (name != nullptr) {
1532dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return name;
1542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
1551ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  std::string temp;
1561ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  const char* descriptor = h_this->GetDescriptor(&temp);
157692fafd9778141fa6ef0048c9569abd7ee0253bfMathieu Chartier  Thread* self = Thread::Current();
1582dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if ((descriptor[0] != 'L') && (descriptor[0] != '[')) {
1592dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // The descriptor indicates that this is the class for
1602dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // a primitive type; special-case the return value.
161004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    const char* c_name = nullptr;
1622dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    switch (descriptor[0]) {
1632dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'Z': c_name = "boolean"; break;
1642dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'B': c_name = "byte";    break;
1652dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'C': c_name = "char";    break;
1662dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'S': c_name = "short";   break;
1672dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'I': c_name = "int";     break;
1682dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'J': c_name = "long";    break;
1692dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'F': c_name = "float";   break;
1702dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'D': c_name = "double";  break;
1712dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    case 'V': c_name = "void";    break;
1722dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    default:
1732dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      LOG(FATAL) << "Unknown primitive type: " << PrintableChar(descriptor[0]);
1742dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
175692fafd9778141fa6ef0048c9569abd7ee0253bfMathieu Chartier    name = String::AllocFromModifiedUtf8(self, c_name);
1762dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  } else {
1772dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Convert the UTF-8 name to a java.lang.String. The name must use '.' to separate package
1782dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // components.
1791ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers    name = String::AllocFromModifiedUtf8(self, DescriptorToDot(descriptor).c_str());
1802dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
181f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  h_this->SetName(name);
1822dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  return name;
1832dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
1842dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
185ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogersvoid Class::DumpClass(std::ostream& os, int flags) {
1862dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if ((flags & kDumpClassFullDetail) == 0) {
1872dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    os << PrettyClass(this);
1882dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    if ((flags & kDumpClassClassLoader) != 0) {
1892dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      os << ' ' << GetClassLoader();
1902dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
1912dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    if ((flags & kDumpClassInitialized) != 0) {
1922dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      os << ' ' << GetStatus();
1932dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
1942dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    os << "\n";
1952dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return;
1962dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
1972dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
198e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  Thread* const self = Thread::Current();
199f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  StackHandleScope<2> hs(self);
200f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  Handle<mirror::Class> h_this(hs.NewHandle(this));
201f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  Handle<mirror::Class> h_super(hs.NewHandle(GetSuperClass()));
202e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  auto image_pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize();
203f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
2041ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  std::string temp;
2052dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  os << "----- " << (IsInterface() ? "interface" : "class") << " "
2061ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers     << "'" << GetDescriptor(&temp) << "' cl=" << GetClassLoader() << " -----\n",
2072dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  os << "  objectSize=" << SizeOf() << " "
208004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom     << "(" << (h_super.Get() != nullptr ? h_super->SizeOf() : -1) << " from super)\n",
2092dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  os << StringPrintf("  access=0x%04x.%04x\n",
2102dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      GetAccessFlags() >> 16, GetAccessFlags() & kAccJavaFlagsMask);
211004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  if (h_super.Get() != nullptr) {
212f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    os << "  super='" << PrettyClass(h_super.Get()) << "' (cl=" << h_super->GetClassLoader()
213f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier       << ")\n";
2142dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
2152dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (IsArrayClass()) {
2162dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    os << "  componentType=" << PrettyClass(GetComponentType()) << "\n";
2172dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
218f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  const size_t num_direct_interfaces = NumDirectInterfaces();
219f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  if (num_direct_interfaces > 0) {
220f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    os << "  interfaces (" << num_direct_interfaces << "):\n";
221f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    for (size_t i = 0; i < num_direct_interfaces; ++i) {
222f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      Class* interface = GetDirectInterface(self, h_this, i);
22316f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe      if (interface == nullptr) {
22416f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe        os << StringPrintf("    %2zd: nullptr!\n", i);
22516f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe      } else {
22616f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe        const ClassLoader* cl = interface->GetClassLoader();
22716f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe        os << StringPrintf("    %2zd: %s (cl=%p)\n", i, PrettyClass(interface).c_str(), cl);
22816f149c2cb43a14d8f33d7d0fa36cd784e900f07Andreas Gampe      }
2292dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
2302dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
23198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  if (!IsLoaded()) {
23298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    os << "  class not yet loaded";
23398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  } else {
23498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    // After this point, this may have moved due to GetDirectInterface.
23598d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    os << "  vtable (" << h_this->NumVirtualMethods() << " entries, "
23698d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        << (h_super.Get() != nullptr ? h_super->NumVirtualMethods() : 0) << " in super):\n";
23798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    for (size_t i = 0; i < NumVirtualMethods(); ++i) {
238e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      os << StringPrintf("    %2zd: %s\n", i, PrettyMethod(
239e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier          h_this->GetVirtualMethodDuringLinking(i, image_pointer_size)).c_str());
24098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    }
24198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    os << "  direct methods (" << h_this->NumDirectMethods() << " entries):\n";
24298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    for (size_t i = 0; i < h_this->NumDirectMethods(); ++i) {
243e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      os << StringPrintf("    %2zd: %s\n", i, PrettyMethod(
244e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier          h_this->GetDirectMethod(i, image_pointer_size)).c_str());
24598d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    }
24698d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    if (h_this->NumStaticFields() > 0) {
24798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      os << "  static fields (" << h_this->NumStaticFields() << " entries):\n";
24898d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      if (h_this->IsResolved() || h_this->IsErroneous()) {
24998d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        for (size_t i = 0; i < h_this->NumStaticFields(); ++i) {
25098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang          os << StringPrintf("    %2zd: %s\n", i, PrettyField(h_this->GetStaticField(i)).c_str());
25198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        }
25298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      } else {
25398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        os << "    <not yet available>";
2542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
2552dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
25698d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang    if (h_this->NumInstanceFields() > 0) {
25798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      os << "  instance fields (" << h_this->NumInstanceFields() << " entries):\n";
25898d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      if (h_this->IsResolved() || h_this->IsErroneous()) {
25998d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        for (size_t i = 0; i < h_this->NumInstanceFields(); ++i) {
26098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang          os << StringPrintf("    %2zd: %s\n", i, PrettyField(h_this->GetInstanceField(i)).c_str());
26198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        }
26298d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang      } else {
26398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang        os << "    <not yet available>";
2642dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
2652dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
2662dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
2672dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
2682dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
2692dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersvoid Class::SetReferenceInstanceOffsets(uint32_t new_reference_offsets) {
270e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  if (kIsDebugBuild && new_reference_offsets != kClassWalkSuper) {
2712dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Sanity check that the number of bits set in the reference offset bitmap
2722dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // agrees with the number of references
273cdc1aaffabbdf417d29b203b2cd2763ed2d623f8Ian Rogers    uint32_t count = 0;
274004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    for (Class* c = this; c != nullptr; c = c->GetSuperClass()) {
2752dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      count += c->NumReferenceInstanceFieldsDuringLinking();
2762dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
277cdc1aaffabbdf417d29b203b2cd2763ed2d623f8Ian Rogers    // +1 for the Class in Object.
278cdc1aaffabbdf417d29b203b2cd2763ed2d623f8Ian Rogers    CHECK_EQ(static_cast<uint32_t>(POPCOUNT(new_reference_offsets)) + 1, count);
2792dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
280d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  // Not called within a transaction.
281d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  SetField32<false>(OFFSET_OF_OBJECT_MEMBER(Class, reference_instance_offsets_),
282b0fa5dc7769c1e054032f39de0a3f6d6dd06f8cfIan Rogers                    new_reference_offsets);
2832dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
2842dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
2852dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersbool Class::IsInSamePackage(const StringPiece& descriptor1, const StringPiece& descriptor2) {
2862dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  size_t i = 0;
2876b604a1b0289e5e7211c2e5f8c4f395f51de7c3dIan Rogers  size_t min_length = std::min(descriptor1.size(), descriptor2.size());
2886b604a1b0289e5e7211c2e5f8c4f395f51de7c3dIan Rogers  while (i < min_length && descriptor1[i] == descriptor2[i]) {
2892dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    ++i;
2902dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
2912dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (descriptor1.find('/', i) != StringPiece::npos ||
2922dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      descriptor2.find('/', i) != StringPiece::npos) {
2932dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return false;
2942dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  } else {
2952dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return true;
2962dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
2972dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
2982dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
299ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogersbool Class::IsInSamePackage(Class* that) {
300ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogers  Class* klass1 = this;
301ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogers  Class* klass2 = that;
3022dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (klass1 == klass2) {
3032dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return true;
3042dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3052dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Class loaders must match.
3062dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (klass1->GetClassLoader() != klass2->GetClassLoader()) {
3072dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return false;
3082dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3092dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Arrays are in the same package when their element classes are.
3102dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  while (klass1->IsArrayClass()) {
3112dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    klass1 = klass1->GetComponentType();
3122dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3132dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  while (klass2->IsArrayClass()) {
3142dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    klass2 = klass2->GetComponentType();
3152dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3169fa3f20c5fa101a4f55f123d817590b7cfbdbfc0Anwar Ghuloum  // trivial check again for array types
3179fa3f20c5fa101a4f55f123d817590b7cfbdbfc0Anwar Ghuloum  if (klass1 == klass2) {
3189fa3f20c5fa101a4f55f123d817590b7cfbdbfc0Anwar Ghuloum    return true;
3199fa3f20c5fa101a4f55f123d817590b7cfbdbfc0Anwar Ghuloum  }
3202dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Compare the package part of the descriptor string.
3211ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  std::string temp1, temp2;
3221ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  return IsInSamePackage(klass1->GetDescriptor(&temp1), klass2->GetDescriptor(&temp2));
3232dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
3242dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
325ef7d42fca18c16fbaf103822ad16f23246e2905dIan Rogersbool Class::IsThrowableClass() {
3262dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  return WellKnownClasses::ToClass(WellKnownClasses::java_lang_Throwable)->IsAssignableFrom(this);
3272dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
3282dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
3292dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogersvoid Class::SetClassLoader(ClassLoader* new_class_loader) {
330d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  if (Runtime::Current()->IsActiveTransaction()) {
331b0fa5dc7769c1e054032f39de0a3f6d6dd06f8cfIan Rogers    SetFieldObject<true>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
332d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  } else {
333b0fa5dc7769c1e054032f39de0a3f6d6dd06f8cfIan Rogers    SetFieldObject<false>(OFFSET_OF_OBJECT_MEMBER(Class, class_loader_), new_class_loader);
334d2fe10a3a34af171bf1631219cd2d6ff6b7778b5Sebastien Hertz  }
3352dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
3362dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
337e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindInterfaceMethod(const StringPiece& name, const StringPiece& signature,
338e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                      size_t pointer_size) {
339004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  // Check the current class before checking the interfaces.
340e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  ArtMethod* method = FindDeclaredVirtualMethod(name, signature, pointer_size);
341004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  if (method != nullptr) {
342004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    return method;
343004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  }
344004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom
345004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  int32_t iftable_count = GetIfTableCount();
346004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  IfTable* iftable = GetIfTable();
347004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (int32_t i = 0; i < iftable_count; ++i) {
348e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    method = iftable->GetInterface(i)->FindDeclaredVirtualMethod(name, signature, pointer_size);
349004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
350004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom      return method;
351004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    }
352004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  }
353004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
354004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom}
355004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom
356e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindInterfaceMethod(const StringPiece& name, const Signature& signature,
357e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                      size_t pointer_size) {
3582dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Check the current class before checking the interfaces.
359e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  ArtMethod* method = FindDeclaredVirtualMethod(name, signature, pointer_size);
360004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  if (method != nullptr) {
3612dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return method;
3622dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3632dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
3642dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  int32_t iftable_count = GetIfTableCount();
3652dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  IfTable* iftable = GetIfTable();
366004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (int32_t i = 0; i < iftable_count; ++i) {
367e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    method = iftable->GetInterface(i)->FindDeclaredVirtualMethod(name, signature, pointer_size);
368004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
3692dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
3702dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
3712dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
372004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
3732dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
3742dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
375e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindInterfaceMethod(const DexCache* dex_cache, uint32_t dex_method_idx,
376e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                      size_t pointer_size) {
3772dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Check the current class before checking the interfaces.
378e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  ArtMethod* method = FindDeclaredVirtualMethod(dex_cache, dex_method_idx, pointer_size);
379004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  if (method != nullptr) {
3802dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    return method;
3812dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
3822dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
3832dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  int32_t iftable_count = GetIfTableCount();
3842dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  IfTable* iftable = GetIfTable();
385004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (int32_t i = 0; i < iftable_count; ++i) {
386e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    method = iftable->GetInterface(i)->FindDeclaredVirtualMethod(
387e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier        dex_cache, dex_method_idx, pointer_size);
388004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
3892dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
3902dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
3912dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
392004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
3932dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
3942dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
395e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredDirectMethod(const StringPiece& name, const StringPiece& signature,
396e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                           size_t pointer_size) {
397e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (auto& method : GetDirectMethods(pointer_size)) {
398e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (name == method.GetName() && method.GetSignature() == signature) {
399e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &method;
400d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers    }
401d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers  }
402004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
403d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers}
404d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers
405e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredDirectMethod(const StringPiece& name, const Signature& signature,
406e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                           size_t pointer_size) {
407e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (auto& method : GetDirectMethods(pointer_size)) {
408e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (name == method.GetName() && signature == method.GetSignature()) {
409e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &method;
4102dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
4112dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
412004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
4132dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
4142dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
415e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredDirectMethod(const DexCache* dex_cache, uint32_t dex_method_idx,
416e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                           size_t pointer_size) {
4172dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (GetDexCache() == dex_cache) {
418e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    for (auto& method : GetDirectMethods(pointer_size)) {
419e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      if (method.GetDexMethodIndex() == dex_method_idx) {
420e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier        return &method;
4212dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
4222dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
4232dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
424004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
4252dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
4262dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
427e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDirectMethod(const StringPiece& name, const StringPiece& signature,
428e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                   size_t pointer_size) {
429004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
430e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredDirectMethod(name, signature, pointer_size);
431004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
4322dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
4332dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
4342dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
435004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
4362dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
4372dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
438e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDirectMethod(const StringPiece& name, const Signature& signature,
439e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                   size_t pointer_size) {
440004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
441e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredDirectMethod(name, signature, pointer_size);
442004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
443d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers      return method;
444d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers    }
445d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers  }
446004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
447d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers}
448d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers
449e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDirectMethod(
450e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    const DexCache* dex_cache, uint32_t dex_method_idx, size_t pointer_size) {
451004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
452e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredDirectMethod(dex_cache, dex_method_idx, pointer_size);
453004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
4542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
4552dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
4562dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
457004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
4582dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
4592dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
460a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas GeoffrayArtMethod* Class::FindDeclaredDirectMethodByName(const StringPiece& name, size_t pointer_size) {
461a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray  for (auto& method : GetDirectMethods(pointer_size)) {
462a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray    ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
463a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray    if (name == np_method->GetName()) {
464a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray      return &method;
465a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray    }
466a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray  }
467a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray  return nullptr;
468a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray}
469a42363f79832a6e14f348514664dc6dc3edf9da2Nicolas Geoffray
470e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light// TODO These should maybe be changed to be named FindOwnedVirtualMethod or something similar
471e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light// because they do not only find 'declared' methods and will return copied methods. This behavior is
472e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light// desired and correct but the naming can lead to confusion because in the java language declared
473e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light// excludes interface methods which might be found by this.
474e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredVirtualMethod(const StringPiece& name, const StringPiece& signature,
475e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                            size_t pointer_size) {
476e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (auto& method : GetVirtualMethods(pointer_size)) {
47772156e28fd6bc72ac965b29446f8801b2e82f2fdMathieu Chartier    ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
47872156e28fd6bc72ac965b29446f8801b2e82f2fdMathieu Chartier    if (name == np_method->GetName() && np_method->GetSignature() == signature) {
479e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &method;
480d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers    }
481d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers  }
482004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
483d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers}
484d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers
485e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredVirtualMethod(const StringPiece& name, const Signature& signature,
486e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                            size_t pointer_size) {
487e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (auto& method : GetVirtualMethods(pointer_size)) {
48872156e28fd6bc72ac965b29446f8801b2e82f2fdMathieu Chartier    ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
48972156e28fd6bc72ac965b29446f8801b2e82f2fdMathieu Chartier    if (name == np_method->GetName() && signature == np_method->GetSignature()) {
490e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &method;
4912dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
4922dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
493004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
4942dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
4952dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
496e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindDeclaredVirtualMethod(const DexCache* dex_cache, uint32_t dex_method_idx,
497e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier                                            size_t pointer_size) {
4982dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (GetDexCache() == dex_cache) {
499e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light    for (auto& method : GetDeclaredVirtualMethods(pointer_size)) {
500e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light      if (method.GetDexMethodIndex() == dex_method_idx) {
501e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier        return &method;
5022dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
5032dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
5042dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
505004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
5062dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
5072dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
50813e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff HaoArtMethod* Class::FindDeclaredVirtualMethodByName(const StringPiece& name, size_t pointer_size) {
50913e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao  for (auto& method : GetVirtualMethods(pointer_size)) {
51013e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao    ArtMethod* const np_method = method.GetInterfaceMethodIfProxy(pointer_size);
51113e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao    if (name == np_method->GetName()) {
51213e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao      return &method;
51313e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao    }
51413e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao  }
51513e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao  return nullptr;
51613e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao}
51713e748b28c5f2bd1e83674d2ca899ff61ae5c0a1Jeff Hao
518e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindVirtualMethod(
519e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    const StringPiece& name, const StringPiece& signature, size_t pointer_size) {
520004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
521e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredVirtualMethod(name, signature, pointer_size);
522004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
5232dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
5242dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
5252dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
526004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
5272dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
5282dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
529e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindVirtualMethod(
530e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    const StringPiece& name, const Signature& signature, size_t pointer_size) {
531004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
532e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredVirtualMethod(name, signature, pointer_size);
533004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
534d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers      return method;
535d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers    }
536d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers  }
537004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
538d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers}
539d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers
540e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindVirtualMethod(
541e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    const DexCache* dex_cache, uint32_t dex_method_idx, size_t pointer_size) {
542004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* klass = this; klass != nullptr; klass = klass->GetSuperClass()) {
543e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    ArtMethod* method = klass->FindDeclaredVirtualMethod(dex_cache, dex_method_idx, pointer_size);
544004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (method != nullptr) {
5452dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return method;
5462dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
547d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers  }
548004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
549d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers}
550d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers
551705ad49f353d3f90d8b63625aca2c2035bacdbefAlex LightArtMethod* Class::FindVirtualMethodForInterfaceSuper(ArtMethod* method, size_t pointer_size) {
552705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  DCHECK(method->GetDeclaringClass()->IsInterface());
553705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  DCHECK(IsInterface()) << "Should only be called on a interface class";
554705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // Check if we have one defined on this interface first. This includes searching copied ones to
555705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // get any conflict methods. Conflict methods are copied into each subtype from the supertype. We
556705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // don't do any indirect method checks here.
557705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  for (ArtMethod& iface_method : GetVirtualMethods(pointer_size)) {
558705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    if (method->HasSameNameAndSignature(&iface_method)) {
559705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light      return &iface_method;
560705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    }
561705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  }
562705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light
563705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  std::vector<ArtMethod*> abstract_methods;
564705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // Search through the IFTable for a working version. We don't need to check for conflicts
565705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // because if there was one it would appear in this classes virtual_methods_ above.
566705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light
567705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  Thread* self = Thread::Current();
568705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  StackHandleScope<2> hs(self);
569705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  MutableHandle<mirror::IfTable> iftable(hs.NewHandle(GetIfTable()));
570705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  MutableHandle<mirror::Class> iface(hs.NewHandle<mirror::Class>(nullptr));
571705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  size_t iftable_count = GetIfTableCount();
572705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // Find the method. We don't need to check for conflicts because they would have been in the
573705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // copied virtuals of this interface.  Order matters, traverse in reverse topological order; most
574705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // subtypiest interfaces get visited first.
575705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  for (size_t k = iftable_count; k != 0;) {
576705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    k--;
577705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    DCHECK_LT(k, iftable->Count());
578705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    iface.Assign(iftable->GetInterface(k));
579705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    // Iterate through every declared method on this interface. Each direct method's name/signature
580705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    // is unique so the order of the inner loop doesn't matter.
581705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    for (auto& method_iter : iface->GetDeclaredVirtualMethods(pointer_size)) {
582705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light      ArtMethod* current_method = &method_iter;
583705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light      if (current_method->HasSameNameAndSignature(method)) {
584705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light        if (current_method->IsDefault()) {
585705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // Handle JLS soft errors, a default method from another superinterface tree can
586705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // "override" an abstract method(s) from another superinterface tree(s).  To do this,
587705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // ignore any [default] method which are dominated by the abstract methods we've seen so
588705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // far. Check if overridden by any in abstract_methods. We do not need to check for
589705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // default_conflicts because we would hit those before we get to this loop.
590705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          bool overridden = false;
591705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          for (ArtMethod* possible_override : abstract_methods) {
592705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light            DCHECK(possible_override->HasSameNameAndSignature(current_method));
593705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light            if (iface->IsAssignableFrom(possible_override->GetDeclaringClass())) {
594705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light              overridden = true;
595705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light              break;
596705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light            }
597705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          }
598705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          if (!overridden) {
599705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light            return current_method;
600705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          }
601705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light        } else {
602705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // Is not default.
603705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          // This might override another default method. Just stash it for now.
604705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light          abstract_methods.push_back(current_method);
605705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light        }
606705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light      }
607705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light    }
608705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  }
609705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // If we reach here we either never found any declaration of the method (in which case
610705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // 'abstract_methods' is empty or we found no non-overriden default methods in which case
611705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // 'abstract_methods' contains a number of abstract implementations of the methods. We choose one
612705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  // of these arbitrarily.
613705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light  return abstract_methods.empty() ? nullptr : abstract_methods[0];
614705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light}
615705ad49f353d3f90d8b63625aca2c2035bacdbefAlex Light
616e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::FindClassInitializer(size_t pointer_size) {
617e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (ArtMethod& method : GetDirectMethods(pointer_size)) {
618e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (method.IsClassInitializer()) {
619e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      DCHECK_STREQ(method.GetName(), "<clinit>");
620e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      DCHECK_STREQ(method.GetSignature().ToString().c_str(), "()V");
621e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &method;
622d91d6d6a80748f277fd938a412211e5af28913b1Ian Rogers    }
6232dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
624004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
6252dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
6262dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
627e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier// Custom binary search to avoid double comparisons from std::binary_search.
628e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartierstatic ArtField* FindFieldByNameAndType(LengthPrefixedArray<ArtField>* fields,
629e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier                                        const StringPiece& name,
630e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier                                        const StringPiece& type)
631e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    SHARED_REQUIRES(Locks::mutator_lock_) {
632e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  if (fields == nullptr) {
633e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    return nullptr;
634e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  }
635e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  size_t low = 0;
63635831e8bfa1c0944d4c978d99c4c5b9577945170Vladimir Marko  size_t high = fields->size();
637e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  ArtField* ret = nullptr;
638e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  while (low < high) {
639e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    size_t mid = (low + high) / 2;
640e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    ArtField& field = fields->At(mid);
641e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    // Fields are sorted by class, then name, then type descriptor. This is verified in dex file
642e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    // verifier. There can be multiple fields with the same in the same class name due to proguard.
643e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    int result = StringPiece(field.GetName()).Compare(name);
644e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    if (result == 0) {
645e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      result = StringPiece(field.GetTypeDescriptor()).Compare(type);
646e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    }
647e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    if (result < 0) {
648e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      low = mid + 1;
649e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    } else if (result > 0) {
650e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      high = mid;
651e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    } else {
652e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      ret = &field;
653e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      break;
6542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
6552dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
656e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  if (kIsDebugBuild) {
657e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    ArtField* found = nullptr;
658e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    for (ArtField& field : MakeIterationRangeFromLengthPrefixedArray(fields)) {
659e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      if (name == field.GetName() && type == field.GetTypeDescriptor()) {
660e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier        found = &field;
661e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier        break;
662e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      }
663e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    }
664e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    CHECK_EQ(found, ret) << "Found " << PrettyField(found) << " vs  " << PrettyField(ret);
665e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  }
666e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  return ret;
667e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier}
668e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier
669e2aa3265594486b4b977453752645cdce3026e82Mathieu ChartierArtField* Class::FindDeclaredInstanceField(const StringPiece& name, const StringPiece& type) {
670e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  // Binary search by name. Interfaces are not relevant because they can't contain instance fields.
671e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  return FindFieldByNameAndType(GetIFieldsPtr(), name, type);
6722dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
6732dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
674ea46f950e7a51585db293cd7f047de190a482414Brian CarlstromArtField* Class::FindDeclaredInstanceField(const DexCache* dex_cache, uint32_t dex_field_idx) {
6752dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (GetDexCache() == dex_cache) {
676e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    for (ArtField& field : GetIFields()) {
677e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      if (field.GetDexFieldIndex() == dex_field_idx) {
678e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier        return &field;
6792dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
6802dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
6812dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
682004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
6832dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
6842dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
685ea46f950e7a51585db293cd7f047de190a482414Brian CarlstromArtField* Class::FindInstanceField(const StringPiece& name, const StringPiece& type) {
6862dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Is the field in this class, or any of its superclasses?
6872dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Interfaces are not relevant because they can't contain instance fields.
688004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* c = this; c != nullptr; c = c->GetSuperClass()) {
689ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom    ArtField* f = c->FindDeclaredInstanceField(name, type);
690004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (f != nullptr) {
6912dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
6922dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
6932dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
694004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
6952dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
6962dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
697ea46f950e7a51585db293cd7f047de190a482414Brian CarlstromArtField* Class::FindInstanceField(const DexCache* dex_cache, uint32_t dex_field_idx) {
6982dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Is the field in this class, or any of its superclasses?
6992dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Interfaces are not relevant because they can't contain instance fields.
700004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* c = this; c != nullptr; c = c->GetSuperClass()) {
701ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom    ArtField* f = c->FindDeclaredInstanceField(dex_cache, dex_field_idx);
702004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (f != nullptr) {
7032dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
7042dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7052dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
706004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
7072dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
7082dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
709ea46f950e7a51585db293cd7f047de190a482414Brian CarlstromArtField* Class::FindDeclaredStaticField(const StringPiece& name, const StringPiece& type) {
710004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  DCHECK(type != nullptr);
711e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier  return FindFieldByNameAndType(GetSFieldsPtr(), name, type);
7122dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
7132dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
714ea46f950e7a51585db293cd7f047de190a482414Brian CarlstromArtField* Class::FindDeclaredStaticField(const DexCache* dex_cache, uint32_t dex_field_idx) {
7152dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  if (dex_cache == GetDexCache()) {
716e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier    for (ArtField& field : GetSFields()) {
717e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier      if (field.GetDexFieldIndex() == dex_field_idx) {
718e2aa3265594486b4b977453752645cdce3026e82Mathieu Chartier        return &field;
7192dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
7202dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7212dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
722004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  return nullptr;
7232dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
7242dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
725f832284dd847ff077577bb5712225430bbbb3b67Mathieu ChartierArtField* Class::FindStaticField(Thread* self, Handle<Class> klass, const StringPiece& name,
726f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier                                 const StringPiece& type) {
7272dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Is the field in this class (or its interfaces), or any of its
7282dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // superclasses (or their interfaces)?
729f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  for (Class* k = klass.Get(); k != nullptr; k = k->GetSuperClass()) {
7302dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is the field in this class?
731ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom    ArtField* f = k->FindDeclaredStaticField(name, type);
732f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    if (f != nullptr) {
7332dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
7342dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
735f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    // Wrap k incase it moves during GetDirectInterface.
736f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    StackHandleScope<1> hs(self);
737f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    HandleWrapper<mirror::Class> h_k(hs.NewHandleWrapper(&k));
7382dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is this field in any of this class' interfaces?
739f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    for (uint32_t i = 0; i < h_k->NumDirectInterfaces(); ++i) {
740277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      StackHandleScope<1> hs2(self);
741277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      Handle<mirror::Class> interface(hs2.NewHandle(GetDirectInterface(self, h_k, i)));
742f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      f = FindStaticField(self, interface, name, type);
743f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      if (f != nullptr) {
7442dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers        return f;
7452dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
7462dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7472dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
748f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return nullptr;
7492dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
7502dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
751f832284dd847ff077577bb5712225430bbbb3b67Mathieu ChartierArtField* Class::FindStaticField(Thread* self, Handle<Class> klass, const DexCache* dex_cache,
752f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier                                 uint32_t dex_field_idx) {
753f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  for (Class* k = klass.Get(); k != nullptr; k = k->GetSuperClass()) {
7542dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is the field in this class?
755ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom    ArtField* f = k->FindDeclaredStaticField(dex_cache, dex_field_idx);
756004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom    if (f != nullptr) {
7572dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
7582dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
759f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    // Wrap k incase it moves during GetDirectInterface.
760f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    StackHandleScope<1> hs(self);
761f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    HandleWrapper<mirror::Class> h_k(hs.NewHandleWrapper(&k));
7622dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is this field in any of this class' interfaces?
763f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    for (uint32_t i = 0; i < h_k->NumDirectInterfaces(); ++i) {
764277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      StackHandleScope<1> hs2(self);
765277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      Handle<mirror::Class> interface(hs2.NewHandle(GetDirectInterface(self, h_k, i)));
766f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      f = FindStaticField(self, interface, dex_cache, dex_field_idx);
767f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      if (f != nullptr) {
7682dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers        return f;
7692dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
7702dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7712dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
772f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return nullptr;
7732dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
7742dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
775f832284dd847ff077577bb5712225430bbbb3b67Mathieu ChartierArtField* Class::FindField(Thread* self, Handle<Class> klass, const StringPiece& name,
776f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier                           const StringPiece& type) {
7772dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  // Find a field using the JLS field resolution order
778004644fe87046b965442b1ee1008b7206817d187Brian Carlstrom  for (Class* k = klass.Get(); k != nullptr; k = k->GetSuperClass()) {
7792dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is the field in this class?
780ea46f950e7a51585db293cd7f047de190a482414Brian Carlstrom    ArtField* f = k->FindDeclaredInstanceField(name, type);
781f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    if (f != nullptr) {
7822dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
7832dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7842dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    f = k->FindDeclaredStaticField(name, type);
785f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    if (f != nullptr) {
7862dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      return f;
7872dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7882dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    // Is this field in any of this class' interfaces?
789f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    StackHandleScope<1> hs(self);
790f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    HandleWrapper<mirror::Class> h_k(hs.NewHandleWrapper(&k));
791f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    for (uint32_t i = 0; i < h_k->NumDirectInterfaces(); ++i) {
792277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      StackHandleScope<1> hs2(self);
793277ccbd200ea43590dfc06a93ae184a765327ad0Andreas Gampe      Handle<mirror::Class> interface(hs2.NewHandle(GetDirectInterface(self, h_k, i)));
794f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      f = interface->FindStaticField(self, interface, name, type);
795f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      if (f != nullptr) {
7962dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers        return f;
7972dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers      }
7982dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers    }
7992dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers  }
800f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return nullptr;
8012dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}
8022dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers
803df707e406877e9c0426dd051c00933ebb331673eIgor Murashkinvoid Class::SetSkipAccessChecksFlagOnAllMethods(size_t pointer_size) {
804e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  DCHECK(IsVerified());
805e64300b8488716056775ecbfa2915dd1b4ce7e08Alex Light  for (auto& m : GetMethods(pointer_size)) {
8069139e008abe30b7beaf4afd6533228a1dd9b202cAlex Light    if (!m.IsNative() && m.IsInvokable()) {
807df707e406877e9c0426dd051c00933ebb331673eIgor Murashkin      m.SetSkipAccessChecks();
808233ea8e084a95ad2a3af746dddbadb155db6a814Sebastien Hertz    }
809233ea8e084a95ad2a3af746dddbadb155db6a814Sebastien Hertz  }
810233ea8e084a95ad2a3af746dddbadb155db6a814Sebastien Hertz}
811233ea8e084a95ad2a3af746dddbadb155db6a814Sebastien Hertz
8121ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogersconst char* Class::GetDescriptor(std::string* storage) {
8131ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  if (IsPrimitive()) {
814f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return Primitive::Descriptor(GetPrimitiveType());
8151ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  } else if (IsArrayClass()) {
8161ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers    return GetArrayDescriptor(storage);
8173a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray  } else if (IsProxyClass()) {
8183a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray    *storage = Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this);
8191ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers    return storage->c_str();
820f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  } else {
821f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    const DexFile& dex_file = GetDexFile();
822f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    const DexFile::TypeId& type_id = dex_file.GetTypeId(GetClassDef()->class_idx_);
823f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return dex_file.GetTypeDescriptor(type_id);
824f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  }
825f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
826f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
8271ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogersconst char* Class::GetArrayDescriptor(std::string* storage) {
8281ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  std::string temp;
8291ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  const char* elem_desc = GetComponentType()->GetDescriptor(&temp);
8301ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  *storage = "[";
8311ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  *storage += elem_desc;
8321ff3c98775a4577cf053dba9a0c2d5c21c07b298Ian Rogers  return storage->c_str();
833f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
834f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
835f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartierconst DexFile::ClassDef* Class::GetClassDef() {
836f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  uint16_t class_def_idx = GetDexClassDefIndex();
837f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  if (class_def_idx == DexFile::kDexNoIndex16) {
838f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return nullptr;
839f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  }
840f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return &GetDexFile().GetClassDef(class_def_idx);
841f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
842f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
843f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartieruint16_t Class::GetDirectInterfaceTypeIdx(uint32_t idx) {
844f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  DCHECK(!IsPrimitive());
845f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  DCHECK(!IsArrayClass());
846f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return GetInterfaceTypeList()->GetTypeItem(idx).type_idx_;
847f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
848f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
8495a4b8a236030460651a3136397d23ca6744e7eb7Andreas Gampemirror::Class* Class::GetDirectInterface(Thread* self, Handle<mirror::Class> klass,
850bf99f77dda749e2b653e8c45259b1fb56e7bb012Mathieu Chartier                                         uint32_t idx) {
851f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  DCHECK(klass.Get() != nullptr);
852f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  DCHECK(!klass->IsPrimitive());
853f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  if (klass->IsArrayClass()) {
854f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    ClassLinker* class_linker = Runtime::Current()->GetClassLinker();
855f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    if (idx == 0) {
856f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      return class_linker->FindSystemClass(self, "Ljava/lang/Cloneable;");
857f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    } else {
858f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      DCHECK_EQ(1U, idx);
859f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      return class_linker->FindSystemClass(self, "Ljava/io/Serializable;");
860f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    }
8613a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray  } else if (klass->IsProxyClass()) {
8623a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray    mirror::ObjectArray<mirror::Class>* interfaces = klass.Get()->GetInterfaces();
863f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    DCHECK(interfaces != nullptr);
864f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return interfaces->Get(idx);
865f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  } else {
866f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    uint16_t type_idx = klass->GetDirectInterfaceTypeIdx(idx);
867f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    mirror::Class* interface = klass->GetDexCache()->GetResolvedType(type_idx);
868f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    if (interface == nullptr) {
869f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      interface = Runtime::Current()->GetClassLinker()->ResolveType(klass->GetDexFile(), type_idx,
870f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier                                                                    klass.Get());
871f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier      CHECK(interface != nullptr || self->IsExceptionPending());
872f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    }
873f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return interface;
874f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  }
875f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
876f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
87752503d83d057c66ea50eed491290e267b80e1fd3Calin Juravlemirror::Class* Class::GetCommonSuperClass(Handle<Class> klass) {
87852503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  DCHECK(klass.Get() != nullptr);
87952503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  DCHECK(!klass->IsInterface());
88052503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  DCHECK(!IsInterface());
88152503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  mirror::Class* common_super_class = this;
88252503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  while (!common_super_class->IsAssignableFrom(klass.Get())) {
88322deed092ff53e4e11e09dd9bd24a220a566190fAart Bik    mirror::Class* old_common = common_super_class;
88422deed092ff53e4e11e09dd9bd24a220a566190fAart Bik    common_super_class = old_common->GetSuperClass();
88522deed092ff53e4e11e09dd9bd24a220a566190fAart Bik    DCHECK(common_super_class != nullptr) << PrettyClass(old_common);
88652503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  }
88752503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle  return common_super_class;
88852503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle}
88952503d83d057c66ea50eed491290e267b80e1fd3Calin Juravle
890f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartierconst char* Class::GetSourceFile() {
891f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  const DexFile& dex_file = GetDexFile();
892f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  const DexFile::ClassDef* dex_class_def = GetClassDef();
8934206eb5d86d3a2406361e59b2018152b2485ccedSebastien Hertz  if (dex_class_def == nullptr) {
8944206eb5d86d3a2406361e59b2018152b2485ccedSebastien Hertz    // Generated classes have no class def.
8954206eb5d86d3a2406361e59b2018152b2485ccedSebastien Hertz    return nullptr;
8964206eb5d86d3a2406361e59b2018152b2485ccedSebastien Hertz  }
897f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return dex_file.GetSourceFile(*dex_class_def);
898f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
899f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
900f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartierstd::string Class::GetLocation() {
901f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  mirror::DexCache* dex_cache = GetDexCache();
9023a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray  if (dex_cache != nullptr && !IsProxyClass()) {
903f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return dex_cache->GetLocation()->ToModifiedUtf8();
904f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  }
905f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  // Arrays and proxies are generated and have no corresponding dex file location.
906f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return "generated class";
907f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
908f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
909f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartierconst DexFile::TypeList* Class::GetInterfaceTypeList() {
910f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  const DexFile::ClassDef* class_def = GetClassDef();
911f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  if (class_def == nullptr) {
912f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier    return nullptr;
913f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  }
914f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier  return GetDexFile().GetInterfacesList(*class_def);
915f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier}
916f832284dd847ff077577bb5712225430bbbb3b67Mathieu Chartier
917df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenkovoid Class::PopulateEmbeddedVTable(size_t pointer_size) {
918e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  PointerArray* table = GetVTableDuringLinking();
9192cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang  CHECK(table != nullptr) << PrettyClass(this);
920e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  const size_t table_length = table->GetLength();
921e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  SetEmbeddedVTableLength(table_length);
922e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (size_t i = 0; i < table_length; i++) {
923e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    SetEmbeddedVTableEntry(i, table->GetElementPtrSize<ArtMethod*>(i, pointer_size), pointer_size);
92498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  }
9252cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang  // Keep java.lang.Object class's vtable around for since it's easier
9262cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang  // to be reused by array classes during their linking.
9272cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang  if (!IsObjectClass()) {
9282cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang    SetVTable(nullptr);
9292cdbad7c62f126581ec5177104de961c4d71adaaMingyao Yang  }
93098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang}
93198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang
9323ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartierclass ReadBarrierOnNativeRootsVisitor {
9333ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier public:
9343ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier  void operator()(mirror::Object* obj ATTRIBUTE_UNUSED,
9353ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier                  MemberOffset offset ATTRIBUTE_UNUSED,
9363ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier                  bool is_static ATTRIBUTE_UNUSED) const {}
9373ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier
9383ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier  void VisitRootIfNonNull(mirror::CompressedReference<mirror::Object>* root) const
9393ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      SHARED_REQUIRES(Locks::mutator_lock_) {
9403ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    if (!root->IsNull()) {
9413ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      VisitRoot(root);
9423ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    }
9433ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier  }
9443ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier
9453ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier  void VisitRoot(mirror::CompressedReference<mirror::Object>* root) const
9463ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      SHARED_REQUIRES(Locks::mutator_lock_) {
9473ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    mirror::Object* old_ref = root->AsMirrorPtr();
9483ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    mirror::Object* new_ref = ReadBarrier::BarrierForRoot(root);
9493ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    if (old_ref != new_ref) {
9503ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      // Update the field atomically. This may fail if mutator updates before us, but it's ok.
9513ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      auto* atomic_root =
9523ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier          reinterpret_cast<Atomic<mirror::CompressedReference<mirror::Object>>*>(root);
9533ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier      atomic_root->CompareExchangeStrongSequentiallyConsistent(
9543ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier          mirror::CompressedReference<mirror::Object>::FromMirrorPtr(old_ref),
9553ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier          mirror::CompressedReference<mirror::Object>::FromMirrorPtr(new_ref));
9563ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    }
9573ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier  }
9583ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier};
9593ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier
9600fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi// The pre-fence visitor for Class::CopyOf().
9610fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchiclass CopyClassVisitor {
9620fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi public:
9633887c468d731420e929e6ad3acf190d5431e94fcRoland Levillain  CopyClassVisitor(Thread* self, Handle<mirror::Class>* orig, size_t new_length,
964df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenko                   size_t copy_bytes, ImTable* imt,
9653887c468d731420e929e6ad3acf190d5431e94fcRoland Levillain                   size_t pointer_size)
9660fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi      : self_(self), orig_(orig), new_length_(new_length),
967e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier        copy_bytes_(copy_bytes), imt_(imt), pointer_size_(pointer_size) {
9680fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  }
9690fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi
970e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  void operator()(mirror::Object* obj, size_t usable_size ATTRIBUTE_UNUSED) const
97190443477f9a0061581c420775ce3b7eeae7468bcMathieu Chartier      SHARED_REQUIRES(Locks::mutator_lock_) {
9725b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    StackHandleScope<1> hs(self_);
9735b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    Handle<mirror::Class> h_new_class_obj(hs.NewHandle(obj->AsClass()));
9745b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    mirror::Object::CopyObject(self_, h_new_class_obj.Get(), orig_->Get(), copy_bytes_);
9755b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    mirror::Class::SetStatus(h_new_class_obj, Class::kStatusResolving, self_);
976df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenko    h_new_class_obj->PopulateEmbeddedVTable(pointer_size_);
977df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenko    h_new_class_obj->SetImt(imt_, pointer_size_);
9785b783e66b26b7b6ee13d344f4b77f6b7c47c4723Hiroshi Yamauchi    h_new_class_obj->SetClassSize(new_length_);
9793ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    // Visit all of the references to make sure there is no from space references in the native
9803ee25bb1df3df4f57c6a4c7d3957dd7303aa00d7Mathieu Chartier    // roots.
981059ef3ddb2088f926ac452889e0953fdcd646a5eMathieu Chartier    static_cast<mirror::Object*>(h_new_class_obj.Get())->VisitReferences(
982059ef3ddb2088f926ac452889e0953fdcd646a5eMathieu Chartier        ReadBarrierOnNativeRootsVisitor(), VoidFunctor());
9830fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  }
9840fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi
9850fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi private:
9860fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  Thread* const self_;
9870fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  Handle<mirror::Class>* const orig_;
9880fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  const size_t new_length_;
9890fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  const size_t copy_bytes_;
990df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenko  ImTable* imt_;
991e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  const size_t pointer_size_;
9920fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  DISALLOW_COPY_AND_ASSIGN(CopyClassVisitor);
9930fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi};
9940fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi
9952d2621a1463d2f3f03fa73503fa42e43657cdcfcMathieu ChartierClass* Class::CopyOf(Thread* self, int32_t new_length,
996df2d4f22d5e89692c90b443da82fe2930518418bArtem Udovichenko                     ImTable* imt, size_t pointer_size) {
99798d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  DCHECK_GE(new_length, static_cast<int32_t>(sizeof(Class)));
99898d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  // We may get copied by a compacting GC.
99998d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  StackHandleScope<1> hs(self);
100098d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  Handle<mirror::Class> h_this(hs.NewHandle(this));
100198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  gc::Heap* heap = Runtime::Current()->GetHeap();
10020fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  // The num_bytes (3rd param) is sizeof(Class) as opposed to SizeOf()
10030fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  // to skip copying the tail part that we will overwrite here.
1004e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  CopyClassVisitor visitor(self, &h_this, new_length, sizeof(Class), imt, pointer_size);
1005e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  mirror::Object* new_class = kMovingClasses ?
1006e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      heap->AllocObject<true>(self, java_lang_Class_.Read(), new_length, visitor) :
1007e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      heap->AllocNonMovableObject<true>(self, java_lang_Class_.Read(), new_length, visitor);
100898d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  if (UNLIKELY(new_class == nullptr)) {
1009e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    self->AssertPendingOOMException();
10102d2621a1463d2f3f03fa73503fa42e43657cdcfcMathieu Chartier    return nullptr;
101198d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang  }
10120fbd6e6ec3241b7163b95f9f001bfe9b08f8b200Hiroshi Yamauchi  return new_class->AsClass();
101398d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang}
101498d1cc8033251c93786e2fa8c59a2e555a9493beMingyao Yang
10153a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffraybool Class::ProxyDescriptorEquals(const char* match) {
10163a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray  DCHECK(IsProxyClass());
10173a0909248e04b22c3981cbf617bc2502ed5b6380Nicolas Geoffray  return Runtime::Current()->GetClassLinker()->GetDescriptorForProxy(this) == match;
10183481ba2c4e4f3aa80d8c6d50a9f85dacb56b508bVladimir Marko}
10193481ba2c4e4f3aa80d8c6d50a9f85dacb56b508bVladimir Marko
1020e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier// TODO: Move this to java_lang_Class.cc?
1021e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu ChartierArtMethod* Class::GetDeclaredConstructor(
1022f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    Thread* self, Handle<mirror::ObjectArray<mirror::Class>> args, size_t pointer_size) {
1023f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe  for (auto& m : GetDirectMethods(pointer_size)) {
1024fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier    // Skip <clinit> which is a static constructor, as well as non constructors.
1025e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (m.IsStatic() || !m.IsConstructor()) {
1026fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier      continue;
1027fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier    }
1028fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier    // May cause thread suspension and exceptions.
1029e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (m.GetInterfaceMethodIfProxy(sizeof(void*))->EqualParameters(args)) {
1030e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier      return &m;
1031fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier    }
1032e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    if (UNLIKELY(self->IsExceptionPending())) {
1033fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier      return nullptr;
1034fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier    }
1035fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier  }
1036fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier  return nullptr;
1037fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier}
1038fc58af45e342ba9e18bbdf597f205a58ec731658Mathieu Chartier
1039e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartieruint32_t Class::Depth() {
1040e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  uint32_t depth = 0;
1041e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  for (Class* klass = this; klass->GetSuperClass() != nullptr; klass = klass->GetSuperClass()) {
1042e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier    depth++;
1043e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  }
1044e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier  return depth;
1045e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier}
1046e401d146407d61eeb99f8d6176b2ac13c4df1e33Mathieu Chartier
1047e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffrayuint32_t Class::FindTypeIndexInOtherDexFile(const DexFile& dex_file) {
1048e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffray  std::string temp;
1049e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffray  const DexFile::TypeId* type_id = dex_file.FindTypeId(GetDescriptor(&temp));
1050e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffray  return (type_id == nullptr) ? DexFile::kDexNoIndex : dex_file.GetIndexForTypeId(*type_id);
1051e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffray}
1052e4084a5eb46dc6b99c0e0b74bcdecccaceb28fe7Nicolas Geoffray
1053bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampetemplate <bool kTransactionActive>
1054bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampemirror::Method* Class::GetDeclaredMethodInternal(Thread* self,
1055bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                 mirror::Class* klass,
1056bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                 mirror::String* name,
1057bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                 mirror::ObjectArray<mirror::Class>* args) {
1058bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // Covariant return types permit the class to define multiple
1059bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // methods with the same name and parameter types. Prefer to
1060bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // return a non-synthetic method in such situations. We may
1061bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // still return a synthetic method to handle situations like
1062bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // escalated visibility. We never return miranda methods that
1063bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  // were synthesized by the runtime.
1064bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  constexpr uint32_t kSkipModifiers = kAccMiranda | kAccSynthetic;
1065bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  StackHandleScope<3> hs(self);
1066bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  auto h_method_name = hs.NewHandle(name);
1067bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  if (UNLIKELY(h_method_name.Get() == nullptr)) {
1068bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    ThrowNullPointerException("name == null");
1069bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    return nullptr;
1070bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  }
1071bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  auto h_args = hs.NewHandle(args);
1072bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  Handle<mirror::Class> h_klass = hs.NewHandle(klass);
1073bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  ArtMethod* result = nullptr;
1074bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  const size_t pointer_size = kTransactionActive
1075bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                  ? Runtime::Current()->GetClassLinker()->GetImagePointerSize()
1076bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                  : sizeof(void*);
1077bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  for (auto& m : h_klass->GetDeclaredVirtualMethods(pointer_size)) {
1078bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    auto* np_method = m.GetInterfaceMethodIfProxy(pointer_size);
1079bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    // May cause thread suspension.
1080bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    mirror::String* np_name = np_method->GetNameAsString(self);
1081bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1082bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      if (UNLIKELY(self->IsExceptionPending())) {
1083bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        return nullptr;
1084bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      }
1085bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      continue;
1086bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    }
1087bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    auto modifiers = m.GetAccessFlags();
1088bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    if ((modifiers & kSkipModifiers) == 0) {
1089bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      return mirror::Method::CreateFromArtMethod<kTransactionActive>(self, &m);
1090bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    }
1091bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    if ((modifiers & kAccMiranda) == 0) {
1092bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      result = &m;  // Remember as potential result if it's not a miranda method.
1093bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    }
1094bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  }
1095bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  if (result == nullptr) {
1096bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    for (auto& m : h_klass->GetDirectMethods(pointer_size)) {
1097bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      auto modifiers = m.GetAccessFlags();
1098bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      if ((modifiers & kAccConstructor) != 0) {
1099bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        continue;
1100bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      }
1101bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      auto* np_method = m.GetInterfaceMethodIfProxy(pointer_size);
1102bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      // May cause thread suspension.
1103bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      mirror::String* np_name = np_method->GetNameAsString(self);
1104bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      if (np_name == nullptr) {
1105bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        self->AssertPendingException();
1106bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        return nullptr;
1107bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      }
1108bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      if (!np_name->Equals(h_method_name.Get()) || !np_method->EqualParameters(h_args)) {
1109bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        if (UNLIKELY(self->IsExceptionPending())) {
1110bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe          return nullptr;
1111bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        }
1112bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        continue;
1113bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      }
1114bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      if ((modifiers & kSkipModifiers) == 0) {
1115bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe        return mirror::Method::CreateFromArtMethod<kTransactionActive>(self, &m);
1116bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      }
1117bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      // Direct methods cannot be miranda methods, so this potential result must be synthetic.
1118bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      result = &m;
1119bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe    }
1120bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  }
1121bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe  return result != nullptr
1122bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      ? mirror::Method::CreateFromArtMethod<kTransactionActive>(self, result)
1123bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe      : nullptr;
1124bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe}
1125bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe
1126bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampetemplate
1127bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampemirror::Method* Class::GetDeclaredMethodInternal<false>(Thread* self,
1128bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                        mirror::Class* klass,
1129bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                        mirror::String* name,
1130bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                        mirror::ObjectArray<mirror::Class>* args);
1131bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampetemplate
1132bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampemirror::Method* Class::GetDeclaredMethodInternal<true>(Thread* self,
1133bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                       mirror::Class* klass,
1134bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                       mirror::String* name,
1135bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe                                                       mirror::ObjectArray<mirror::Class>* args);
1136bc4d218ce2ceef0c4f308d4ff42f7ec1ec43c40eAndreas Gampe
1137f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampetemplate <bool kTransactionActive>
1138f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampemirror::Constructor* Class::GetDeclaredConstructorInternal(
1139f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    Thread* self,
1140f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::Class* klass,
1141f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::ObjectArray<mirror::Class>* args) {
1142f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe  StackHandleScope<1> hs(self);
1143f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe  const size_t pointer_size = kTransactionActive
1144f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe                                  ? Runtime::Current()->GetClassLinker()->GetImagePointerSize()
1145f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe                                  : sizeof(void*);
1146f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe  ArtMethod* result = klass->GetDeclaredConstructor(self, hs.NewHandle(args), pointer_size);
1147f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe  return result != nullptr
1148f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe      ? mirror::Constructor::CreateFromArtMethod<kTransactionActive>(self, result)
1149f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe      : nullptr;
1150f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe}
1151f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe
1152f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe// mirror::Constructor::CreateFromArtMethod<kTransactionActive>(self, result)
1153f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe
1154f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampetemplate mirror::Constructor* Class::GetDeclaredConstructorInternal<false>(
1155f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    Thread* self,
1156f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::Class* klass,
1157f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::ObjectArray<mirror::Class>* args);
1158f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampetemplate mirror::Constructor* Class::GetDeclaredConstructorInternal<true>(
1159f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    Thread* self,
1160f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::Class* klass,
1161f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe    mirror::ObjectArray<mirror::Class>* args);
1162f72f19fac0016499d33fd75b0463d0128a58a9f4Andreas Gampe
1163b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampeint32_t Class::GetInnerClassFlags(Handle<Class> h_this, int32_t default_value) {
1164b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  if (h_this->IsProxyClass() || h_this->GetDexCache() == nullptr) {
1165b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe    return default_value;
1166b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  }
1167b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  uint32_t flags;
1168b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  if (!h_this->GetDexFile().GetInnerClassFlags(h_this, &flags)) {
1169b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe    return default_value;
1170b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  }
1171b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe  return flags;
1172b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe}
1173b3ffbe32b78c18739736fc998d65430b46c510e5Andreas Gampe
11742dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}  // namespace mirror
11752dd0e2cea360bc9206eb88ecc40d259e796c239dIan Rogers}  // namespace art
1176