mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-08 16:04:10 -08:00
WASM: fix exception handling. Use if instead of switch after call site when possible
This commit is contained in:
parent
8a012178ed
commit
cbd74d41f4
|
@ -216,6 +216,10 @@ public class WasmTarget implements TeaVMTarget {
|
|||
int.class), null).use();
|
||||
dependencyChecker.linkMethod(new MethodReference(WasmRuntime.class, "getStackRootPointer", Address.class,
|
||||
Address.class), null).use();
|
||||
dependencyChecker.linkMethod(new MethodReference(WasmRuntime.class, "setExceptionHandlerId", Address.class,
|
||||
int.class, void.class), null).use();
|
||||
dependencyChecker.linkMethod(new MethodReference(WasmRuntime.class, "getCallSiteId", Address.class,
|
||||
int.class), null).use();
|
||||
|
||||
dependencyChecker.linkMethod(new MethodReference(Allocator.class, "allocate",
|
||||
RuntimeClass.class, Address.class), null).use();
|
||||
|
|
|
@ -32,6 +32,8 @@ import org.teavm.model.TryCatchBlock;
|
|||
import org.teavm.model.TryCatchJoint;
|
||||
import org.teavm.model.ValueType;
|
||||
import org.teavm.model.Variable;
|
||||
import org.teavm.model.instructions.BinaryBranchingCondition;
|
||||
import org.teavm.model.instructions.BinaryBranchingInstruction;
|
||||
import org.teavm.model.instructions.CloneArrayInstruction;
|
||||
import org.teavm.model.instructions.ConstructArrayInstruction;
|
||||
import org.teavm.model.instructions.ConstructInstruction;
|
||||
|
@ -240,7 +242,6 @@ public class ExceptionHandlingShadowStackContributor {
|
|||
|
||||
SwitchInstruction switchInsn = new SwitchInstruction();
|
||||
switchInsn.setCondition(handlerIdVariable);
|
||||
instructions.add(switchInsn);
|
||||
|
||||
if (next != null) {
|
||||
SwitchTableEntry continueExecutionEntry = new SwitchTableEntry();
|
||||
|
@ -280,6 +281,24 @@ public class ExceptionHandlingShadowStackContributor {
|
|||
switchInsn.setDefaultTarget(getDefaultExceptionHandler());
|
||||
}
|
||||
|
||||
if (switchInsn.getEntries().size() == 1) {
|
||||
SwitchTableEntry entry = switchInsn.getEntries().get(0);
|
||||
|
||||
IntegerConstantInstruction singleTestConstant = new IntegerConstantInstruction();
|
||||
singleTestConstant.setConstant(entry.getCondition());
|
||||
singleTestConstant.setReceiver(program.createVariable());
|
||||
instructions.add(singleTestConstant);
|
||||
|
||||
BinaryBranchingInstruction branching = new BinaryBranchingInstruction(BinaryBranchingCondition.EQUAL);
|
||||
branching.setConsequent(entry.getTarget());
|
||||
branching.setAlternative(switchInsn.getDefaultTarget());
|
||||
branching.setFirstOperand(switchInsn.getCondition());
|
||||
branching.setSecondOperand(singleTestConstant.getReceiver());
|
||||
instructions.add(branching);
|
||||
} else {
|
||||
instructions.add(switchInsn);
|
||||
}
|
||||
|
||||
return instructions;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user