From a71414fec062527d41be364ab8eb7b5b7a99f8ee Mon Sep 17 00:00:00 2001 From: Graham Chapman Date: Mon, 15 Jan 2018 11:31:22 -0500 Subject: [PATCH] Allow Object methods in invokeinterface Previous security fix broke the case where an Object method is resolved by invokeinterface. Restore the correct behaviour. Signed-off-by: Graham Chapman --- runtime/vm/resolvesupport.cpp | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/runtime/vm/resolvesupport.cpp b/runtime/vm/resolvesupport.cpp index 49550ffb4c3..2ed4db558b7 100644 --- a/runtime/vm/resolvesupport.cpp +++ b/runtime/vm/resolvesupport.cpp @@ -1052,8 +1052,18 @@ resolveInterfaceMethodRefInto(J9VMThread *vmStruct, J9ConstantPool *ramCP, UDATA if (method != NULL) { if (ramCPEntry != NULL) { J9RAMInterfaceMethodRef *ramInterfaceMethodRef = (J9RAMInterfaceMethodRef *)&ramCP[cpIndex]; - UDATA methodIndex = getITableIndexForMethod(method, interfaceClass) << 8; + J9Class *methodClass = J9_CLASS_FROM_METHOD(method); + UDATA methodIndex = 0; UDATA oldArgCount = ramInterfaceMethodRef->methodIndexAndArgCount & 255; + /* Object methods may be invoked via invokeinterface. In that case, use Object + * for the interfaceClass in the ref. The methodIndex value doesn't matter as + * Object will never be found in an iTable. + */ + if (J9_ARE_ANY_BITS_SET(methodClass->romClass->modifiers, J9_JAVA_INTERFACE)) { + methodIndex = getITableIndexForMethod(method, interfaceClass) << 8; + } else { + interfaceClass = methodClass; + } methodIndex |= oldArgCount; ramCPEntry->methodIndexAndArgCount = methodIndex; /* interfaceClass is used to indicate resolved. Make sure to write it last */