1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2024 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 import java.lang.invoke.MethodHandle; 18*795d594fSAndroid Build Coastguard Worker 19*795d594fSAndroid Build Coastguard Worker import annotations.ConstantMethodHandle; 20*795d594fSAndroid Build Coastguard Worker 21*795d594fSAndroid Build Coastguard Worker public class InvokeSpecial { 22*795d594fSAndroid Build Coastguard Worker 23*795d594fSAndroid Build Coastguard Worker private int instanceField; 24*795d594fSAndroid Build Coastguard Worker unreachable()25*795d594fSAndroid Build Coastguard Worker private static void unreachable() { 26*795d594fSAndroid Build Coastguard Worker throw new AssertionError("unreachable!"); 27*795d594fSAndroid Build Coastguard Worker } 28*795d594fSAndroid Build Coastguard Worker method()29*795d594fSAndroid Build Coastguard Worker public void method() {} 30*795d594fSAndroid Build Coastguard Worker 31*795d594fSAndroid Build Coastguard Worker @ConstantMethodHandle( 32*795d594fSAndroid Build Coastguard Worker kind = ConstantMethodHandle.INVOKE_SPECIAL, 33*795d594fSAndroid Build Coastguard Worker owner = "InvokeSpecial", 34*795d594fSAndroid Build Coastguard Worker fieldOrMethodName = "unreachable", 35*795d594fSAndroid Build Coastguard Worker descriptor = "()V") forStaticMethod()36*795d594fSAndroid Build Coastguard Worker private static MethodHandle forStaticMethod() { 37*795d594fSAndroid Build Coastguard Worker unreachable(); 38*795d594fSAndroid Build Coastguard Worker return null; 39*795d594fSAndroid Build Coastguard Worker } 40*795d594fSAndroid Build Coastguard Worker 41*795d594fSAndroid Build Coastguard Worker @ConstantMethodHandle( 42*795d594fSAndroid Build Coastguard Worker kind = ConstantMethodHandle.INVOKE_SPECIAL, 43*795d594fSAndroid Build Coastguard Worker owner = "java/util/List", 44*795d594fSAndroid Build Coastguard Worker fieldOrMethodName = "size", 45*795d594fSAndroid Build Coastguard Worker descriptor = "()I") forInterfaceMethod()46*795d594fSAndroid Build Coastguard Worker private static MethodHandle forInterfaceMethod() { 47*795d594fSAndroid Build Coastguard Worker unreachable(); 48*795d594fSAndroid Build Coastguard Worker return null; 49*795d594fSAndroid Build Coastguard Worker } 50*795d594fSAndroid Build Coastguard Worker 51*795d594fSAndroid Build Coastguard Worker @ConstantMethodHandle( 52*795d594fSAndroid Build Coastguard Worker kind = ConstantMethodHandle.INVOKE_SPECIAL, 53*795d594fSAndroid Build Coastguard Worker owner = "Main", 54*795d594fSAndroid Build Coastguard Worker fieldOrMethodName = "instanceMethod", 55*795d594fSAndroid Build Coastguard Worker descriptor = "()V") inaccessiblePrivateMethod()56*795d594fSAndroid Build Coastguard Worker private static MethodHandle inaccessiblePrivateMethod() { 57*795d594fSAndroid Build Coastguard Worker unreachable(); 58*795d594fSAndroid Build Coastguard Worker return null; 59*795d594fSAndroid Build Coastguard Worker } 60*795d594fSAndroid Build Coastguard Worker 61*795d594fSAndroid Build Coastguard Worker @ConstantMethodHandle( 62*795d594fSAndroid Build Coastguard Worker kind = ConstantMethodHandle.INVOKE_SPECIAL, 63*795d594fSAndroid Build Coastguard Worker owner = "Main", 64*795d594fSAndroid Build Coastguard Worker fieldOrMethodName = "staticMethod", 65*795d594fSAndroid Build Coastguard Worker descriptor = "()V") inaccessibleStaticMethod()66*795d594fSAndroid Build Coastguard Worker private static MethodHandle inaccessibleStaticMethod() { 67*795d594fSAndroid Build Coastguard Worker unreachable(); 68*795d594fSAndroid Build Coastguard Worker return null; 69*795d594fSAndroid Build Coastguard Worker } 70*795d594fSAndroid Build Coastguard Worker runTests()71*795d594fSAndroid Build Coastguard Worker public static void runTests() { 72*795d594fSAndroid Build Coastguard Worker try { 73*795d594fSAndroid Build Coastguard Worker forStaticMethod(); 74*795d594fSAndroid Build Coastguard Worker unreachable(); 75*795d594fSAndroid Build Coastguard Worker } catch (IncompatibleClassChangeError expected) {} 76*795d594fSAndroid Build Coastguard Worker 77*795d594fSAndroid Build Coastguard Worker // TODO(b/297147201): runtime crashes here. 78*795d594fSAndroid Build Coastguard Worker /* 79*795d594fSAndroid Build Coastguard Worker try { 80*795d594fSAndroid Build Coastguard Worker forInterfaceMethod(); 81*795d594fSAndroid Build Coastguard Worker unreachable(); 82*795d594fSAndroid Build Coastguard Worker } catch (IncompatibleClassChangeError expected) {} 83*795d594fSAndroid Build Coastguard Worker */ 84*795d594fSAndroid Build Coastguard Worker 85*795d594fSAndroid Build Coastguard Worker // TODO(b/297147201): runtime does not throw exception here. 86*795d594fSAndroid Build Coastguard Worker /* 87*795d594fSAndroid Build Coastguard Worker try { 88*795d594fSAndroid Build Coastguard Worker InvokeSpecialForConstructor.runTests(); 89*795d594fSAndroid Build Coastguard Worker unreachable(); 90*795d594fSAndroid Build Coastguard Worker } catch (IncompatibleClassChangeError | ClassFormatError expected) {} 91*795d594fSAndroid Build Coastguard Worker */ 92*795d594fSAndroid Build Coastguard Worker 93*795d594fSAndroid Build Coastguard Worker try { 94*795d594fSAndroid Build Coastguard Worker InvokeSpecialForClassInitializer.runTests(); 95*795d594fSAndroid Build Coastguard Worker unreachable(); 96*795d594fSAndroid Build Coastguard Worker } catch (IncompatibleClassChangeError | ClassFormatError expected) {} 97*795d594fSAndroid Build Coastguard Worker 98*795d594fSAndroid Build Coastguard Worker try { 99*795d594fSAndroid Build Coastguard Worker inaccessibleStaticMethod(); 100*795d594fSAndroid Build Coastguard Worker unreachable(); 101*795d594fSAndroid Build Coastguard Worker } catch (IncompatibleClassChangeError expected) {} 102*795d594fSAndroid Build Coastguard Worker } 103*795d594fSAndroid Build Coastguard Worker 104*795d594fSAndroid Build Coastguard Worker } 105