blob: 64faf76213274702f33963301d268831fc5e0160 [file] [log] [blame]
Ian Rogers848871b2013-08-05 10:56:33 -07001/*
2 * Copyright (C) 2012 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "class_linker.h"
18#include "interpreter/interpreter.h"
Brian Carlstromea46f952013-07-30 01:26:50 -070019#include "mirror/art_method-inl.h"
Ian Rogers848871b2013-08-05 10:56:33 -070020#include "mirror/object-inl.h"
Ian Rogers53b8b092014-03-13 23:45:53 -070021#include "reflection.h"
Ian Rogers848871b2013-08-05 10:56:33 -070022#include "runtime.h"
23#include "stack.h"
24
25namespace art {
26
Mathieu Chartier0cd81352014-05-22 16:48:55 -070027// TODO: Make the MethodHelper here be compaction safe.
Dragos Sbirlea08bf1962013-08-12 08:53:04 -070028extern "C" void artInterpreterToCompiledCodeBridge(Thread* self, MethodHelper& mh,
Ian Rogers848871b2013-08-05 10:56:33 -070029 const DexFile::CodeItem* code_item,
Ian Rogers0f40ac32013-08-13 22:10:30 -070030 ShadowFrame* shadow_frame, JValue* result) {
Brian Carlstromea46f952013-07-30 01:26:50 -070031 mirror::ArtMethod* method = shadow_frame->GetMethod();
Ian Rogers848871b2013-08-05 10:56:33 -070032 // Ensure static methods are initialized.
33 if (method->IsStatic()) {
Sebastien Hertzc61124b2013-09-10 11:44:19 +020034 mirror::Class* declaringClass = method->GetDeclaringClass();
Ian Rogers6c5cb212014-06-18 16:07:20 -070035 if (UNLIKELY(!declaringClass->IsInitialized())) {
Mathieu Chartierf043de42013-12-10 14:37:16 -080036 self->PushShadowFrame(shadow_frame);
Mathieu Chartiereb8167a2014-05-07 15:43:14 -070037 StackHandleScope<1> hs(self);
38 Handle<mirror::Class> h_class(hs.NewHandle(declaringClass));
39 if (UNLIKELY(!Runtime::Current()->GetClassLinker()->EnsureInitialized(h_class, true, true))) {
Mathieu Chartierf043de42013-12-10 14:37:16 -080040 self->PopShadowFrame();
41 DCHECK(self->IsExceptionPending());
Sebastien Hertzc61124b2013-09-10 11:44:19 +020042 return;
43 }
Mathieu Chartierf043de42013-12-10 14:37:16 -080044 self->PopShadowFrame();
Mathieu Chartiereb8167a2014-05-07 15:43:14 -070045 CHECK(h_class->IsInitializing());
Mathieu Chartier0cd81352014-05-22 16:48:55 -070046 // Reload from shadow frame in case the method moved, this is faster than adding a handle.
47 method = shadow_frame->GetMethod();
Sebastien Hertzc61124b2013-09-10 11:44:19 +020048 }
Ian Rogers848871b2013-08-05 10:56:33 -070049 }
50 uint16_t arg_offset = (code_item == NULL) ? 0 : code_item->registers_size_ - code_item->ins_size_;
Ian Rogersef7d42f2014-01-06 12:55:46 -080051 if (kUsePortableCompiler) {
Ian Rogers53b8b092014-03-13 23:45:53 -070052 InvokeWithShadowFrame(self, shadow_frame, arg_offset, mh, result);
Ian Rogersef7d42f2014-01-06 12:55:46 -080053 } else {
54 method->Invoke(self, shadow_frame->GetVRegArgs(arg_offset),
55 (shadow_frame->NumberOfVRegs() - arg_offset) * sizeof(uint32_t),
Ian Rogers0177e532014-02-11 16:30:46 -080056 result, mh.GetShorty());
Ian Rogersef7d42f2014-01-06 12:55:46 -080057 }
Ian Rogers848871b2013-08-05 10:56:33 -070058}
59
60} // namespace art