mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-18 04:14:50 -08:00
Wasm: don't generate class metadata if it's not used. Don't generate names and call site metadata in minified mode
This commit is contained in:
parent
3f2c52000f
commit
0e7c1e5ef9
|
@ -129,6 +129,7 @@ import org.teavm.model.MethodReader;
|
||||||
import org.teavm.model.MethodReference;
|
import org.teavm.model.MethodReference;
|
||||||
import org.teavm.model.Program;
|
import org.teavm.model.Program;
|
||||||
import org.teavm.model.ValueType;
|
import org.teavm.model.ValueType;
|
||||||
|
import org.teavm.model.analysis.ClassMetadataRequirements;
|
||||||
import org.teavm.model.classes.TagRegistry;
|
import org.teavm.model.classes.TagRegistry;
|
||||||
import org.teavm.model.classes.VirtualTableBuilder;
|
import org.teavm.model.classes.VirtualTableBuilder;
|
||||||
import org.teavm.model.classes.VirtualTableProvider;
|
import org.teavm.model.classes.VirtualTableProvider;
|
||||||
|
@ -184,6 +185,7 @@ public class WasmTarget implements TeaVMTarget, TeaVMWasmHost {
|
||||||
private CheckInstructionTransformation checkTransformation = new CheckInstructionTransformation();
|
private CheckInstructionTransformation checkTransformation = new CheckInstructionTransformation();
|
||||||
private int minHeapSize = 2 * 1024 * 1024;
|
private int minHeapSize = 2 * 1024 * 1024;
|
||||||
private int maxHeapSize = 128 * 1024 * 1024;
|
private int maxHeapSize = 128 * 1024 * 1024;
|
||||||
|
private boolean obfuscated;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setController(TeaVMTargetController controller) {
|
public void setController(TeaVMTargetController controller) {
|
||||||
|
@ -272,6 +274,10 @@ public class WasmTarget implements TeaVMTarget, TeaVMWasmHost {
|
||||||
this.maxHeapSize = maxHeapSize;
|
this.maxHeapSize = maxHeapSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setObfuscated(boolean obfuscated) {
|
||||||
|
this.obfuscated = obfuscated;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void contributeDependencies(DependencyAnalyzer dependencyAnalyzer) {
|
public void contributeDependencies(DependencyAnalyzer dependencyAnalyzer) {
|
||||||
for (Class<?> type : Arrays.asList(int.class, long.class, float.class, double.class)) {
|
for (Class<?> type : Arrays.asList(int.class, long.class, float.class, double.class)) {
|
||||||
|
@ -374,8 +380,10 @@ public class WasmTarget implements TeaVMTarget, TeaVMWasmHost {
|
||||||
BinaryWriter binaryWriter = new BinaryWriter(256);
|
BinaryWriter binaryWriter = new BinaryWriter(256);
|
||||||
NameProvider names = new NameProviderWithSpecialNames(new WasmNameProvider(),
|
NameProvider names = new NameProviderWithSpecialNames(new WasmNameProvider(),
|
||||||
controller.getUnprocessedClassSource());
|
controller.getUnprocessedClassSource());
|
||||||
|
ClassMetadataRequirements metadataRequirements = new ClassMetadataRequirements(controller.getDependencyInfo());
|
||||||
WasmClassGenerator classGenerator = new WasmClassGenerator(classes, controller.getUnprocessedClassSource(),
|
WasmClassGenerator classGenerator = new WasmClassGenerator(classes, controller.getUnprocessedClassSource(),
|
||||||
vtableProvider, tagRegistry, binaryWriter, names);
|
vtableProvider, tagRegistry, binaryWriter, names, metadataRequirements,
|
||||||
|
controller.getClassInitializerInfo());
|
||||||
|
|
||||||
Decompiler decompiler = new Decompiler(classes, new HashSet<>(), false);
|
Decompiler decompiler = new Decompiler(classes, new HashSet<>(), false);
|
||||||
WasmStringPool stringPool = classGenerator.getStringPool();
|
WasmStringPool stringPool = classGenerator.getStringPool();
|
||||||
|
@ -417,7 +425,7 @@ public class WasmTarget implements TeaVMTarget, TeaVMWasmHost {
|
||||||
context.addIntrinsic(mutatorIntrinsic);
|
context.addIntrinsic(mutatorIntrinsic);
|
||||||
context.addIntrinsic(new ShadowStackIntrinsic());
|
context.addIntrinsic(new ShadowStackIntrinsic());
|
||||||
ExceptionHandlingIntrinsic exceptionHandlingIntrinsic = new ExceptionHandlingIntrinsic(binaryWriter,
|
ExceptionHandlingIntrinsic exceptionHandlingIntrinsic = new ExceptionHandlingIntrinsic(binaryWriter,
|
||||||
classGenerator, stringPool);
|
classGenerator, stringPool, obfuscated);
|
||||||
context.addIntrinsic(exceptionHandlingIntrinsic);
|
context.addIntrinsic(exceptionHandlingIntrinsic);
|
||||||
|
|
||||||
WasmGenerator generator = new WasmGenerator(decompiler, classes, context, classGenerator, binaryWriter);
|
WasmGenerator generator = new WasmGenerator(decompiler, classes, context, classGenerator, binaryWriter);
|
||||||
|
@ -471,7 +479,7 @@ public class WasmTarget implements TeaVMTarget, TeaVMWasmHost {
|
||||||
}
|
}
|
||||||
|
|
||||||
WasmBinaryWriter writer = new WasmBinaryWriter();
|
WasmBinaryWriter writer = new WasmBinaryWriter();
|
||||||
WasmBinaryRenderer renderer = new WasmBinaryRenderer(writer, version);
|
WasmBinaryRenderer renderer = new WasmBinaryRenderer(writer, version, obfuscated);
|
||||||
renderer.render(module);
|
renderer.render(module);
|
||||||
|
|
||||||
try (OutputStream output = buildTarget.createResource(outputName)) {
|
try (OutputStream output = buildTarget.createResource(outputName)) {
|
||||||
|
|
|
@ -62,11 +62,14 @@ public class CallSiteBinaryGenerator {
|
||||||
private WasmClassGenerator classGenerator;
|
private WasmClassGenerator classGenerator;
|
||||||
private WasmStringPool stringPool;
|
private WasmStringPool stringPool;
|
||||||
private ObjectIntMap<String> stringIndirectPointerCache = new ObjectIntHashMap<>();
|
private ObjectIntMap<String> stringIndirectPointerCache = new ObjectIntHashMap<>();
|
||||||
|
private boolean obfuscated;
|
||||||
|
|
||||||
public CallSiteBinaryGenerator(BinaryWriter writer, WasmClassGenerator classGenerator, WasmStringPool stringPool) {
|
public CallSiteBinaryGenerator(BinaryWriter writer, WasmClassGenerator classGenerator, WasmStringPool stringPool,
|
||||||
|
boolean obfuscated) {
|
||||||
this.writer = writer;
|
this.writer = writer;
|
||||||
this.classGenerator = classGenerator;
|
this.classGenerator = classGenerator;
|
||||||
this.stringPool = stringPool;
|
this.stringPool = stringPool;
|
||||||
|
this.obfuscated = obfuscated;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int writeCallSites(List<? extends CallSiteDescriptor> callSites) {
|
public int writeCallSites(List<? extends CallSiteDescriptor> callSites) {
|
||||||
|
@ -120,6 +123,17 @@ public class CallSiteBinaryGenerator {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!obfuscated) {
|
||||||
|
binaryCallSite.setAddress(CALL_SITE_LOCATION,
|
||||||
|
generateLocations(methodLocationCache, locationCache, callSite));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return firstCallSite;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int generateLocations(ObjectIntMap<MethodLocation> methodLocationCache,
|
||||||
|
ObjectIntMap<LocationList> locationCache, CallSiteDescriptor callSite) {
|
||||||
CallSiteLocation[] locations = callSite.getLocations();
|
CallSiteLocation[] locations = callSite.getLocations();
|
||||||
LocationList prevList = null;
|
LocationList prevList = null;
|
||||||
int locationAddress = 0;
|
int locationAddress = 0;
|
||||||
|
@ -132,8 +146,8 @@ public class CallSiteBinaryGenerator {
|
||||||
locationAddress = writer.append(binaryLocation);
|
locationAddress = writer.append(binaryLocation);
|
||||||
locationCache.put(list, locationAddress);
|
locationCache.put(list, locationAddress);
|
||||||
CallSiteLocation location = list.location;
|
CallSiteLocation location = list.location;
|
||||||
MethodLocation methodLocation = new MethodLocation(location.getFileName(), location.getClassName(),
|
MethodLocation methodLocation = new MethodLocation(location.getFileName(),
|
||||||
location.getMethodName());
|
location.getClassName(), location.getMethodName());
|
||||||
int methodLocationAddress = methodLocationCache.getOrDefault(methodLocation, -1);
|
int methodLocationAddress = methodLocationCache.getOrDefault(methodLocation, -1);
|
||||||
if (methodLocationAddress < 0) {
|
if (methodLocationAddress < 0) {
|
||||||
DataValue binaryMethodLocation = methodLocationStructure.createValue();
|
DataValue binaryMethodLocation = methodLocationStructure.createValue();
|
||||||
|
@ -160,10 +174,7 @@ public class CallSiteBinaryGenerator {
|
||||||
previousLocationAddress = locationAddress;
|
previousLocationAddress = locationAddress;
|
||||||
}
|
}
|
||||||
|
|
||||||
binaryCallSite.setAddress(CALL_SITE_LOCATION, locationAddress);
|
return locationAddress;
|
||||||
}
|
|
||||||
|
|
||||||
return firstCallSite;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getStringIndirectPointer(String str) {
|
private int getStringIndirectPointer(String str) {
|
||||||
|
|
|
@ -43,6 +43,8 @@ import org.teavm.model.FieldReference;
|
||||||
import org.teavm.model.MethodDescriptor;
|
import org.teavm.model.MethodDescriptor;
|
||||||
import org.teavm.model.MethodReference;
|
import org.teavm.model.MethodReference;
|
||||||
import org.teavm.model.ValueType;
|
import org.teavm.model.ValueType;
|
||||||
|
import org.teavm.model.analysis.ClassInitializerInfo;
|
||||||
|
import org.teavm.model.analysis.ClassMetadataRequirements;
|
||||||
import org.teavm.model.classes.TagRegistry;
|
import org.teavm.model.classes.TagRegistry;
|
||||||
import org.teavm.model.classes.VirtualTable;
|
import org.teavm.model.classes.VirtualTable;
|
||||||
import org.teavm.model.classes.VirtualTableEntry;
|
import org.teavm.model.classes.VirtualTableEntry;
|
||||||
|
@ -91,6 +93,8 @@ public class WasmClassGenerator {
|
||||||
private int staticGcRootsAddress;
|
private int staticGcRootsAddress;
|
||||||
private int classesAddress;
|
private int classesAddress;
|
||||||
private int classCount;
|
private int classCount;
|
||||||
|
private ClassMetadataRequirements metadataRequirements;
|
||||||
|
private ClassInitializerInfo classInitializerInfo;
|
||||||
|
|
||||||
private static final int CLASS_SIZE = 1;
|
private static final int CLASS_SIZE = 1;
|
||||||
private static final int CLASS_FLAGS = 2;
|
private static final int CLASS_FLAGS = 2;
|
||||||
|
@ -110,7 +114,8 @@ public class WasmClassGenerator {
|
||||||
|
|
||||||
public WasmClassGenerator(ClassReaderSource processedClassSource, ClassReaderSource classSource,
|
public WasmClassGenerator(ClassReaderSource processedClassSource, ClassReaderSource classSource,
|
||||||
VirtualTableProvider vtableProvider, TagRegistry tagRegistry, BinaryWriter binaryWriter,
|
VirtualTableProvider vtableProvider, TagRegistry tagRegistry, BinaryWriter binaryWriter,
|
||||||
NameProvider names) {
|
NameProvider names, ClassMetadataRequirements metadataRequirements,
|
||||||
|
ClassInitializerInfo classInitializerInfo) {
|
||||||
this.processedClassSource = processedClassSource;
|
this.processedClassSource = processedClassSource;
|
||||||
this.classSource = classSource;
|
this.classSource = classSource;
|
||||||
this.vtableProvider = vtableProvider;
|
this.vtableProvider = vtableProvider;
|
||||||
|
@ -118,6 +123,8 @@ public class WasmClassGenerator {
|
||||||
this.binaryWriter = binaryWriter;
|
this.binaryWriter = binaryWriter;
|
||||||
this.stringPool = new WasmStringPool(this, binaryWriter);
|
this.stringPool = new WasmStringPool(this, binaryWriter);
|
||||||
this.names = names;
|
this.names = names;
|
||||||
|
this.metadataRequirements = metadataRequirements;
|
||||||
|
this.classInitializerInfo = classInitializerInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public WasmStringPool getStringPool() {
|
public WasmStringPool getStringPool() {
|
||||||
|
@ -259,6 +266,7 @@ public class WasmClassGenerator {
|
||||||
: 0;
|
: 0;
|
||||||
|
|
||||||
String name = ((ValueType.Object) binaryData.type).getClassName();
|
String name = ((ValueType.Object) binaryData.type).getClassName();
|
||||||
|
ClassMetadataRequirements.Info requirements = metadataRequirements.getInfo(name);
|
||||||
int flags = 0;
|
int flags = 0;
|
||||||
|
|
||||||
VirtualTable vtable = vtableProvider.lookup(name);
|
VirtualTable vtable = vtableProvider.lookup(name);
|
||||||
|
@ -279,7 +287,8 @@ public class WasmClassGenerator {
|
||||||
int tag = ranges.stream().mapToInt(range -> range.lower).min().orElse(0);
|
int tag = ranges.stream().mapToInt(range -> range.lower).min().orElse(0);
|
||||||
header.setInt(CLASS_TAG, tag);
|
header.setInt(CLASS_TAG, tag);
|
||||||
header.setInt(CLASS_CANARY, RuntimeClass.computeCanary(occupiedSize, tag));
|
header.setInt(CLASS_CANARY, RuntimeClass.computeCanary(occupiedSize, tag));
|
||||||
header.setAddress(CLASS_NAME, stringPool.getStringPointer(name));
|
int nameAddress = requirements.name() ? stringPool.getStringPointer(name) : 0;
|
||||||
|
header.setAddress(CLASS_NAME, nameAddress);
|
||||||
header.setInt(CLASS_IS_INSTANCE, functionTable.size());
|
header.setInt(CLASS_IS_INSTANCE, functionTable.size());
|
||||||
functionTable.add(names.forSupertypeFunction(ValueType.object(name)));
|
functionTable.add(names.forSupertypeFunction(ValueType.object(name)));
|
||||||
header.setAddress(CLASS_PARENT, parentPtr);
|
header.setAddress(CLASS_PARENT, parentPtr);
|
||||||
|
@ -287,14 +296,16 @@ public class WasmClassGenerator {
|
||||||
ClassReader cls = processedClassSource.get(name);
|
ClassReader cls = processedClassSource.get(name);
|
||||||
|
|
||||||
if (cls != null) {
|
if (cls != null) {
|
||||||
if (cls.getSimpleName() != null) {
|
if (cls.getSimpleName() != null && requirements.simpleName()) {
|
||||||
header.setAddress(CLASS_SIMPLE_NAME, stringPool.getStringPointer(cls.getSimpleName()));
|
header.setAddress(CLASS_SIMPLE_NAME, stringPool.getStringPointer(cls.getSimpleName()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cls.getOwnerName() != null && processedClassSource.get(cls.getOwnerName()) != null) {
|
if (cls.getOwnerName() != null && processedClassSource.get(cls.getOwnerName()) != null
|
||||||
|
&& requirements.enclosingClass()) {
|
||||||
header.setAddress(CLASS_ENCLOSING_CLASS, getClassPointer(ValueType.object(cls.getOwnerName())));
|
header.setAddress(CLASS_ENCLOSING_CLASS, getClassPointer(ValueType.object(cls.getOwnerName())));
|
||||||
}
|
}
|
||||||
if (cls.getDeclaringClassName() != null && processedClassSource.get(cls.getDeclaringClassName()) != null) {
|
if (cls.getDeclaringClassName() != null && processedClassSource.get(cls.getDeclaringClassName()) != null
|
||||||
|
&& requirements.declaringClass()) {
|
||||||
header.setAddress(CLASS_DECLARING_CLASS,
|
header.setAddress(CLASS_DECLARING_CLASS,
|
||||||
getClassPointer(ValueType.object(cls.getDeclaringClassName())));
|
getClassPointer(ValueType.object(cls.getDeclaringClassName())));
|
||||||
}
|
}
|
||||||
|
@ -332,7 +343,8 @@ public class WasmClassGenerator {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cls != null && binaryData.start >= 0
|
if (cls != null && binaryData.start >= 0
|
||||||
&& cls.getMethod(new MethodDescriptor("<clinit>", ValueType.VOID)) != null) {
|
&& cls.getMethod(new MethodDescriptor("<clinit>", ValueType.VOID)) != null
|
||||||
|
&& classInitializerInfo.isDynamicInitializer(name)) {
|
||||||
header.setInt(CLASS_INIT, functionTable.size());
|
header.setInt(CLASS_INIT, functionTable.size());
|
||||||
functionTable.add(names.forClassInitializer(name));
|
functionTable.add(names.forClassInitializer(name));
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -39,8 +39,8 @@ public class ExceptionHandlingIntrinsic implements WasmIntrinsic {
|
||||||
private List<WasmInt32Constant> constants = new ArrayList<>();
|
private List<WasmInt32Constant> constants = new ArrayList<>();
|
||||||
|
|
||||||
public ExceptionHandlingIntrinsic(BinaryWriter binaryWriter, WasmClassGenerator classGenerator,
|
public ExceptionHandlingIntrinsic(BinaryWriter binaryWriter, WasmClassGenerator classGenerator,
|
||||||
WasmStringPool stringPool) {
|
WasmStringPool stringPool, boolean obfuscated) {
|
||||||
callSiteBinaryGenerator = new CallSiteBinaryGenerator(binaryWriter, classGenerator, stringPool);
|
callSiteBinaryGenerator = new CallSiteBinaryGenerator(binaryWriter, classGenerator, stringPool, obfuscated);
|
||||||
this.classGenerator = classGenerator;
|
this.classGenerator = classGenerator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,10 +49,12 @@ public class WasmBinaryRenderer {
|
||||||
private List<WasmSignature> signatures = new ArrayList<>();
|
private List<WasmSignature> signatures = new ArrayList<>();
|
||||||
private Map<WasmSignature, Integer> signatureIndexes = new HashMap<>();
|
private Map<WasmSignature, Integer> signatureIndexes = new HashMap<>();
|
||||||
private Map<String, Integer> functionIndexes = new HashMap<>();
|
private Map<String, Integer> functionIndexes = new HashMap<>();
|
||||||
|
private boolean obfuscated;
|
||||||
|
|
||||||
public WasmBinaryRenderer(WasmBinaryWriter output, WasmBinaryVersion version) {
|
public WasmBinaryRenderer(WasmBinaryWriter output, WasmBinaryVersion version, boolean obfuscated) {
|
||||||
this.output = output;
|
this.output = output;
|
||||||
this.version = version;
|
this.version = version;
|
||||||
|
this.obfuscated = obfuscated;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void render(WasmModule module) {
|
public void render(WasmModule module) {
|
||||||
|
@ -73,8 +75,10 @@ public class WasmBinaryRenderer {
|
||||||
renderElement(module);
|
renderElement(module);
|
||||||
renderCode(module);
|
renderCode(module);
|
||||||
renderData(module);
|
renderData(module);
|
||||||
|
if (!obfuscated) {
|
||||||
renderNames(module);
|
renderNames(module);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void renderSignatures(WasmModule module) {
|
private void renderSignatures(WasmModule module) {
|
||||||
WasmBinaryWriter section = new WasmBinaryWriter();
|
WasmBinaryWriter section = new WasmBinaryWriter();
|
||||||
|
|
|
@ -332,6 +332,7 @@ public class TeaVMTool {
|
||||||
webAssemblyTarget.setVersion(wasmVersion);
|
webAssemblyTarget.setVersion(wasmVersion);
|
||||||
webAssemblyTarget.setMinHeapSize(minHeapSize);
|
webAssemblyTarget.setMinHeapSize(minHeapSize);
|
||||||
webAssemblyTarget.setMaxHeapSize(maxHeapSize);
|
webAssemblyTarget.setMaxHeapSize(maxHeapSize);
|
||||||
|
webAssemblyTarget.setObfuscated(minifying);
|
||||||
return webAssemblyTarget;
|
return webAssemblyTarget;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user