diff options
Diffstat (limited to 'runtime/class_linker.cc')
-rw-r--r-- | runtime/class_linker.cc | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/runtime/class_linker.cc b/runtime/class_linker.cc index 3e8dc23c20..5599c212c1 100644 --- a/runtime/class_linker.cc +++ b/runtime/class_linker.cc @@ -3501,19 +3501,14 @@ mirror::ArtMethod* ClassLinker::CreateProxyConstructor(Thread* self, proxy_class->GetDirectMethods(); CHECK_EQ(proxy_direct_methods->GetLength(), 16); mirror::ArtMethod* proxy_constructor = proxy_direct_methods->Get(2); - mirror::ArtMethod* constructor = down_cast<mirror::ArtMethod*>(proxy_constructor->Clone(self)); - if (constructor == nullptr) { + // Clone the existing constructor of Proxy (our constructor would just invoke it so steal its + // code_ too) + mirror::ArtMethod* constructor = + down_cast<mirror::ArtMethod*>(proxy_constructor->Clone(self)); + if (constructor == NULL) { CHECK(self->IsExceptionPending()); // OOME. - return nullptr; + return NULL; } - // Make the proxy constructor's code always point to the uninstrumented code. This avoids - // getting a method enter event for the proxy constructor as the proxy constructor doesn't - // have an activation. - bool have_portable_code; - constructor->SetEntryPointFromQuickCompiledCode(GetQuickOatCodeFor(proxy_constructor)); - constructor->SetEntryPointFromPortableCompiledCode(GetPortableOatCodeFor(proxy_constructor, - &have_portable_code)); - // Make this constructor public and fix the class to be our Proxy version constructor->SetAccessFlags((constructor->GetAccessFlags() & ~kAccProtected) | kAccPublic); constructor->SetDeclaringClass(klass.Get()); |