lots of build fixes

This commit is contained in:
Joel Dice 2007-06-05 18:41:04 -06:00
parent 45f5417827
commit 2176c32cee
4 changed files with 222 additions and 158 deletions

View File

@ -1,13 +1,23 @@
#ifndef OPCODES_H
#define OPCODES_H
#ifndef CONSTANTS_H
#define CONSTANTS_H
enum OpCode {
aaload,
aastore,
aconst,
aconst_null,
aload,
aload_0,
aload_1,
aload_2,
aload_3,
anewarray,
areturn,
arraylength,
astore,
astore_0,
astore_1,
astore_2,
astore_3,
athrow,
baload,
bastore,
@ -34,7 +44,11 @@ enum OpCode {
dstore,
dsub,
dup,
dup_x1,
dup_x2,
dup2,
dup2_x1,
dup2_x2,
f2d,
f2i,
f2l,
@ -55,6 +69,7 @@ enum OpCode {
getfield,
getstatic,
goto_,
goto_w,
i2b,
i2c,
i2d,
@ -65,9 +80,22 @@ enum OpCode {
iaload,
iand,
iastore,
iconst,
iconst_0,
iconst_1,
iconst_2,
iconst_3,
iconst_4,
iconst_5,
idiv,
if_,
if_acmpeq,
if_acmpne,
if_icmpeq,
if_icmpne,
if_icmpgt,
if_icmpge,
if_icmplt,
if_icmple,
ifeq,
ifge,
ifgt,
@ -78,6 +106,10 @@ enum OpCode {
ifnull,
iinc,
iload,
iload_0,
iload_1,
iload_2,
iload_3,
impdep1,
impdep2,
imul,
@ -93,10 +125,15 @@ enum OpCode {
ishl,
ishr,
istore,
istore_0,
istore_1,
istore_2,
istore_3,
isub,
iushr,
ixor,
jsr,
jsr_w,
l2d,
l2f,
l2i,
@ -105,11 +142,17 @@ enum OpCode {
land,
lastore,
lcmp,
lconst,
lconst_0,
lconst_1,
ldc,
ldc2,
ldc_w,
ldc2_w,
ldiv,
lload,
lload_0,
lload_1,
lload_2,
lload_3,
lmul,
lneg,
lookupswitch,
@ -119,6 +162,10 @@ enum OpCode {
lshl,
lshr,
lstore,
lstore_0,
lstore_1,
lstore_2,
lstore_3,
lsub,
lushr,
lxor,
@ -142,4 +189,15 @@ enum OpCode {
wide
};
#endif//OPCODES_H
enum TypeCode {
T_BOOLEAN = 4,
T_CHAR = 5,
T_FLOAT = 6,
T_DOUBLE = 7,
T_BYTE = 8,
T_SHORT = 9,
T_INT = 10,
T_LONG = 11
};
#endif//CONSTANTS_H

View File

@ -340,6 +340,10 @@ addMember(Object* o, Object* member)
{
switch (o->type) {
case Object::Type: case Object::Pod:
if (member->type == Object::Array) {
static_cast<Type*>(o)->members.append
(Scalar::make(o, 0, "uint32_t", "length", sizeof(uint32_t)));
}
static_cast<Type*>(o)->members.append(member);
break;

View File

@ -9,25 +9,17 @@
(object methodTable)
(object staticTable))
(pod field
(type field
(uint16_t flags)
(object name)
(object class))
(type fieldTable
(object index)
(array field body))
(pod method
(type method
(uint16_t flags)
(object name)
(object spec)
(object code))
(type methodTable
(object index)
(array method body))
(pod exceptionHandler
(uint16_t start)
(uint16_t end)
@ -62,19 +54,22 @@
(array char value))
(type byte
(uint8_t value))
(int8_t value))
(type boolean
(extends byte))
(type short
(int16_t value))
(type char
(uint16_t value))
(type int
(uint32_t value))
(int32_t value))
(type long
(uint64_t value))
(int64_t value))
(type float
(uint32_t value))
@ -90,22 +85,22 @@
(array object body))
(type byteArray
(array uint8_t body))
(array int8_t body))
(type booleanArray
(extends byteArray))
(type shortArray
(array uint16_t body))
(array int16_t body))
(type charArray
(array uint16_t body))
(type intArray
(array uint32_t body))
(array int32_t body))
(type longArray
(array uint64_t body))
(array int64_t body))
(type floatArray
(array uint32_t body))

View File

@ -7,7 +7,7 @@ namespace {
typedef void* object;
typedef unsigned Type;
#include "opcodes.h"
#include "constants.h"
enum ObjectType {
NullType,
@ -304,10 +304,10 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < objectArrayLength(t, array)) {
if (i >= 0 and static_cast<uint32_t>(i) < objectArrayLength(t, array)) {
push(t, objectArrayBody(t, array)[i]);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
object message = makeJString(t, "%d not in [0,%d]", i,
objectArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
@ -325,10 +325,10 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < objectArrayLength(t, array)) {
set(t, objectArrayBody(array)[i], value);
if (i >= 0 and static_cast<uint32_t>(i) < objectArrayLength(t, array)) {
set(t, objectArrayBody(t, array)[i], value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
object message = makeJString(t, "%d not in [0,%d]", i,
objectArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
@ -346,31 +346,31 @@ run(Thread* t)
case aload:
case iload:
case lload: {
push(t, frameBody(t, t->frame)[codeBody(t, t->code)[ip++]]);
push(t, frameLocals(t, t->frame)[codeBody(t, t->code)[ip++]]);
} goto loop;
case aload_0:
case iload_0:
case lload_0: {
push(t, frameBody(t, t->frame)[0]);
push(t, frameLocals(t, t->frame)[0]);
} goto loop;
case aload_1:
case iload_1:
case lload_1: {
push(t, frameBody(t, t->frame)[1]);
push(t, frameLocals(t, t->frame)[1]);
} goto loop;
case aload_2:
case iload_2:
case lload_2: {
push(t, frameBody(t, t->frame)[2]);
push(t, frameLocals(t, t->frame)[2]);
} goto loop;
case aload_3:
case iload_3:
case lload_3: {
push(t, frameBody(t, t->frame)[3]);
push(t, frameLocals(t, t->frame)[3]);
} goto loop;
case anewarray: {
@ -382,15 +382,15 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object class_ = resolveClass(t, codePool(t->code), index);
object class_ = resolveClass(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
object array = makeObjectArray(t, class_, c);
t->vm->sys->zero(objectArrayBody(array), c * 4);
t->vm->sys->zero(objectArrayBody(t, array), c * 4);
push(t, array);
} else {
object message = makeString(t, "%d", c);
object message = makeJString(t, "%d", c);
t->exception = makeNegativeArrayStoreException(t, message);
goto throw_;
}
@ -399,10 +399,10 @@ run(Thread* t)
case areturn:
case ireturn:
case lreturn: {
t->frame = frameNext(t->frame);
t->frame = frameNext(t, t->frame);
if (t->frame) {
t->code = methodCode(frameMethod(t->frame));
ip = frameIp(t->frame);
t->code = methodCode(t, frameMethod(t, t->frame));
ip = frameIp(t, t->frame);
goto loop;
} else {
object value = pop(t);
@ -414,7 +414,13 @@ run(Thread* t)
case arraylength: {
object array = pop(t);
if (array) {
push(t, makeInt(t, arrayLength(array)));
if (typeOf(array) == ObjectArrayType) {
push(t, makeInt(t, objectArrayLength(t, array)));
} else {
// for all other array types, the length follow the class pointer.
push(t, makeInt(t, reinterpret_cast<uint32_t&>
(static_cast<uintptr_t*>(array)[1])));
}
} else {
t->exception = makeNullPointerException(t, 0);
goto throw_;
@ -425,35 +431,35 @@ run(Thread* t)
case istore:
case lstore: {
object value = pop(t);
set(t, frameBody(t, t->frame)[codeBody(t, t->code)[ip++]], value);
set(t, frameLocals(t, t->frame)[codeBody(t, t->code)[ip++]], value);
} goto loop;
case astore_0:
case istore_0:
case lstore_0: {
object value = pop(t);
set(t, frameBody(t, t->frame)[0], value);
set(t, frameLocals(t, t->frame)[0], value);
} goto loop;
case astore_1:
case istore_1:
case lstore_1: {
object value = pop(t);
set(t, frameBody(t, t->frame)[1], value);
set(t, frameLocals(t, t->frame)[1], value);
} goto loop;
case astore_2:
case istore_2:
case lstore_2: {
object value = pop(t);
set(t, frameBody(t, t->frame)[2], value);
set(t, frameLocals(t, t->frame)[2], value);
} goto loop;
case astore_3:
case istore_3:
case lstore_3: {
object value = pop(t);
set(t, frameBody(t, t->frame)[3], value);
set(t, frameLocals(t, t->frame)[3], value);
} goto loop;
case athrow: {
@ -470,11 +476,11 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < byteArrayLength(array)) {
push(t, makeByte(t, byteArrayBody(array)[i]));
if (i >= 0 and static_cast<uint32_t>(i) < byteArrayLength(t, array)) {
push(t, makeByte(t, byteArrayBody(t, array)[i]));
} else {
object message = makeString(t, "%d not in [0,%d]", i,
byteArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
byteArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -491,11 +497,11 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < byteArrayLength(array)) {
byteArrayBody(array)[i] = intValue(t, value);
if (i >= 0 and static_cast<uint32_t>(i) < byteArrayLength(t, array)) {
byteArrayBody(t, array)[i] = intValue(t, value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
byteArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
byteArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -515,11 +521,11 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < charArrayLength(array)) {
push(t, makeInt(t, charArrayBody(array)[i]));
if (i >= 0 and static_cast<uint32_t>(i) < charArrayLength(t, array)) {
push(t, makeInt(t, charArrayBody(t, array)[i]));
} else {
object message = makeString(t, "%d not in [0,%d]", i,
charArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
charArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -536,11 +542,11 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < charArrayLength(array)) {
charArrayBody(array)[i] = intValue(t, value);
if (i >= 0 and static_cast<uint32_t>(i) < charArrayLength(t, array)) {
charArrayBody(t, array)[i] = intValue(t, value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
charArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
charArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -557,7 +563,7 @@ run(Thread* t)
if (t->stack[t->sp - 1]) {
uint16_t index = (index1 << 8) | index2;
object class_ = resolveClass(t, codePool(t->code), index);
object class_ = resolveClass(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (not instanceOf(t, class_, t->stack[t->sp - 1])) {
@ -664,7 +670,7 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object field = resolveField(t, codePool(t->code), index);
object field = resolveField(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
push(t, getField(instance, field));
@ -679,11 +685,11 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object field = resolveField(t, codePool(t->code), index);
object field = resolveField(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (not classInitialized(fieldClass(field))) {
t->code = classInitializer(fieldClass(field));
if (not classInitialized(fieldClass(t, field))) {
t->code = classInitializer(fieldClass(t, field));
ip -= 3;
parameterCount = 0;
goto invoke;
@ -746,11 +752,11 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < intArrayLength(array)) {
push(t, makeInt(t, intArrayBody(array)[i]));
if (i >= 0 and static_cast<uint32_t>(i) < intArrayLength(t, array)) {
push(t, makeInt(t, intArrayBody(t, array)[i]));
} else {
object message = makeString(t, "%d not in [0,%d]", i,
intArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
intArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -774,11 +780,11 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < intArrayLength(array)) {
intArrayBody(array)[i] = intValue(t, value);
if (i >= 0 and static_cast<uint32_t>(i) < intArrayLength(t, array)) {
intArrayBody(t, array)[i] = intValue(t, value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
intArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
intArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -789,27 +795,27 @@ run(Thread* t)
} goto loop;
case iconst_0: {
push(t, makeInt(0));
push(t, makeInt(t, 0));
} goto loop;
case iconst_1: {
push(t, makeInt(1));
push(t, makeInt(t, 1));
} goto loop;
case iconst_2: {
push(t, makeInt(2));
push(t, makeInt(t, 2));
} goto loop;
case iconst_3: {
push(t, makeInt(3));
push(t, makeInt(t, 3));
} goto loop;
case iconst_4: {
push(t, makeInt(4));
push(t, makeInt(t, 4));
} goto loop;
case iconst_5: {
push(t, makeInt(5));
push(t, makeInt(t, 5));
} goto loop;
case idiv: {
@ -1007,8 +1013,8 @@ run(Thread* t)
uint8_t index = codeBody(t, t->code)[ip++];
int8_t c = codeBody(t, t->code)[ip++];
int32_t v = intValue(t, frameBody(t, t->frame)[index]);
frameBody(t, t->frame)[index] = makeInt(t, v + c);
int32_t v = intValue(t, frameLocals(t, t->frame)[index]);
frameLocals(t, t->frame)[index] = makeInt(t, v + c);
} goto loop;
case imul: {
@ -1031,7 +1037,7 @@ run(Thread* t)
if (t->stack[t->sp - 1]) {
uint16_t index = (index1 << 8) | index2;
object class_ = resolveClass(t, codePool(t->code), index);
object class_ = resolveClass(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (instanceOf(t, class_, t->stack[t->sp - 1])) {
@ -1051,7 +1057,7 @@ run(Thread* t)
ip += 2;
object method = resolveMethod(t, codePool(t->code), index);
object method = resolveMethod(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
parameterCount = methodParameterCount(method);
@ -1072,7 +1078,7 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object method = resolveMethod(t, codePool(t->code), index);
object method = resolveMethod(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
parameterCount = methodParameterCount(method);
@ -1082,7 +1088,7 @@ run(Thread* t)
(findSpecialMethod(t, method, t->stack[t->sp - parameterCount]));
if (t->exception) goto throw_;
} else {
t->code = methodCode(method);
t->code = methodCode(t, method);
}
goto invoke;
@ -1097,18 +1103,18 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object method = resolveMethod(t, codePool(t->code), index);
object method = resolveMethod(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (not classInitialized(methodClass(method))) {
t->code = classInitializer(methodClass(method));
if (not classInitialized(methodClass(t, method))) {
t->code = classInitializer(methodClass(t, method));
ip -= 2;
parameterCount = 0;
goto invoke;
}
parameterCount = methodParameterCount(method);
t->code = methodCode(method);
t->code = methodCode(t, method);
} goto invoke;
case invokevirtual: {
@ -1116,13 +1122,13 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object method = resolveMethod(t, codePool(t->code), index);
object method = resolveMethod(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
parameterCount = methodParameterCount(method);
if (t->stack[t->sp - parameterCount]) {
t->code = methodCode
(findVirtualMethod(t, method, t->stack[t->sp - parameterCount]));
(t, findVirtualMethod(t, method, t->stack[t->sp - parameterCount]));
if (t->exception) goto throw_;
goto invoke;
@ -1185,7 +1191,7 @@ run(Thread* t)
uint8_t offset1 = codeBody(t, t->code)[ip++];
uint8_t offset2 = codeBody(t, t->code)[ip++];
push(t, makeInt(ip));
push(t, makeInt(t, ip));
ip = (ip - 1) + ((offset1 << 8) | offset2);
} goto loop;
@ -1195,7 +1201,7 @@ run(Thread* t)
uint8_t offset3 = codeBody(t, t->code)[ip++];
uint8_t offset4 = codeBody(t, t->code)[ip++];
push(t, makeInt(ip));
push(t, makeInt(t, ip));
ip = (ip - 1)
+ ((offset1 << 24) | (offset2 << 16) | (offset3 << 8) | offset4);
} goto loop;
@ -1203,14 +1209,14 @@ run(Thread* t)
case l2i: {
object v = pop(t);
push(t, makeInt(t, static_cast<int32_t>(longValue(v))));
push(t, makeInt(t, static_cast<int32_t>(longValue(t, v))));
} goto loop;
case ladd: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) + longValue(b)));
push(t, makeLong(t, longValue(t, a) + longValue(t, b)));
} goto loop;
case laload: {
@ -1219,11 +1225,11 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < longArrayLength(array)) {
push(t, makeLong(t, longArrayBody(array)[i]));
if (i >= 0 and static_cast<uint32_t>(i) < longArrayLength(t, array)) {
push(t, makeLong(t, longArrayBody(t, array)[i]));
} else {
object message = makeString(t, "%d not in [0,%d]", i,
longArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
longArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -1237,7 +1243,7 @@ run(Thread* t)
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) & longValue(b)));
push(t, makeLong(t, longValue(t, a) & longValue(t, b)));
} goto loop;
case lastore: {
@ -1247,11 +1253,11 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < longArrayLength(array)) {
longArrayBody(array)[i] = longValue(value);
if (i >= 0 and static_cast<uint32_t>(i) < longArrayLength(t, array)) {
longArrayBody(t, array)[i] = longValue(t, value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
longArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
longArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -1265,20 +1271,20 @@ run(Thread* t)
object b = pop(t);
object a = pop(t);
push(t, makeInt(t, longValue(a) > longValue(b) ? 1
: longValue(a) == longValue(b) ? 0 : -1));
push(t, makeInt(t, longValue(t, a) > longValue(t, b) ? 1
: longValue(t, a) == longValue(t, b) ? 0 : -1));
} goto loop;
case lconst_0: {
push(t, makeLong(0));
push(t, makeLong(t, 0));
} goto loop;
case lconst_1: {
push(t, makeLong(1));
push(t, makeLong(t, 1));
} goto loop;
case ldc: {
push(t, codePool(t->code)[codeBody(t, t->code)[ip++]]);
push(t, rawArrayBody(t, codePool(t, t->code))[codeBody(t, t->code)[ip++]]);
} goto loop;
case ldc_w:
@ -1286,76 +1292,77 @@ run(Thread* t)
uint8_t index1 = codeBody(t, t->code)[ip++];
uint8_t index2 = codeBody(t, t->code)[ip++];
push(t, codePool(t->code)[codeBody(t, t->code)[(offset1 << 8) | offset2]]);
push(t, rawArrayBody(t, codePool(t, t->code))[(index1 << 8) | index2]);
} goto loop;
case ldiv: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) / longValue(b)));
push(t, makeLong(t, longValue(t, a) / longValue(t, b)));
} goto loop;
case lmul: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) * longValue(b)));
push(t, makeLong(t, longValue(t, a) * longValue(t, b)));
} goto loop;
case lneg: {
object v = pop(t);
push(t, makeLong(t, - longValue(v)));
push(t, makeLong(t, - longValue(t, v)));
} goto loop;
case lor: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) | longValue(b)));
push(t, makeLong(t, longValue(t, a) | longValue(t, b)));
} goto loop;
case lrem: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) % longValue(b)));
push(t, makeLong(t, longValue(t, a) % longValue(t, b)));
} goto loop;
case lshl: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) << longValue(b)));
push(t, makeLong(t, longValue(t, a) << longValue(t, b)));
} goto loop;
case lshr: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) >> longValue(b)));
push(t, makeLong(t, longValue(t, a) >> longValue(t, b)));
} goto loop;
case lsub: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) - longValue(b)));
push(t, makeLong(t, longValue(t, a) - longValue(t, b)));
} goto loop;
case lushr: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, static_cast<uint64_t>(longValue(a)) << longValue(b)));
push(t, makeLong(t, static_cast<uint64_t>(longValue(t, a))
<< longValue(t, b)));
} goto loop;
case lxor: {
object b = pop(t);
object a = pop(t);
push(t, makeLong(t, longValue(a) ^ longValue(b)));
push(t, makeLong(t, longValue(t, a) ^ longValue(t, b)));
} goto loop;
case new_: {
@ -1363,7 +1370,7 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object class_ = resolveClass(t, codePool(t->code), index);
object class_ = resolveClass(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (not classInitialized(class_)) {
@ -1441,7 +1448,7 @@ run(Thread* t)
push(t, array);
} else {
object message = makeString(t, "%d", c);
object message = makeJString(t, "%d", c);
t->exception = makeNegativeArrayStoreException(t, message);
goto throw_;
}
@ -1469,7 +1476,7 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object field = resolveField(t, codePool(t->code), index);
object field = resolveField(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
object value = pop(t);
@ -1485,11 +1492,11 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
uint16_t index = (index1 << 8) | index2;
object field = resolveField(t, codePool(t->code), index);
object field = resolveField(t, codePool(t, t->code), index);
if (t->exception) goto throw_;
if (not classInitialized(fieldClass(field))) {
t->code = classInitializer(fieldClass(field));
if (not classInitialized(fieldClass(t, field))) {
t->code = classInitializer(fieldClass(t, field));
ip -= 3;
parameterCount = 0;
goto invoke;
@ -1500,14 +1507,14 @@ run(Thread* t)
} goto loop;
case ret: {
ip = intValue(t, frameBody(t, t->frame)[codeBody(t, t->code)[ip++]]);
ip = intValue(t, frameLocals(t, t->frame)[codeBody(t, t->code)[ip]]);
} goto loop;
case return_: {
t->frame = frameNext(t->frame);
t->frame = frameNext(t, t->frame);
if (t->frame) {
t->code = methodCode(frameMethod(t->frame));
ip = frameIp(t->frame);
t->code = methodCode(t, frameMethod(t, t->frame));
ip = frameIp(t, t->frame);
goto loop;
} else {
t->code = 0;
@ -1521,11 +1528,11 @@ run(Thread* t)
if (array) {
int32_t i = intValue(t, index);
if (i >= 0 and i < shortArrayLength(array)) {
push(t, makeShort(t, shortArrayBody(array)[i]));
if (i >= 0 and static_cast<uint32_t>(i) < shortArrayLength(t, array)) {
push(t, makeShort(t, shortArrayBody(t, array)[i]));
} else {
object message = makeString(t, "%d not in [0,%d]", i,
shortArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
shortArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -1542,11 +1549,11 @@ run(Thread* t)
int32_t i = intValue(t, index);
if (array) {
if (i >= 0 and i < shortArrayLength(array)) {
shortArrayBody(array)[i] = intValue(t, value);
if (i >= 0 and static_cast<uint32_t>(i) < shortArrayLength(t, array)) {
shortArrayBody(t, array)[i] = intValue(t, value);
} else {
object message = makeString(t, "%d not in [0,%d]", i,
shortArrayLength(array));
object message = makeJString(t, "%d not in [0,%d]", i,
shortArrayLength(t, array));
t->exception = makeArrayIndexOutOfBoundsException(t, message);
goto throw_;
}
@ -1582,7 +1589,7 @@ run(Thread* t)
uint8_t index1 = codeBody(t, t->code)[ip++];
uint8_t index2 = codeBody(t, t->code)[ip++];
push(t, frameBody(t, t->frame)[(index1 << 8) | index2]);
push(t, frameLocals(t, t->frame)[(index1 << 8) | index2]);
} goto loop;
case astore:
@ -1592,7 +1599,7 @@ run(Thread* t)
uint8_t index2 = codeBody(t, t->code)[ip++];
object value = pop(t);
set(t, frameBody(t, t->frame)[(index1 << 8) | index2], value);
set(t, frameLocals(t, t->frame)[(index1 << 8) | index2], value);
} goto loop;
case iinc: {
@ -1604,30 +1611,30 @@ run(Thread* t)
uint8_t count2 = codeBody(t, t->code)[ip++];
uint16_t count = (count1 << 8) | count2;
int32_t v = intValue(t, frameBody(t, t->frame)[index]);
frameBody(t, t->frame)[index] = makeInt(t, v + count);
int32_t v = intValue(t, frameLocals(t, t->frame)[index]);
frameLocals(t, t->frame)[index] = makeInt(t, v + count);
} goto loop;
case ret: {
uint8_t index1 = codeBody(t, t->code)[ip++];
uint8_t index2 = codeBody(t, t->code)[ip++];
ip = intValue(t, frameBody(t, t->frame)[(index1 << 8) | index2]);
ip = intValue(t, frameLocals(t, t->frame)[(index1 << 8) | index2]);
} goto loop;
default: abort(t);
}
invoke:
if (codeMaxStack(t->code) + t->sp - parameterCount > Thread::StackSize) {
if (codeMaxStack(t, t->code) + t->sp - parameterCount > Thread::StackSize) {
t->exception = makeStackOverflowException(t, 0);
goto throw_;
}
frameIp(t->frame) = ip;
frameIp(t, t->frame) = ip;
t->frame = makeFrame(t, t->code, t->frame);
memcpy(frameLocals(t->frame),
memcpy(frameLocals(t, t->frame),
t->stack + t->sp - parameterCount,
parameterCount);
t->sp -= parameterCount;
@ -1635,18 +1642,18 @@ run(Thread* t)
goto loop;
throw_:
for (; t->frame; t->frame = frameNext(t->frame)) {
t->code = methodCode(frameMethod(t->frame));
object eht = codeExceptionHandlerTable(t->code);
for (; t->frame; t->frame = frameNext(t, t->frame)) {
t->code = methodCode(t, frameMethod(t, t->frame));
object eht = codeExceptionHandlerTable(t, t->code);
if (eht) {
for (unsigned i = 0; i < exceptionHandleTableLength(eht); ++i) {
ExceptionHandler* eh = exceptionHandlerTableBody(eht)[i];
for (unsigned i = 0; i < exceptionHandleTableLength(t, eht); ++i) {
ExceptionHandler* eh = exceptionHandlerTableBody(t, eht)[i];
uint16_t catchType = exceptionHandlerCatchType(eh);
if (catchType == 0 or
instanceOf(rawArrayBody(codePool(t->code))[catchType],
instanceOf(rawArrayBody(t, codePool(t, t->code))[catchType],
t->exception))
{
t->sp = frameStackBase(t->frame);
t->sp = frameStackBase(t, t->frame);
ip = exceptionHandlerIp(eh);
push(t, t->exception);
t->exception = 0;