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();
#if defined(WITH_JIT)
/*
* 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 ((self->interpBreak.ctl.subMode & kSubModeJitTraceBuild) &&
(!dvmDexGetResolvedClass(methodClassDex, ref))) {
/* Class initialization is still ongoing - end the trace */
dvmJitEndTraceSelect(self,pc);
}
#endif
/*
* Verifier now tests for interface/abstract class.
*/
//if (dvmIsInterfaceClass(clazz) || dvmIsAbstractClass(clazz)) {
// dvmThrowExceptionWithClassMessage(gDvm.exInstantiationError,
// clazz->descriptor);
// GOTO_exceptionThrown();
//}
newObj = dvmAllocObject(clazz, ALLOC_DONT_TRACK);
if (newObj == NULL)
GOTO_exceptionThrown();
SET_REGISTER(vdst, (u4) newObj);
}
FINISH(4);
OP_END