blob: b49adbfae403eba3c4a154dd5e12ba3d45c4ce23 [file] [log] [blame]
HANDLE_OPCODE(OP_NEW_INSTANCE_JUMBO /*vBBBB, class@AAAAAAAA*/)
{
ClassObject* clazz;
Object* newObj;
EXPORT_PC();
ref = FETCH(1) | (u4)FETCH(2) << 16;
vdst = FETCH(3);
ILOGV("|new-instance/jumbo v%d,class@0x%08x", vdst, ref);
clazz = dvmDexGetResolvedClass(methodClassDex, ref);
if (clazz == NULL) {
clazz = dvmResolveClass(curMethod->clazz, ref, false);
if (clazz == NULL)
GOTO_exceptionThrown();
}
if (!dvmIsClassInitialized(clazz) && !dvmInitClass(clazz))
GOTO_exceptionThrown();
/*
* The JIT needs dvmDexGetResolvedClass() to return non-null.
* Since we use the portable interpreter to build the trace, this extra
* check is not needed for mterp.
*/
if (!dvmDexGetResolvedClass(methodClassDex, ref)) {
/* Class initialization is still ongoing - end the trace */
END_JIT_TSELECT();
}
/*
* Verifier now tests for interface/abstract class.
*/
//if (dvmIsInterfaceClass(clazz) || dvmIsAbstractClass(clazz)) {
// dvmThrowExceptionWithClassMessage("Ljava/lang/InstantiationError;",
// clazz->descriptor);
// GOTO_exceptionThrown();
//}
newObj = dvmAllocObject(clazz, ALLOC_DONT_TRACK);
if (newObj == NULL)
GOTO_exceptionThrown();
SET_REGISTER(vdst, (u4) newObj);
}
FINISH(4);
OP_END