mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
zero heap space ahead of time when allocating raw storage and garbage collecting, not when allocating individual objects
This helps us support the Java Memory Model without adding a memory barrier to every object allocation. It's also potentially more efficient, since we zero out each heap segment all at once instead of bit-by-bit with each object allocation.
This commit is contained in:
parent
8410e1d683
commit
6e6035505c
@ -27,7 +27,7 @@ search(Thread* t, jstring name, object (*op)(Thread*, object),
|
|||||||
bool replaceDots)
|
bool replaceDots)
|
||||||
{
|
{
|
||||||
if (LIKELY(name)) {
|
if (LIKELY(name)) {
|
||||||
object n = makeByteArray(t, stringLength(t, *name) + 1, false);
|
object n = makeByteArray(t, stringLength(t, *name) + 1);
|
||||||
char* s = reinterpret_cast<char*>(&byteArrayBody(t, n, 0));
|
char* s = reinterpret_cast<char*>(&byteArrayBody(t, n, 0));
|
||||||
stringChars(t, *name, s);
|
stringChars(t, *name, s);
|
||||||
|
|
||||||
@ -406,7 +406,7 @@ Java_java_lang_reflect_Array_makeObjectArray
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeObjectArray(t, *elementType, length, true));
|
return makeLocalReference(t, makeObjectArray(t, *elementType, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jint JNICALL
|
extern "C" JNIEXPORT jint JNICALL
|
||||||
@ -671,7 +671,7 @@ Java_java_lang_Throwable_trace(Thread* t, jclass, jint skipCount)
|
|||||||
|
|
||||||
t->m->processor->walkStack(t, &v);
|
t->m->processor->walkStack(t, &v);
|
||||||
|
|
||||||
if (v.trace == 0) v.trace = makeArray(t, 0, true);
|
if (v.trace == 0) v.trace = makeArray(t, 0);
|
||||||
|
|
||||||
return makeLocalReference(t, v.trace);
|
return makeLocalReference(t, v.trace);
|
||||||
}
|
}
|
||||||
@ -683,8 +683,7 @@ Java_java_lang_Throwable_resolveTrace(Thread* t, jclass, jobject trace)
|
|||||||
|
|
||||||
unsigned length = arrayLength(t, *trace);
|
unsigned length = arrayLength(t, *trace);
|
||||||
object array = makeObjectArray
|
object array = makeObjectArray
|
||||||
(t, arrayBody(t, t->m->types, Machine::StackTraceElementType),
|
(t, arrayBody(t, t->m->types, Machine::StackTraceElementType), length);
|
||||||
length, true);
|
|
||||||
PROTECT(t, array);
|
PROTECT(t, array);
|
||||||
|
|
||||||
object e = 0;
|
object e = 0;
|
||||||
|
@ -1568,8 +1568,7 @@ uint64_t
|
|||||||
makeBlankObjectArray(MyThread* t, object class_, int32_t length)
|
makeBlankObjectArray(MyThread* t, object class_, int32_t length)
|
||||||
{
|
{
|
||||||
if (length >= 0) {
|
if (length >= 0) {
|
||||||
return reinterpret_cast<uint64_t>
|
return reinterpret_cast<uint64_t>(makeObjectArray(t, class_, length));
|
||||||
(makeObjectArray(t, class_, length, true));
|
|
||||||
} else {
|
} else {
|
||||||
object message = makeString(t, "%d", length);
|
object message = makeString(t, "%d", length);
|
||||||
t->exception = makeNegativeArraySizeException(t, message);
|
t->exception = makeNegativeArraySizeException(t, message);
|
||||||
@ -1581,7 +1580,7 @@ uint64_t
|
|||||||
makeBlankArray(MyThread* t, unsigned type, int32_t length)
|
makeBlankArray(MyThread* t, unsigned type, int32_t length)
|
||||||
{
|
{
|
||||||
if (length >= 0) {
|
if (length >= 0) {
|
||||||
object (*constructor)(Thread*, uintptr_t, bool);
|
object (*constructor)(Thread*, uintptr_t);
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case T_BOOLEAN:
|
case T_BOOLEAN:
|
||||||
constructor = makeBooleanArray;
|
constructor = makeBooleanArray;
|
||||||
@ -1618,7 +1617,7 @@ makeBlankArray(MyThread* t, unsigned type, int32_t length)
|
|||||||
default: abort(t);
|
default: abort(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
return reinterpret_cast<uintptr_t>(constructor(t, length, true));
|
return reinterpret_cast<uintptr_t>(constructor(t, length));
|
||||||
} else {
|
} else {
|
||||||
object message = makeString(t, "%d", length);
|
object message = makeString(t, "%d", length);
|
||||||
t->exception = makeNegativeArraySizeException(t, message);
|
t->exception = makeNegativeArraySizeException(t, message);
|
||||||
@ -1698,7 +1697,7 @@ makeMultidimensionalArray2(MyThread* t, object class_, uintptr_t* countStack,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
object array = makeArray(t, counts[0], true);
|
object array = makeArray(t, counts[0]);
|
||||||
setObjectClass(t, array, class_);
|
setObjectClass(t, array, class_);
|
||||||
PROTECT(t, array);
|
PROTECT(t, array);
|
||||||
|
|
||||||
@ -3828,10 +3827,10 @@ translateExceptionHandlerTable(MyThread* t, Compiler* c, object code,
|
|||||||
|
|
||||||
unsigned length = exceptionHandlerTableLength(t, oldTable);
|
unsigned length = exceptionHandlerTableLength(t, oldTable);
|
||||||
|
|
||||||
object newIndex = makeIntArray(t, length * 3, false);
|
object newIndex = makeIntArray(t, length * 3);
|
||||||
PROTECT(t, newIndex);
|
PROTECT(t, newIndex);
|
||||||
|
|
||||||
object newTable = makeArray(t, length + 1, true);
|
object newTable = makeArray(t, length + 1);
|
||||||
PROTECT(t, newTable);
|
PROTECT(t, newTable);
|
||||||
|
|
||||||
set(t, newTable, ArrayBody, newIndex);
|
set(t, newTable, ArrayBody, newIndex);
|
||||||
@ -3874,7 +3873,7 @@ translateLineNumberTable(MyThread* t, Compiler* c, object code, intptr_t start)
|
|||||||
PROTECT(t, oldTable);
|
PROTECT(t, oldTable);
|
||||||
|
|
||||||
unsigned length = lineNumberTableLength(t, oldTable);
|
unsigned length = lineNumberTableLength(t, oldTable);
|
||||||
object newTable = makeLineNumberTable(t, length, false);
|
object newTable = makeLineNumberTable(t, length);
|
||||||
for (unsigned i = 0; i < length; ++i) {
|
for (unsigned i = 0; i < length; ++i) {
|
||||||
LineNumber* oldLine = lineNumberTableBody(t, oldTable, i);
|
LineNumber* oldLine = lineNumberTableBody(t, oldTable, i);
|
||||||
LineNumber* newLine = lineNumberTableBody(t, newTable, i);
|
LineNumber* newLine = lineNumberTableBody(t, newTable, i);
|
||||||
@ -4107,7 +4106,7 @@ finish(MyThread* t, Allocator* allocator, Context* context)
|
|||||||
FixedSizeOfArray + ((context->objectPoolCount + 1) * BytesPerWord),
|
FixedSizeOfArray + ((context->objectPoolCount + 1) * BytesPerWord),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
initArray(t, pool, context->objectPoolCount + 1, false);
|
initArray(t, pool, context->objectPoolCount + 1);
|
||||||
mark(t, pool, 0);
|
mark(t, pool, 0);
|
||||||
|
|
||||||
set(t, pool, ArrayBody, objectPools(t));
|
set(t, pool, ArrayBody, objectPools(t));
|
||||||
@ -4150,7 +4149,7 @@ finish(MyThread* t, Allocator* allocator, Context* context)
|
|||||||
codeLineNumberTable(t, code),
|
codeLineNumberTable(t, code),
|
||||||
codeMaxStack(t, code),
|
codeMaxStack(t, code),
|
||||||
codeMaxLocals(t, code),
|
codeMaxLocals(t, code),
|
||||||
0, false);
|
0);
|
||||||
|
|
||||||
set(t, context->method, MethodCode, code);
|
set(t, context->method, MethodCode, code);
|
||||||
}
|
}
|
||||||
@ -4176,8 +4175,7 @@ finish(MyThread* t, Allocator* allocator, Context* context)
|
|||||||
unsigned size = usableFrameSizeWithParameters(t, context->method);
|
unsigned size = usableFrameSizeWithParameters(t, context->method);
|
||||||
object map = makeIntArray
|
object map = makeIntArray
|
||||||
(t, context->traceLogCount
|
(t, context->traceLogCount
|
||||||
+ ceiling(context->traceLogCount * size, 32),
|
+ ceiling(context->traceLogCount * size, 32));
|
||||||
false);
|
|
||||||
|
|
||||||
assert(t, intArrayLength(t, map) == context->traceLogCount
|
assert(t, intArrayLength(t, map) == context->traceLogCount
|
||||||
+ frameObjectMapSize(t, context->method, map));
|
+ frameObjectMapSize(t, context->method, map));
|
||||||
@ -5076,7 +5074,7 @@ class MyProcessor: public Processor {
|
|||||||
return vm::makeClass
|
return vm::makeClass
|
||||||
(t, flags, vmFlags, arrayDimensions, fixedSize, arrayElementSize,
|
(t, flags, vmFlags, arrayDimensions, fixedSize, arrayElementSize,
|
||||||
objectMask, name, super, interfaceTable, virtualTable, fieldTable,
|
objectMask, name, super, interfaceTable, virtualTable, fieldTable,
|
||||||
methodTable, staticTable, loader, vtableLength, false);
|
methodTable, staticTable, loader, vtableLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void
|
virtual void
|
||||||
@ -5399,7 +5397,7 @@ class MyProcessor: public Processor {
|
|||||||
if (image) {
|
if (image) {
|
||||||
::boot(static_cast<MyThread*>(t), image);
|
::boot(static_cast<MyThread*>(t), image);
|
||||||
} else {
|
} else {
|
||||||
callTable = makeArray(t, 128, true);
|
callTable = makeArray(t, 128);
|
||||||
|
|
||||||
methodTree = methodTreeSentinal = makeTreeNode(t, 0, 0, 0);
|
methodTree = methodTreeSentinal = makeTreeNode(t, 0, 0, 0);
|
||||||
set(t, methodTree, TreeNodeLeft, methodTreeSentinal);
|
set(t, methodTree, TreeNodeLeft, methodTreeSentinal);
|
||||||
@ -5471,7 +5469,7 @@ resizeTable(MyThread* t, object oldTable, unsigned newLength)
|
|||||||
object oldNode = 0;
|
object oldNode = 0;
|
||||||
PROTECT(t, oldNode);
|
PROTECT(t, oldNode);
|
||||||
|
|
||||||
object newTable = makeArray(t, newLength, true);
|
object newTable = makeArray(t, newLength);
|
||||||
PROTECT(t, newTable);
|
PROTECT(t, newTable);
|
||||||
|
|
||||||
for (unsigned i = 0; i < arrayLength(t, oldTable); ++i) {
|
for (unsigned i = 0; i < arrayLength(t, oldTable); ++i) {
|
||||||
@ -5532,7 +5530,7 @@ insertCallNode(MyThread* t, object node)
|
|||||||
object
|
object
|
||||||
makeClassMap(Thread* t, unsigned* table, unsigned count, uintptr_t* heap)
|
makeClassMap(Thread* t, unsigned* table, unsigned count, uintptr_t* heap)
|
||||||
{
|
{
|
||||||
object array = makeArray(t, nextPowerOfTwo(count), true);
|
object array = makeArray(t, nextPowerOfTwo(count));
|
||||||
object map = makeHashMap(t, 0, array);
|
object map = makeHashMap(t, 0, array);
|
||||||
PROTECT(t, map);
|
PROTECT(t, map);
|
||||||
|
|
||||||
@ -5548,7 +5546,7 @@ object
|
|||||||
makeStaticTableArray(Thread* t, unsigned* table, unsigned count,
|
makeStaticTableArray(Thread* t, unsigned* table, unsigned count,
|
||||||
uintptr_t* heap)
|
uintptr_t* heap)
|
||||||
{
|
{
|
||||||
object array = makeArray(t, count, false);
|
object array = makeArray(t, count);
|
||||||
|
|
||||||
for (unsigned i = 0; i < count; ++i) {
|
for (unsigned i = 0; i < count; ++i) {
|
||||||
set(t, array, ArrayBody + (i * BytesPerWord),
|
set(t, array, ArrayBody + (i * BytesPerWord),
|
||||||
@ -5561,7 +5559,7 @@ makeStaticTableArray(Thread* t, unsigned* table, unsigned count,
|
|||||||
object
|
object
|
||||||
makeStringMap(Thread* t, unsigned* table, unsigned count, uintptr_t* heap)
|
makeStringMap(Thread* t, unsigned* table, unsigned count, uintptr_t* heap)
|
||||||
{
|
{
|
||||||
object array = makeArray(t, nextPowerOfTwo(count), true);
|
object array = makeArray(t, nextPowerOfTwo(count));
|
||||||
object map = makeWeakHashMap(t, 0, array);
|
object map = makeWeakHashMap(t, 0, array);
|
||||||
PROTECT(t, map);
|
PROTECT(t, map);
|
||||||
|
|
||||||
@ -5577,7 +5575,7 @@ object
|
|||||||
makeCallTable(MyThread* t, uintptr_t* heap, unsigned* calls, unsigned count,
|
makeCallTable(MyThread* t, uintptr_t* heap, unsigned* calls, unsigned count,
|
||||||
uintptr_t base)
|
uintptr_t base)
|
||||||
{
|
{
|
||||||
object table = makeArray(t, nextPowerOfTwo(count), true);
|
object table = makeArray(t, nextPowerOfTwo(count));
|
||||||
PROTECT(t, table);
|
PROTECT(t, table);
|
||||||
|
|
||||||
unsigned size = 0;
|
unsigned size = 0;
|
||||||
|
@ -168,7 +168,7 @@ NewString(Thread* t, const jchar* chars, jsize size)
|
|||||||
|
|
||||||
object a = 0;
|
object a = 0;
|
||||||
if (size) {
|
if (size) {
|
||||||
a = makeCharArray(t, size, false);
|
a = makeCharArray(t, size);
|
||||||
memcpy(&charArrayBody(t, a, 0), chars, size * sizeof(jchar));
|
memcpy(&charArrayBody(t, a, 0), chars, size * sizeof(jchar));
|
||||||
}
|
}
|
||||||
object s = makeString(t, a, 0, size, 0);
|
object s = makeString(t, a, 0, size, 0);
|
||||||
@ -184,7 +184,7 @@ NewStringUTF(Thread* t, const char* chars)
|
|||||||
object a = 0;
|
object a = 0;
|
||||||
unsigned size = strlen(chars);
|
unsigned size = strlen(chars);
|
||||||
if (size) {
|
if (size) {
|
||||||
a = makeByteArray(t, size, false);
|
a = makeByteArray(t, size);
|
||||||
memcpy(&byteArrayBody(t, a, 0), chars, size);
|
memcpy(&byteArrayBody(t, a, 0), chars, size);
|
||||||
}
|
}
|
||||||
object s = makeString(t, a, 0, size, 0);
|
object s = makeString(t, a, 0, size, 0);
|
||||||
@ -208,7 +208,7 @@ FindClass(Thread* t, const char* name)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object n = makeByteArray(t, strlen(name) + 1, false);
|
object n = makeByteArray(t, strlen(name) + 1);
|
||||||
replace('.', '/', name, &byteArrayBody(t, n, 0));
|
replace('.', '/', name, &byteArrayBody(t, n, 0));
|
||||||
|
|
||||||
return makeLocalReference(t, resolveClass(t, n));
|
return makeLocalReference(t, resolveClass(t, n));
|
||||||
@ -1214,7 +1214,7 @@ NewObjectArray(Thread* t, jsize length, jclass class_, jobject init)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object a = makeObjectArray(t, *class_, length, false);
|
object a = makeObjectArray(t, *class_, length);
|
||||||
object value = (init ? *init : 0);
|
object value = (init ? *init : 0);
|
||||||
for (jsize i = 0; i < length; ++i) {
|
for (jsize i = 0; i < length; ++i) {
|
||||||
set(t, a, ArrayBody + (i * BytesPerWord), value);
|
set(t, a, ArrayBody + (i * BytesPerWord), value);
|
||||||
@ -1244,7 +1244,7 @@ NewBooleanArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeBooleanArray(t, length, true));
|
return makeLocalReference(t, makeBooleanArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jbyteArray JNICALL
|
jbyteArray JNICALL
|
||||||
@ -1252,7 +1252,7 @@ NewByteArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeByteArray(t, length, true));
|
return makeLocalReference(t, makeByteArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jcharArray JNICALL
|
jcharArray JNICALL
|
||||||
@ -1260,7 +1260,7 @@ NewCharArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeCharArray(t, length, true));
|
return makeLocalReference(t, makeCharArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jshortArray JNICALL
|
jshortArray JNICALL
|
||||||
@ -1268,7 +1268,7 @@ NewShortArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeShortArray(t, length, true));
|
return makeLocalReference(t, makeShortArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jintArray JNICALL
|
jintArray JNICALL
|
||||||
@ -1276,7 +1276,7 @@ NewIntArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeIntArray(t, length, true));
|
return makeLocalReference(t, makeIntArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jlongArray JNICALL
|
jlongArray JNICALL
|
||||||
@ -1284,7 +1284,7 @@ NewLongArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeLongArray(t, length, true));
|
return makeLocalReference(t, makeLongArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jfloatArray JNICALL
|
jfloatArray JNICALL
|
||||||
@ -1292,7 +1292,7 @@ NewFloatArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeFloatArray(t, length, true));
|
return makeLocalReference(t, makeFloatArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jdoubleArray JNICALL
|
jdoubleArray JNICALL
|
||||||
@ -1300,7 +1300,7 @@ NewDoubleArray(Thread* t, jsize length)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return makeLocalReference(t, makeDoubleArray(t, length, true));
|
return makeLocalReference(t, makeDoubleArray(t, length));
|
||||||
}
|
}
|
||||||
|
|
||||||
jboolean* JNICALL
|
jboolean* JNICALL
|
||||||
|
@ -453,9 +453,16 @@ postCollect(Thread* t)
|
|||||||
t->m->heap->free(t->defaultHeap, ThreadHeapSizeInBytes);
|
t->m->heap->free(t->defaultHeap, ThreadHeapSizeInBytes);
|
||||||
t->defaultHeap = static_cast<uintptr_t*>
|
t->defaultHeap = static_cast<uintptr_t*>
|
||||||
(t->m->heap->allocate(ThreadHeapSizeInBytes));
|
(t->m->heap->allocate(ThreadHeapSizeInBytes));
|
||||||
|
memset(t->defaultHeap, 0, ThreadHeapSizeInBytes);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (t->heap == t->defaultHeap) {
|
||||||
|
memset(t->defaultHeap, 0, t->heapIndex * BytesPerWord);
|
||||||
|
} else {
|
||||||
|
memset(t->defaultHeap, 0, ThreadHeapSizeInBytes);
|
||||||
t->heap = t->defaultHeap;
|
t->heap = t->defaultHeap;
|
||||||
|
}
|
||||||
|
|
||||||
t->heapOffset = 0;
|
t->heapOffset = 0;
|
||||||
t->heapIndex = 0;
|
t->heapIndex = 0;
|
||||||
|
|
||||||
@ -481,7 +488,7 @@ makeByteArray(Thread* t, const char* format, va_list a)
|
|||||||
int r = vsnprintf(buffer, Size - 1, format, a);
|
int r = vsnprintf(buffer, Size - 1, format, a);
|
||||||
expect(t, r >= 0 and r < Size - 1);
|
expect(t, r >= 0 and r < Size - 1);
|
||||||
|
|
||||||
object s = makeByteArray(t, strlen(buffer) + 1, false);
|
object s = makeByteArray(t, strlen(buffer) + 1);
|
||||||
memcpy(&byteArrayBody(t, s, 0), buffer, byteArrayLength(t, s));
|
memcpy(&byteArrayBody(t, s, 0), buffer, byteArrayLength(t, s));
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
@ -490,7 +497,7 @@ makeByteArray(Thread* t, const char* format, va_list a)
|
|||||||
object
|
object
|
||||||
parseUtf8(Thread* t, Stream& s, unsigned length)
|
parseUtf8(Thread* t, Stream& s, unsigned length)
|
||||||
{
|
{
|
||||||
object value = makeByteArray(t, length + 1, false);
|
object value = makeByteArray(t, length + 1);
|
||||||
unsigned vi = 0;
|
unsigned vi = 0;
|
||||||
for (unsigned si = 0; si < length; ++si) {
|
for (unsigned si = 0; si < length; ++si) {
|
||||||
unsigned a = s.read1();
|
unsigned a = s.read1();
|
||||||
@ -523,7 +530,7 @@ parseUtf8(Thread* t, Stream& s, unsigned length)
|
|||||||
if (vi < length) {
|
if (vi < length) {
|
||||||
PROTECT(t, value);
|
PROTECT(t, value);
|
||||||
|
|
||||||
object v = makeByteArray(t, vi + 1, false);
|
object v = makeByteArray(t, vi + 1);
|
||||||
memcpy(&byteArrayBody(t, v, 0), &byteArrayBody(t, value, 0), vi);
|
memcpy(&byteArrayBody(t, v, 0), &byteArrayBody(t, value, 0), vi);
|
||||||
value = v;
|
value = v;
|
||||||
}
|
}
|
||||||
@ -622,7 +629,7 @@ parsePool(Thread* t, Stream& s)
|
|||||||
{
|
{
|
||||||
unsigned count = s.read2() - 1;
|
unsigned count = s.read2() - 1;
|
||||||
|
|
||||||
object pool = makeSingleton(t, count);
|
object pool = makeSingletonOfSize(t, count);
|
||||||
PROTECT(t, pool);
|
PROTECT(t, pool);
|
||||||
|
|
||||||
if (count) {
|
if (count) {
|
||||||
@ -734,7 +741,7 @@ parseInterfaceTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
if ((classFlags(t, class_) & ACC_INTERFACE) == 0) {
|
if ((classFlags(t, class_) & ACC_INTERFACE) == 0) {
|
||||||
length *= 2;
|
length *= 2;
|
||||||
}
|
}
|
||||||
interfaceTable = makeArray(t, length, true);
|
interfaceTable = makeArray(t, length);
|
||||||
PROTECT(t, interfaceTable);
|
PROTECT(t, interfaceTable);
|
||||||
|
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
@ -749,7 +756,7 @@ parseInterfaceTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
if (classVirtualTable(t, interface)) {
|
if (classVirtualTable(t, interface)) {
|
||||||
// we'll fill in this table in parseMethodTable():
|
// we'll fill in this table in parseMethodTable():
|
||||||
object vtable = makeArray
|
object vtable = makeArray
|
||||||
(t, arrayLength(t, classVirtualTable(t, interface)), true);
|
(t, arrayLength(t, classVirtualTable(t, interface)));
|
||||||
|
|
||||||
set(t, interfaceTable, ArrayBody + (i * BytesPerWord), vtable);
|
set(t, interfaceTable, ArrayBody + (i * BytesPerWord), vtable);
|
||||||
}
|
}
|
||||||
@ -778,10 +785,10 @@ parseFieldTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
unsigned staticOffset = BytesPerWord * 2;
|
unsigned staticOffset = BytesPerWord * 2;
|
||||||
unsigned staticCount = 0;
|
unsigned staticCount = 0;
|
||||||
|
|
||||||
object fieldTable = makeArray(t, count, true);
|
object fieldTable = makeArray(t, count);
|
||||||
PROTECT(t, fieldTable);
|
PROTECT(t, fieldTable);
|
||||||
|
|
||||||
object staticValueTable = makeIntArray(t, count, false);
|
object staticValueTable = makeIntArray(t, count);
|
||||||
PROTECT(t, staticValueTable);
|
PROTECT(t, staticValueTable);
|
||||||
|
|
||||||
uint8_t staticTypes[count];
|
uint8_t staticTypes[count];
|
||||||
@ -856,7 +863,7 @@ parseFieldTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
if (staticCount) {
|
if (staticCount) {
|
||||||
unsigned footprint = ceiling(staticOffset - (BytesPerWord * 2),
|
unsigned footprint = ceiling(staticOffset - (BytesPerWord * 2),
|
||||||
BytesPerWord);
|
BytesPerWord);
|
||||||
object staticTable = makeSingleton(t, footprint);
|
object staticTable = makeSingletonOfSize(t, footprint);
|
||||||
|
|
||||||
uint8_t* body = reinterpret_cast<uint8_t*>
|
uint8_t* body = reinterpret_cast<uint8_t*>
|
||||||
(&singletonBody(t, staticTable, 0));
|
(&singletonBody(t, staticTable, 0));
|
||||||
@ -901,8 +908,6 @@ parseFieldTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
|
|
||||||
default: abort(t);
|
default: abort(t);
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
memset(body + offset, 0, size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (staticTypes[i] == ObjectField) {
|
if (staticTypes[i] == ObjectField) {
|
||||||
@ -925,7 +930,7 @@ parseFieldTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
classObjectMask(t, classSuper(t, class_)));
|
classObjectMask(t, classSuper(t, class_)));
|
||||||
} else {
|
} else {
|
||||||
object mask = makeIntArray
|
object mask = makeIntArray
|
||||||
(t, ceiling(classFixedSize(t, class_), 32 * BytesPerWord), true);
|
(t, ceiling(classFixedSize(t, class_), 32 * BytesPerWord));
|
||||||
intArrayBody(t, mask, 0) = 1;
|
intArrayBody(t, mask, 0) = 1;
|
||||||
|
|
||||||
object superMask = 0;
|
object superMask = 0;
|
||||||
@ -970,13 +975,13 @@ parseCode(Thread* t, Stream& s, object pool)
|
|||||||
unsigned maxLocals = s.read2();
|
unsigned maxLocals = s.read2();
|
||||||
unsigned length = s.read4();
|
unsigned length = s.read4();
|
||||||
|
|
||||||
object code = makeCode(t, pool, 0, 0, maxStack, maxLocals, length, false);
|
object code = makeCode(t, pool, 0, 0, maxStack, maxLocals, length);
|
||||||
s.read(&codeBody(t, code, 0), length);
|
s.read(&codeBody(t, code, 0), length);
|
||||||
PROTECT(t, code);
|
PROTECT(t, code);
|
||||||
|
|
||||||
unsigned ehtLength = s.read2();
|
unsigned ehtLength = s.read2();
|
||||||
if (ehtLength) {
|
if (ehtLength) {
|
||||||
object eht = makeExceptionHandlerTable(t, ehtLength, false);
|
object eht = makeExceptionHandlerTable(t, ehtLength);
|
||||||
for (unsigned i = 0; i < ehtLength; ++i) {
|
for (unsigned i = 0; i < ehtLength; ++i) {
|
||||||
ExceptionHandler* eh = exceptionHandlerTableBody(t, eht, i);
|
ExceptionHandler* eh = exceptionHandlerTableBody(t, eht, i);
|
||||||
exceptionHandlerStart(eh) = s.read2();
|
exceptionHandlerStart(eh) = s.read2();
|
||||||
@ -997,7 +1002,7 @@ parseCode(Thread* t, Stream& s, object pool)
|
|||||||
&byteArrayBody(t, name, 0)) == 0)
|
&byteArrayBody(t, name, 0)) == 0)
|
||||||
{
|
{
|
||||||
unsigned lntLength = s.read2();
|
unsigned lntLength = s.read2();
|
||||||
object lnt = makeLineNumberTable(t, lntLength, false);
|
object lnt = makeLineNumberTable(t, lntLength);
|
||||||
for (unsigned i = 0; i < lntLength; ++i) {
|
for (unsigned i = 0; i < lntLength; ++i) {
|
||||||
LineNumber* ln = lineNumberTableBody(t, lnt, i);
|
LineNumber* ln = lineNumberTableBody(t, lnt, i);
|
||||||
lineNumberIp(ln) = s.read2();
|
lineNumberIp(ln) = s.read2();
|
||||||
@ -1094,7 +1099,7 @@ parseMethodTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
|
|
||||||
unsigned count = s.read2();
|
unsigned count = s.read2();
|
||||||
if (count) {
|
if (count) {
|
||||||
object methodTable = makeArray(t, count, true);
|
object methodTable = makeArray(t, count);
|
||||||
PROTECT(t, methodTable);
|
PROTECT(t, methodTable);
|
||||||
|
|
||||||
for (unsigned i = 0; i < count; ++i) {
|
for (unsigned i = 0; i < count; ++i) {
|
||||||
@ -1199,13 +1204,13 @@ parseMethodTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
} else {
|
} else {
|
||||||
// apparently, Object does not have any virtual methods. We
|
// apparently, Object does not have any virtual methods. We
|
||||||
// give it a vtable anyway so code doesn't break elsewhere.
|
// give it a vtable anyway so code doesn't break elsewhere.
|
||||||
object vtable = makeArray(t, 0, false);
|
object vtable = makeArray(t, 0);
|
||||||
set(t, class_, ClassVirtualTable, vtable);
|
set(t, class_, ClassVirtualTable, vtable);
|
||||||
}
|
}
|
||||||
} else if (virtualCount) {
|
} else if (virtualCount) {
|
||||||
// generate class vtable
|
// generate class vtable
|
||||||
|
|
||||||
object vtable = makeArray(t, virtualCount, true);
|
object vtable = makeArray(t, virtualCount);
|
||||||
|
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
if (classFlags(t, class_) & ACC_INTERFACE) {
|
if (classFlags(t, class_) & ACC_INTERFACE) {
|
||||||
@ -1384,7 +1389,7 @@ makeArrayClass(Thread* t, object spec)
|
|||||||
const char* elementSpecStart = s;
|
const char* elementSpecStart = s;
|
||||||
while (*s and *s != ';') ++ s;
|
while (*s and *s != ';') ++ s;
|
||||||
|
|
||||||
elementSpec = makeByteArray(t, s - elementSpecStart + 1, false);
|
elementSpec = makeByteArray(t, s - elementSpecStart + 1);
|
||||||
memcpy(&byteArrayBody(t, elementSpec, 0),
|
memcpy(&byteArrayBody(t, elementSpec, 0),
|
||||||
&byteArrayBody(t, spec, elementSpecStart - start),
|
&byteArrayBody(t, spec, elementSpecStart - start),
|
||||||
s - elementSpecStart);
|
s - elementSpecStart);
|
||||||
@ -1394,7 +1399,7 @@ makeArrayClass(Thread* t, object spec)
|
|||||||
default:
|
default:
|
||||||
if (dimensions > 1) {
|
if (dimensions > 1) {
|
||||||
char c = *s;
|
char c = *s;
|
||||||
elementSpec = makeByteArray(t, 3, false);
|
elementSpec = makeByteArray(t, 3);
|
||||||
byteArrayBody(t, elementSpec, 0) = '[';
|
byteArrayBody(t, elementSpec, 0) = '[';
|
||||||
byteArrayBody(t, elementSpec, 1) = c;
|
byteArrayBody(t, elementSpec, 1) = c;
|
||||||
byteArrayBody(t, elementSpec, 2) = 0;
|
byteArrayBody(t, elementSpec, 2) = 0;
|
||||||
@ -1460,7 +1465,7 @@ bootClass(Thread* t, Machine::Type type, int superType, uint32_t objectMask,
|
|||||||
{
|
{
|
||||||
mask = classObjectMask(t, arrayBody(t, t->m->types, superType));
|
mask = classObjectMask(t, arrayBody(t, t->m->types, superType));
|
||||||
} else {
|
} else {
|
||||||
mask = makeIntArray(t, 1, false);
|
mask = makeIntArray(t, 1);
|
||||||
intArrayBody(t, mask, 0) = objectMask;
|
intArrayBody(t, mask, 0) = objectMask;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -1491,7 +1496,7 @@ bootJavaClass(Thread* t, Machine::Type type, int superType, const char* name,
|
|||||||
if (vtableLength >= 0) {
|
if (vtableLength >= 0) {
|
||||||
PROTECT(t, class_);
|
PROTECT(t, class_);
|
||||||
|
|
||||||
vtable = makeArray(t, vtableLength, false);
|
vtable = makeArray(t, vtableLength);
|
||||||
for (int i = 0; i < vtableLength; ++ i) {
|
for (int i = 0; i < vtableLength; ++ i) {
|
||||||
arrayBody(t, vtable, i) = bootMethod;
|
arrayBody(t, vtable, i) = bootMethod;
|
||||||
}
|
}
|
||||||
@ -1514,11 +1519,9 @@ boot(Thread* t)
|
|||||||
m->unsafe = true;
|
m->unsafe = true;
|
||||||
|
|
||||||
m->loader = allocate(t, sizeof(void*) * 3, true);
|
m->loader = allocate(t, sizeof(void*) * 3, true);
|
||||||
memset(m->loader, 0, sizeof(void*) * 2);
|
|
||||||
|
|
||||||
m->types = allocate(t, pad((TypeCount + 2) * BytesPerWord), true);
|
m->types = allocate(t, pad((TypeCount + 2) * BytesPerWord), true);
|
||||||
arrayLength(t, m->types) = TypeCount;
|
arrayLength(t, m->types) = TypeCount;
|
||||||
memset(&arrayBody(t, m->types, 0), 0, TypeCount * BytesPerWord);
|
|
||||||
|
|
||||||
#include "type-initializations.cpp"
|
#include "type-initializations.cpp"
|
||||||
|
|
||||||
@ -1578,7 +1581,7 @@ boot(Thread* t)
|
|||||||
|
|
||||||
m->processor->boot(t, 0);
|
m->processor->boot(t, 0);
|
||||||
|
|
||||||
{ object bootCode = makeCode(t, 0, 0, 0, 0, 0, 1, false);
|
{ object bootCode = makeCode(t, 0, 0, 0, 0, 0, 1);
|
||||||
codeBody(t, bootCode, 0) = impdep1;
|
codeBody(t, bootCode, 0) = impdep1;
|
||||||
object bootMethod = makeMethod
|
object bootMethod = makeMethod
|
||||||
(t, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, bootCode, 0);
|
(t, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, bootCode, 0);
|
||||||
@ -1792,6 +1795,8 @@ Thread::Thread(Machine* m, object javaThread, Thread* parent):
|
|||||||
void
|
void
|
||||||
Thread::init()
|
Thread::init()
|
||||||
{
|
{
|
||||||
|
memset(defaultHeap, 0, ThreadHeapSizeInBytes);
|
||||||
|
|
||||||
if (parent == 0) {
|
if (parent == 0) {
|
||||||
assert(this, m->rootThread == 0);
|
assert(this, m->rootThread == 0);
|
||||||
assert(this, javaThread == 0);
|
assert(this, javaThread == 0);
|
||||||
@ -1826,7 +1831,7 @@ Thread::init()
|
|||||||
|
|
||||||
m->monitorMap = makeWeakHashMap(this, 0, 0);
|
m->monitorMap = makeWeakHashMap(this, 0, 0);
|
||||||
|
|
||||||
m->jniMethodTable = makeVector(this, 0, 0, false);
|
m->jniMethodTable = makeVector(this, 0, 0);
|
||||||
|
|
||||||
m->localThread->set(this);
|
m->localThread->set(this);
|
||||||
} else {
|
} else {
|
||||||
@ -2063,7 +2068,10 @@ allocate3(Thread* t, Allocator* allocator, Machine::AllocationType type,
|
|||||||
if (t->m->heapPoolIndex < ThreadHeapPoolSize) {
|
if (t->m->heapPoolIndex < ThreadHeapPoolSize) {
|
||||||
t->heap = static_cast<uintptr_t*>
|
t->heap = static_cast<uintptr_t*>
|
||||||
(t->m->heap->tryAllocate(ThreadHeapSizeInBytes));
|
(t->m->heap->tryAllocate(ThreadHeapSizeInBytes));
|
||||||
|
|
||||||
if (t->heap) {
|
if (t->heap) {
|
||||||
|
memset(t->heap, 0, ThreadHeapSizeInBytes);
|
||||||
|
|
||||||
t->m->heapPool[t->m->heapPoolIndex++] = t->heap;
|
t->m->heapPool[t->m->heapPoolIndex++] = t->heap;
|
||||||
t->heapOffset += t->heapIndex;
|
t->heapOffset += t->heapIndex;
|
||||||
t->heapIndex = 0;
|
t->heapIndex = 0;
|
||||||
@ -2099,6 +2107,8 @@ allocate3(Thread* t, Allocator* allocator, Machine::AllocationType type,
|
|||||||
(t->m->heap->allocateFixed
|
(t->m->heap->allocateFixed
|
||||||
(allocator, ceiling(sizeInBytes, BytesPerWord), objectMask, &total));
|
(allocator, ceiling(sizeInBytes, BytesPerWord), objectMask, &total));
|
||||||
|
|
||||||
|
memset(o, 0, sizeInBytes);
|
||||||
|
|
||||||
cast<uintptr_t>(o, 0) = FixedMark;
|
cast<uintptr_t>(o, 0) = FixedMark;
|
||||||
|
|
||||||
t->m->fixedFootprint += total;
|
t->m->fixedFootprint += total;
|
||||||
@ -2112,6 +2122,8 @@ allocate3(Thread* t, Allocator* allocator, Machine::AllocationType type,
|
|||||||
(t->m->heap->allocateImmortalFixed
|
(t->m->heap->allocateImmortalFixed
|
||||||
(allocator, ceiling(sizeInBytes, BytesPerWord), objectMask, &total));
|
(allocator, ceiling(sizeInBytes, BytesPerWord), objectMask, &total));
|
||||||
|
|
||||||
|
memset(o, 0, sizeInBytes);
|
||||||
|
|
||||||
cast<uintptr_t>(o, 0) = FixedMark;
|
cast<uintptr_t>(o, 0) = FixedMark;
|
||||||
|
|
||||||
return o;
|
return o;
|
||||||
@ -2376,8 +2388,7 @@ parseClass(Thread* t, const uint8_t* data, unsigned size)
|
|||||||
0, // methods
|
0, // methods
|
||||||
0, // static table
|
0, // static table
|
||||||
t->m->loader,
|
t->m->loader,
|
||||||
0, // vtable length
|
0);// vtable length
|
||||||
false);
|
|
||||||
PROTECT(t, class_);
|
PROTECT(t, class_);
|
||||||
|
|
||||||
unsigned super = s.read2();
|
unsigned super = s.read2();
|
||||||
@ -2526,13 +2537,13 @@ resolveObjectArrayClass(Thread* t, object elementSpec)
|
|||||||
|
|
||||||
object spec;
|
object spec;
|
||||||
if (byteArrayBody(t, elementSpec, 0) == '[') {
|
if (byteArrayBody(t, elementSpec, 0) == '[') {
|
||||||
spec = makeByteArray(t, byteArrayLength(t, elementSpec) + 1, false);
|
spec = makeByteArray(t, byteArrayLength(t, elementSpec) + 1);
|
||||||
byteArrayBody(t, spec, 0) = '[';
|
byteArrayBody(t, spec, 0) = '[';
|
||||||
memcpy(&byteArrayBody(t, spec, 1),
|
memcpy(&byteArrayBody(t, spec, 1),
|
||||||
&byteArrayBody(t, elementSpec, 0),
|
&byteArrayBody(t, elementSpec, 0),
|
||||||
byteArrayLength(t, elementSpec));
|
byteArrayLength(t, elementSpec));
|
||||||
} else {
|
} else {
|
||||||
spec = makeByteArray(t, byteArrayLength(t, elementSpec) + 3, false);
|
spec = makeByteArray(t, byteArrayLength(t, elementSpec) + 3);
|
||||||
byteArrayBody(t, spec, 0) = '[';
|
byteArrayBody(t, spec, 0) = '[';
|
||||||
byteArrayBody(t, spec, 1) = 'L';
|
byteArrayBody(t, spec, 1) = 'L';
|
||||||
memcpy(&byteArrayBody(t, spec, 2),
|
memcpy(&byteArrayBody(t, spec, 2),
|
||||||
@ -2546,12 +2557,12 @@ resolveObjectArrayClass(Thread* t, object elementSpec)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
makeObjectArray(Thread* t, object elementClass, unsigned count, bool clear)
|
makeObjectArray(Thread* t, object elementClass, unsigned count)
|
||||||
{
|
{
|
||||||
object arrayClass = resolveObjectArrayClass(t, className(t, elementClass));
|
object arrayClass = resolveObjectArrayClass(t, className(t, elementClass));
|
||||||
PROTECT(t, arrayClass);
|
PROTECT(t, arrayClass);
|
||||||
|
|
||||||
object array = makeArray(t, count, clear);
|
object array = makeArray(t, count);
|
||||||
setObjectClass(t, array, arrayClass);
|
setObjectClass(t, array, arrayClass);
|
||||||
|
|
||||||
return array;
|
return array;
|
||||||
@ -2900,7 +2911,7 @@ makeTrace(Thread* t, Processor::StackWalker* walker)
|
|||||||
|
|
||||||
virtual bool visit(Processor::StackWalker* walker) {
|
virtual bool visit(Processor::StackWalker* walker) {
|
||||||
if (trace == 0) {
|
if (trace == 0) {
|
||||||
trace = makeArray(t, walker->count(), true);
|
trace = makeArray(t, walker->count());
|
||||||
}
|
}
|
||||||
|
|
||||||
object e = makeTraceElement(t, walker->method(), walker->ip());
|
object e = makeTraceElement(t, walker->method(), walker->ip());
|
||||||
@ -2918,7 +2929,7 @@ makeTrace(Thread* t, Processor::StackWalker* walker)
|
|||||||
|
|
||||||
walker->walk(&v);
|
walker->walk(&v);
|
||||||
|
|
||||||
return v.trace ? v.trace : makeArray(t, 0, true);
|
return v.trace ? v.trace : makeArray(t, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
@ -2939,7 +2950,7 @@ makeTrace(Thread* t, Thread* target)
|
|||||||
|
|
||||||
t->m->processor->walkStack(target, &v);
|
t->m->processor->walkStack(target, &v);
|
||||||
|
|
||||||
return v.trace ? v.trace : makeArray(t, 0, true);
|
return v.trace ? v.trace : makeArray(t, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1490,6 +1490,9 @@ ensure(Thread* t, unsigned sizeInBytes)
|
|||||||
expect(t, t->backupHeap == 0);
|
expect(t, t->backupHeap == 0);
|
||||||
t->backupHeap = static_cast<uintptr_t*>
|
t->backupHeap = static_cast<uintptr_t*>
|
||||||
(t->m->heap->allocate(pad(sizeInBytes)));
|
(t->m->heap->allocate(pad(sizeInBytes)));
|
||||||
|
|
||||||
|
memset(t->backupHeap, 0, sizeInBytes);
|
||||||
|
|
||||||
t->backupHeapIndex = 0;
|
t->backupHeapIndex = 0;
|
||||||
t->backupHeapSizeInWords = ceiling(sizeInBytes, BytesPerWord);
|
t->backupHeapSizeInWords = ceiling(sizeInBytes, BytesPerWord);
|
||||||
}
|
}
|
||||||
@ -1763,8 +1766,6 @@ makeNew(Thread* t, object class_)
|
|||||||
unsigned sizeInBytes = pad(classFixedSize(t, class_));
|
unsigned sizeInBytes = pad(classFixedSize(t, class_));
|
||||||
object instance = allocate(t, sizeInBytes, classObjectMask(t, class_));
|
object instance = allocate(t, sizeInBytes, classObjectMask(t, class_));
|
||||||
setObjectClass(t, instance, class_);
|
setObjectClass(t, instance, class_);
|
||||||
memset(&cast<object>(instance, BytesPerWord), 0,
|
|
||||||
sizeInBytes - BytesPerWord);
|
|
||||||
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
@ -2068,7 +2069,7 @@ initClass(Thread* t, object c)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
makeObjectArray(Thread* t, object elementClass, unsigned count, bool clear);
|
makeObjectArray(Thread* t, object elementClass, unsigned count);
|
||||||
|
|
||||||
object
|
object
|
||||||
findInTable(Thread* t, object table, object name, object spec,
|
findInTable(Thread* t, object table, object name, object spec,
|
||||||
@ -2358,9 +2359,9 @@ singletonValue(Thread* t, object singleton, unsigned index)
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline object
|
inline object
|
||||||
makeSingleton(Thread* t, unsigned count)
|
makeSingletonOfSize(Thread* t, unsigned count)
|
||||||
{
|
{
|
||||||
object o = makeSingleton(t, count + singletonMaskSize(count), true);
|
object o = makeSingleton(t, count + singletonMaskSize(count));
|
||||||
assert(t, singletonLength(t, o) == count + singletonMaskSize(t, o));
|
assert(t, singletonLength(t, o) == count + singletonMaskSize(t, o));
|
||||||
if (count) {
|
if (count) {
|
||||||
singletonMask(t, o)[0] = 1;
|
singletonMask(t, o)[0] = 1;
|
||||||
|
@ -167,8 +167,7 @@ populateMultiArray(Thread* t, object array, int32_t* counts,
|
|||||||
object spec = className(t, objectClass(t, array));
|
object spec = className(t, objectClass(t, array));
|
||||||
PROTECT(t, spec);
|
PROTECT(t, spec);
|
||||||
|
|
||||||
object elementSpec = makeByteArray
|
object elementSpec = makeByteArray(t, byteArrayLength(t, spec) - 1);
|
||||||
(t, byteArrayLength(t, spec) - 1, false);
|
|
||||||
memcpy(&byteArrayBody(t, elementSpec, 0),
|
memcpy(&byteArrayBody(t, elementSpec, 0),
|
||||||
&byteArrayBody(t, spec, 1),
|
&byteArrayBody(t, spec, 1),
|
||||||
byteArrayLength(t, spec) - 1);
|
byteArrayLength(t, spec) - 1);
|
||||||
@ -177,7 +176,7 @@ populateMultiArray(Thread* t, object array, int32_t* counts,
|
|||||||
PROTECT(t, class_);
|
PROTECT(t, class_);
|
||||||
|
|
||||||
for (int32_t i = 0; i < counts[index]; ++i) {
|
for (int32_t i = 0; i < counts[index]; ++i) {
|
||||||
object a = makeArray(t, counts[index + 1], true);
|
object a = makeArray(t, counts[index + 1]);
|
||||||
setObjectClass(t, a, class_);
|
setObjectClass(t, a, class_);
|
||||||
set(t, array, ArrayBody + (i * BytesPerWord), a);
|
set(t, array, ArrayBody + (i * BytesPerWord), a);
|
||||||
|
|
||||||
|
@ -1797,10 +1797,6 @@ writeConstructorParameters(Output* out, Object* t)
|
|||||||
out->write(obfuscate(memberName(m)));
|
out->write(obfuscate(memberName(m)));
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case Object::Array: {
|
|
||||||
out->write(", bool clear");
|
|
||||||
} break;
|
|
||||||
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1817,10 +1813,6 @@ writeConstructorArguments(Output* out, Object* t)
|
|||||||
out->write(obfuscate(memberName(m)));
|
out->write(obfuscate(memberName(m)));
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case Object::Array: {
|
|
||||||
out->write(", clear");
|
|
||||||
} break;
|
|
||||||
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1840,17 +1832,6 @@ writeConstructorInitializations(Output* out, Object* t)
|
|||||||
out->write(";\n");
|
out->write(";\n");
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case Object::Array: {
|
|
||||||
out->write(" if (clear and length) memset(");
|
|
||||||
if (memberTypeObject(m) == 0) {
|
|
||||||
out->write("&");
|
|
||||||
}
|
|
||||||
writeAccessorName(out, m);
|
|
||||||
out->write("(t, o, 0), 0, length * ");
|
|
||||||
out->write(arrayElementSize(m));
|
|
||||||
out->write(");\n");
|
|
||||||
} break;
|
|
||||||
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -358,7 +358,7 @@ hashMapResize(Thread* t, object map, uint32_t (*hash)(Thread*, object),
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
newArray = makeArray(t, newLength, true);
|
newArray = makeArray(t, newLength);
|
||||||
|
|
||||||
if (oldArray != hashMapArray(t, map)) {
|
if (oldArray != hashMapArray(t, map)) {
|
||||||
// a resize was performed during a GC via the makeArray call
|
// a resize was performed during a GC via the makeArray call
|
||||||
@ -525,7 +525,7 @@ vectorAppend(Thread* t, object vector, object value)
|
|||||||
PROTECT(t, value);
|
PROTECT(t, value);
|
||||||
|
|
||||||
object newVector = makeVector
|
object newVector = makeVector
|
||||||
(t, vectorSize(t, vector), max(16, vectorSize(t, vector) * 2), false);
|
(t, vectorSize(t, vector), max(16, vectorSize(t, vector) * 2));
|
||||||
|
|
||||||
if (vectorSize(t, vector)) {
|
if (vectorSize(t, vector)) {
|
||||||
memcpy(&vectorBody(t, newVector, 0),
|
memcpy(&vectorBody(t, newVector, 0),
|
||||||
|
Loading…
Reference in New Issue
Block a user