Skip to content

Commit

Permalink
Merge pull request eclipse-openj9#31 from runtimes/revert-19-ibm_sdk
Browse files Browse the repository at this point in the history
Revert "Allow Object methods in invokeinterface"
  • Loading branch information
gacholio authored and GitHub Enterprise committed Feb 15, 2018
2 parents 6de69c3 + be9328b commit 813a290
Showing 1 changed file with 1 addition and 11 deletions.
12 changes: 1 addition & 11 deletions runtime/vm/resolvesupport.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1005,18 +1005,8 @@ resolveInterfaceMethodRefInto(J9VMThread *vmStruct, J9ConstantPool *ramCP, UDATA
if (method != NULL) {
if (ramCPEntry != NULL) {
J9RAMInterfaceMethodRef *ramInterfaceMethodRef = (J9RAMInterfaceMethodRef *)&ramCP[cpIndex];
J9Class *methodClass = J9_CLASS_FROM_METHOD(method);
UDATA methodIndex = 0;
UDATA methodIndex = getITableIndexForMethod(method, interfaceClass) << 8;
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 */
Expand Down

0 comments on commit 813a290

Please sign in to comment.