Home | History | Annotate | Download | only in interp
      1 /*
      2  * Copyright (C) 2008 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  * Dalvik interpreter definitions.  These are internal to the interpreter.
     18  *
     19  * This includes defines, types, function declarations, and inline functions
     20  * that are common to all interpreter implementations.
     21  *
     22  * Functions and globals declared here are defined in Interp.c.
     23  */
     24 #ifndef DALVIK_INTERP_DEFS_H_
     25 #define DALVIK_INTERP_DEFS_H_
     26 
     27 #if defined(WITH_JIT)
     28 /*
     29  * Size of save area for callee-save FP regs, which are not automatically
     30  * saved by interpreter main because it doesn't use them (but Jit'd code
     31  * may). Save/restore routine is defined by target, and size should
     32  * be >= max needed by any target.
     33  */
     34 #define JIT_CALLEE_SAVE_DOUBLE_COUNT 8
     35 
     36 #endif
     37 
     38 /*
     39  * Portable interpreter.
     40  */
     41 extern void dvmInterpretPortable(Thread* self);
     42 
     43 /*
     44  * "mterp" interpreter.
     45  */
     46 extern void dvmMterpStd(Thread* self);
     47 
     48 /*
     49  * Get the "this" pointer from the current frame.
     50  */
     51 Object* dvmGetThisPtr(const Method* method, const u4* fp);
     52 
     53 /*
     54  * Verify that our tracked local references are valid.
     55  */
     56 void dvmInterpCheckTrackedRefs(Thread* self, const Method* method,
     57     int debugTrackedRefStart);
     58 
     59 /*
     60  * Process switch statement.
     61  */
     62 extern "C" s4 dvmInterpHandlePackedSwitch(const u2* switchData, s4 testVal);
     63 extern "C" s4 dvmInterpHandleSparseSwitch(const u2* switchData, s4 testVal);
     64 
     65 /*
     66  * Process fill-array-data.
     67  */
     68 extern "C" bool dvmInterpHandleFillArrayData(ArrayObject* arrayObject,
     69                                   const u2* arrayData);
     70 
     71 /*
     72  * Find an interface method.
     73  */
     74 Method* dvmInterpFindInterfaceMethod(ClassObject* thisClass, u4 methodIdx,
     75     const Method* method, DvmDex* methodClassDex);
     76 
     77 /*
     78  * Determine if the debugger or profiler is currently active.
     79  */
     80 static inline bool dvmDebuggerOrProfilerActive()
     81 {
     82     return gDvm.debuggerActive || gDvm.activeProfilers != 0;
     83 }
     84 
     85 #if defined(WITH_JIT)
     86 /*
     87  * Determine if the jit, debugger or profiler is currently active.  Used when
     88  * selecting which interpreter to switch to.
     89  */
     90 static inline bool dvmJitDebuggerOrProfilerActive()
     91 {
     92     return (gDvmJit.pProfTable != NULL) || dvmDebuggerOrProfilerActive();
     93 }
     94 
     95 /*
     96  * Hide the translations and stick with the interpreter as long as one of the
     97  * following conditions is true.
     98  */
     99 static inline bool dvmJitHideTranslation()
    100 {
    101     return (gDvm.sumThreadSuspendCount != 0) ||
    102            (gDvmJit.codeCacheFull == true) ||
    103            (gDvmJit.pProfTable == NULL);
    104 }
    105 
    106 #endif
    107 
    108 /*
    109  * Construct an s4 from two consecutive half-words of switch data.
    110  * This needs to check endianness because the DEX optimizer only swaps
    111  * half-words in instruction stream.
    112  *
    113  * "switchData" must be 32-bit aligned.
    114  */
    115 #if __BYTE_ORDER == __LITTLE_ENDIAN
    116 static inline s4 s4FromSwitchData(const void* switchData) {
    117     return *(s4*) switchData;
    118 }
    119 #else
    120 static inline s4 s4FromSwitchData(const void* switchData) {
    121     u2* data = switchData;
    122     return data[0] | (((s4) data[1]) << 16);
    123 }
    124 #endif
    125 
    126 #endif  // DALVIK_INTERP_DEFS_H_
    127