Wasm: fix issue with attempt to shrink heap after GC

This commit is contained in:
Alexey Andreev 2022-11-17 12:01:57 +01:00
parent 64ae44ee01
commit df98b411d0
3 changed files with 17 additions and 2 deletions
core/src/main/java/org/teavm
backend
c/intrinsic
wasm/intrinsics
runtime

View File

@ -39,6 +39,7 @@ public class GCIntrinsic implements Intrinsic {
case "resizeHeap": case "resizeHeap":
case "cardTable": case "cardTable":
case "writeBarrier": case "writeBarrier":
case "canShrinkHeap":
return true; return true;
default: default:
return false; return false;
@ -60,6 +61,10 @@ public class GCIntrinsic implements Intrinsic {
context.writer().print(")"); context.writer().print(")");
break; break;
case "canShrinkHeap":
context.writer().print("1");
break;
default: default:
context.includes().includePath("heaptrace.h"); context.includes().includePath("heaptrace.h");
context.writer().print("teavm_gc_").print(invocation.getMethod().getName()); context.writer().print("teavm_gc_").print(invocation.getMethod().getName());

View File

@ -72,6 +72,7 @@ public class GCIntrinsic implements WasmIntrinsic {
case "maxAvailableBytes": case "maxAvailableBytes":
case "resizeHeap": case "resizeHeap":
case "writeBarrier": case "writeBarrier":
case "canShrinkHeap":
return true; return true;
default: default:
return false; return false;
@ -131,6 +132,12 @@ public class GCIntrinsic implements WasmIntrinsic {
cardIndex); cardIndex);
return new WasmStoreInt32(1, card, new WasmInt32Constant(0), WasmInt32Subtype.INT8); return new WasmStoreInt32(1, card, new WasmInt32Constant(0), WasmInt32Subtype.INT8);
} }
case "canShrinkHeap": {
var expr = new WasmInt32Constant(0);
expr.setLocation(invocation.getLocation());
return expr;
}
default: default:
throw new IllegalArgumentException(invocation.getMethod().toString()); throw new IllegalArgumentException(invocation.getMethod().toString());
} }

View File

@ -67,6 +67,8 @@ public final class GC {
public static native void resizeHeap(long size); public static native void resizeHeap(long size);
public static native boolean canShrinkHeap();
private static native int regionSize(); private static native int regionSize();
public static native void writeBarrier(RuntimeObject object); public static native void writeBarrier(RuntimeObject object);
@ -183,7 +185,8 @@ public final class GC {
} }
if (!isFullGC) { if (!isFullGC) {
if (++youngGCCount >= 8 && isAboutToExpand(minRequestedSize)) { var youngGCLimit = canShrinkHeap() ? 2 : 8;
if (++youngGCCount >= youngGCLimit && isAboutToExpand(minRequestedSize)) {
triggerFullGC(); triggerFullGC();
doCollectGarbage(); doCollectGarbage();
youngGCCount = 0; youngGCCount = 0;
@ -1387,7 +1390,7 @@ public final class GC {
freeChunks++; freeChunks++;
totalChunks++; totalChunks++;
} }
} else { } else if (canShrinkHeap()) {
long minimumSize = lastChunk.toAddress().toLong() - heapAddress().toLong(); long minimumSize = lastChunk.toAddress().toLong() - heapAddress().toLong();
if (lastChunk.classReference != 0) { if (lastChunk.classReference != 0) {
minimumSize += objectSize(lastChunk); minimumSize += objectSize(lastChunk);