summaryrefslogtreecommitdiff
path: root/src/tools/tool-options.h
diff options
context:
space:
mode:
authorThomas Lively <7121787+tlively@users.noreply.github.com>2022-06-28 21:11:31 -0700
committerGitHub <noreply@github.com>2022-06-28 21:11:31 -0700
commit9dbe45780d8c78dbb49c208fe4505cd1624a98ac (patch)
tree041feff94f8df88b1798b0ee8dd2e3d282a98cfd /src/tools/tool-options.h
parent7b7e2c56b7df43c7c6d99ef44dc4fff3b2e142bc (diff)
downloadbinaryen-9dbe45780d8c78dbb49c208fe4505cd1624a98ac.tar.gz
binaryen-9dbe45780d8c78dbb49c208fe4505cd1624a98ac.tar.bz2
binaryen-9dbe45780d8c78dbb49c208fe4505cd1624a98ac.zip
Disallow --nominal with GC (#4758)
Nominal types don't make much sense without GC, and in particular trying to emit them with typed function references but not GC enabled can result in invalid binaries because nominal types do not respect the type ordering constraints required by the typed function references proposal. Making this change was mostly straightforward, but required fixing the fuzzer to use --nominal only when GC is enabled and required exiting early from nominal-only optimizations when GC was not enabled. Fixes #4756.
Diffstat (limited to 'src/tools/tool-options.h')
-rw-r--r--src/tools/tool-options.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/tools/tool-options.h b/src/tools/tool-options.h
index bc948fc97..c15291c8d 100644
--- a/src/tools/tool-options.h
+++ b/src/tools/tool-options.h
@@ -176,6 +176,12 @@ struct ToolOptions : public Options {
void applyFeatures(Module& module) const {
module.features.enable(enabledFeatures);
module.features.disable(disabledFeatures);
+ // Non-default type systems only make sense with GC enabled. TODO: Error on
+ // non-GC equirecursive types as well once we make isorecursive the default
+ // if we don't remove equirecursive types entirely.
+ if (!module.features.hasGC() && getTypeSystem() == TypeSystem::Nominal) {
+ Fatal() << "Nominal typing is only allowed when GC is enabled";
+ }
}
private: