1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2012 The Android Open Source Project 3*795d594fSAndroid Build Coastguard Worker * 4*795d594fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*795d594fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*795d594fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*795d594fSAndroid Build Coastguard Worker * 8*795d594fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*795d594fSAndroid Build Coastguard Worker * 10*795d594fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*795d594fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*795d594fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*795d594fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*795d594fSAndroid Build Coastguard Worker * limitations under the License. 15*795d594fSAndroid Build Coastguard Worker */ 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Worker #ifndef ART_LIBDEXFILE_DEX_MODIFIERS_H_ 18*795d594fSAndroid Build Coastguard Worker #define ART_LIBDEXFILE_DEX_MODIFIERS_H_ 19*795d594fSAndroid Build Coastguard Worker 20*795d594fSAndroid Build Coastguard Worker #include <string> 21*795d594fSAndroid Build Coastguard Worker 22*795d594fSAndroid Build Coastguard Worker #include <stdint.h> 23*795d594fSAndroid Build Coastguard Worker 24*795d594fSAndroid Build Coastguard Worker namespace art { 25*795d594fSAndroid Build Coastguard Worker 26*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccPublic = 0x0001; // class, field, method, ic 27*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccPrivate = 0x0002; // field, method, ic 28*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccProtected = 0x0004; // field, method, ic 29*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccStatic = 0x0008; // field, method, ic 30*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccFinal = 0x0010; // class, field, method, ic 31*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSynchronized = 0x0020; // method (only allowed on natives) 32*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSuper = 0x0020; // class (not used in dex) 33*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccVolatile = 0x0040; // field 34*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccBridge = 0x0040; // method (1.5) 35*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccTransient = 0x0080; // field 36*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccVarargs = 0x0080; // method (1.5) 37*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccNative = 0x0100; // method 38*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccInterface = 0x0200; // class, ic 39*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccAbstract = 0x0400; // class, method, ic 40*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccStrict = 0x0800; // method 41*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSynthetic = 0x1000; // class, field, method, ic 42*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccAnnotation = 0x2000; // class, ic (1.5) 43*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccEnum = 0x4000; // class, field, ic (1.5) 44*795d594fSAndroid Build Coastguard Worker 45*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccJavaFlagsMask = 0xffff; // bits set from Java sources (low 16) 46*795d594fSAndroid Build Coastguard Worker 47*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccConstructor = 0x00010000; // method (dex only) <(cl)init> 48*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccDeclaredSynchronized = 0x00020000; // method (dex only) 49*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccClassIsProxy = 0x00040000; // class (dex only) 50*795d594fSAndroid Build Coastguard Worker // Set to indicate that the ArtMethod is obsolete and has a different DexCache + DexFile from its 51*795d594fSAndroid Build Coastguard Worker // declaring class. This flag may only be applied to methods. 52*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccObsoleteMethod = 0x00040000; // method (runtime) 53*795d594fSAndroid Build Coastguard Worker // Used by a method to denote that its execution does not need to go through slow path interpreter. 54*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSkipAccessChecks = 0x00080000; // method (runtime, not native) 55*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSkipHiddenapiChecks = 0x00100000; // class (runtime) 56*795d594fSAndroid Build Coastguard Worker // Used by a class to denote that this class and any objects with this as a 57*795d594fSAndroid Build Coastguard Worker // declaring-class/super-class are to be considered obsolete, meaning they should not be used by. 58*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccObsoleteObject = 0x00200000; // class (runtime) 59*795d594fSAndroid Build Coastguard Worker // Set during boot image compilation to indicate that the class is 60*795d594fSAndroid Build Coastguard Worker // not initialized at compile time and not in the list of preloaded classes. 61*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccInBootImageAndNotInPreloadedClasses = 0x00400000; // class (runtime) 62*795d594fSAndroid Build Coastguard Worker // This is set by the class linker during LinkInterfaceMethods. It is used by a method 63*795d594fSAndroid Build Coastguard Worker // to represent that it was copied from its declaring class into another class. 64*795d594fSAndroid Build Coastguard Worker // We need copies of the original method because the method may end up in different 65*795d594fSAndroid Build Coastguard Worker // places in classes vtables, and the vtable index is set in ArtMethod.method_index. 66*795d594fSAndroid Build Coastguard Worker // 67*795d594fSAndroid Build Coastguard Worker // Default methods copied to a sub-interface or a concrete class shall have this bit set. 68*795d594fSAndroid Build Coastguard Worker // Default conflict methods shall be marked as copied, abstract and default. 69*795d594fSAndroid Build Coastguard Worker // Miranda methods shall be marked as copied and abstract but not default. 70*795d594fSAndroid Build Coastguard Worker // 71*795d594fSAndroid Build Coastguard Worker // We do not have intrinsics for any default methods and therefore intrinsics are never 72*795d594fSAndroid Build Coastguard Worker // copied. We can therefore use a flag from the intrinsic flags range. 73*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccCopied = 0x01000000; // method (runtime) 74*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccDefault = 0x00400000; // method (runtime) 75*795d594fSAndroid Build Coastguard Worker // Native method flags are set when linking the methods based on the presence of the 76*795d594fSAndroid Build Coastguard Worker // @dalvik.annotation.optimization.{Fast,Critical}Native annotations with build visibility. 77*795d594fSAndroid Build Coastguard Worker // Reuse the values of kAccSkipAccessChecks and kAccNterpEntryPointFastPathFlag which are not used 78*795d594fSAndroid Build Coastguard Worker // for native methods. 79*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccFastNative = 0x00080000; // method (runtime; native only) 80*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccCriticalNative = 0x00100000; // method (runtime; native only) 81*795d594fSAndroid Build Coastguard Worker 82*795d594fSAndroid Build Coastguard Worker // Set by the JIT when clearing profiling infos to denote that a method was previously warm. 83*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccPreviouslyWarm = 0x00800000; // method (runtime) 84*795d594fSAndroid Build Coastguard Worker 85*795d594fSAndroid Build Coastguard Worker // Set by the verifier for a method we do not want the compiler to compile. 86*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccCompileDontBother = 0x02000000; // method (runtime) 87*795d594fSAndroid Build Coastguard Worker 88*795d594fSAndroid Build Coastguard Worker // Used in conjunction with kAccCompileDontBother to mark the method as pre compiled 89*795d594fSAndroid Build Coastguard Worker // by the JIT compiler. We are reusing the value of the kAccPreviouslyWarm flag which 90*795d594fSAndroid Build Coastguard Worker // is meaningless for other methods with kAccCompileDontBother as we do not collect 91*795d594fSAndroid Build Coastguard Worker // samples for such methods. 92*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccPreCompiled = 0x00800000; // method (runtime) 93*795d594fSAndroid Build Coastguard Worker static_assert(kAccPreCompiled == kAccPreviouslyWarm); 94*795d594fSAndroid Build Coastguard Worker 95*795d594fSAndroid Build Coastguard Worker // Set by the verifier for a method that could not be verified to follow structured locking. 96*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccMustCountLocks = 0x04000000; // method (runtime) 97*795d594fSAndroid Build Coastguard Worker 98*795d594fSAndroid Build Coastguard Worker // Set by the class linker for a method that has only one implementation for a 99*795d594fSAndroid Build Coastguard Worker // virtual call. 100*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccSingleImplementation = 0x08000000; // method (runtime) 101*795d594fSAndroid Build Coastguard Worker 102*795d594fSAndroid Build Coastguard Worker // Whether nterp can take a fast path when entering this method (runtime; non-native) 103*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccNterpEntryPointFastPathFlag = 0x00100000; 104*795d594fSAndroid Build Coastguard Worker // Set by the class linker to mark that a method does not have floating points 105*795d594fSAndroid Build Coastguard Worker // or longs in its shorty. On RISC-V 64, a method that has only reference args. 106*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccNterpInvokeFastPathFlag = 0x00200000; // method (runtime) 107*795d594fSAndroid Build Coastguard Worker 108*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccPublicApi = 0x10000000; // field, method 109*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccCorePlatformApi = 0x20000000; // field, method 110*795d594fSAndroid Build Coastguard Worker 111*795d594fSAndroid Build Coastguard Worker // For methods which we'd like to share memory between zygote and apps. 112*795d594fSAndroid Build Coastguard Worker // Uses an intrinsic bit but that's OK as intrinsics are always in the boot image. 113*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccMemorySharedMethod = 0x40000000; 114*795d594fSAndroid Build Coastguard Worker 115*795d594fSAndroid Build Coastguard Worker // Set by the compiler driver when compiling boot classes with intrinsic methods. 116*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccIntrinsic = 0x80000000; // method (runtime) 117*795d594fSAndroid Build Coastguard Worker 118*795d594fSAndroid Build Coastguard Worker // Special runtime-only flags. 119*795d594fSAndroid Build Coastguard Worker // Interface and all its super-interfaces with default methods have been recursively initialized. 120*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccRecursivelyInitialized = 0x20000000; 121*795d594fSAndroid Build Coastguard Worker // Interface declares some default method. 122*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccHasDefaultMethod = 0x40000000; 123*795d594fSAndroid Build Coastguard Worker // class/ancestor overrides finalize() 124*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccClassIsFinalizable = 0x80000000; 125*795d594fSAndroid Build Coastguard Worker 126*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccHiddenapiBits = kAccPublicApi | kAccCorePlatformApi; 127*795d594fSAndroid Build Coastguard Worker 128*795d594fSAndroid Build Coastguard Worker // Continuous sequence of bits used to hold the ordinal of an intrinsic method. Flags 129*795d594fSAndroid Build Coastguard Worker // which overlap are not valid when kAccIntrinsic is set. 130*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccIntrinsicBits = kAccHiddenapiBits | 131*795d594fSAndroid Build Coastguard Worker kAccSingleImplementation | kAccMustCountLocks | kAccCompileDontBother | kAccCopied | 132*795d594fSAndroid Build Coastguard Worker kAccPreviouslyWarm | kAccMemorySharedMethod | kAccDefault; 133*795d594fSAndroid Build Coastguard Worker 134*795d594fSAndroid Build Coastguard Worker // Valid (meaningful) bits for a field. 135*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccValidFieldFlags = kAccPublic | kAccPrivate | kAccProtected | 136*795d594fSAndroid Build Coastguard Worker kAccStatic | kAccFinal | kAccVolatile | kAccTransient | kAccSynthetic | kAccEnum; 137*795d594fSAndroid Build Coastguard Worker 138*795d594fSAndroid Build Coastguard Worker // Valid (meaningful) bits for a method. 139*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccValidMethodFlags = kAccPublic | kAccPrivate | kAccProtected | 140*795d594fSAndroid Build Coastguard Worker kAccStatic | kAccFinal | kAccSynchronized | kAccBridge | kAccVarargs | kAccNative | 141*795d594fSAndroid Build Coastguard Worker kAccAbstract | kAccStrict | kAccSynthetic | kAccConstructor | kAccDeclaredSynchronized; 142*795d594fSAndroid Build Coastguard Worker static_assert(((kAccIntrinsic | kAccIntrinsicBits) & kAccValidMethodFlags) == 0, 143*795d594fSAndroid Build Coastguard Worker "Intrinsic bits and valid dex file method access flags must not overlap."); 144*795d594fSAndroid Build Coastguard Worker 145*795d594fSAndroid Build Coastguard Worker // Valid (meaningful) bits for a class (not interface). 146*795d594fSAndroid Build Coastguard Worker // Note 1. These are positive bits. Other bits may have to be zero. 147*795d594fSAndroid Build Coastguard Worker // Note 2. Inner classes can expose more access flags to Java programs. That is handled by libcore. 148*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccValidClassFlags = kAccPublic | kAccFinal | kAccSuper | 149*795d594fSAndroid Build Coastguard Worker kAccAbstract | kAccSynthetic | kAccEnum; 150*795d594fSAndroid Build Coastguard Worker 151*795d594fSAndroid Build Coastguard Worker // Valid (meaningful) bits for an interface. 152*795d594fSAndroid Build Coastguard Worker // Note 1. Annotations are interfaces. 153*795d594fSAndroid Build Coastguard Worker // Note 2. These are positive bits. Other bits may have to be zero. 154*795d594fSAndroid Build Coastguard Worker // Note 3. Inner classes can expose more access flags to Java programs. That is handled by libcore. 155*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccValidInterfaceFlags = kAccPublic | kAccInterface | 156*795d594fSAndroid Build Coastguard Worker kAccAbstract | kAccSynthetic | kAccAnnotation; 157*795d594fSAndroid Build Coastguard Worker 158*795d594fSAndroid Build Coastguard Worker static constexpr uint32_t kAccVisibilityFlags = kAccPublic | kAccPrivate | kAccProtected; 159*795d594fSAndroid Build Coastguard Worker 160*795d594fSAndroid Build Coastguard Worker // Returns a human-readable version of the Java part of the access flags, e.g., "private static " 161*795d594fSAndroid Build Coastguard Worker // (note the trailing whitespace). 162*795d594fSAndroid Build Coastguard Worker std::string PrettyJavaAccessFlags(uint32_t access_flags); 163*795d594fSAndroid Build Coastguard Worker 164*795d594fSAndroid Build Coastguard Worker } // namespace art 165*795d594fSAndroid Build Coastguard Worker 166*795d594fSAndroid Build Coastguard Worker #endif // ART_LIBDEXFILE_DEX_MODIFIERS_H_ 167*795d594fSAndroid Build Coastguard Worker 168