xref: /aosp_15_r20/art/libdexfile/dex/modifiers.h (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
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