[PATCH] D87537: [lld][WebAssembly] Error on import/export of mutable global without `mutable-globals` feature
Thomas Lively via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Sep 11 18:47:21 PDT 2020
tlively added inline comments.
================
Comment at: clang/lib/Driver/ToolChains/WebAssembly.cpp:246-252
+ llvm::Reloc::Model RelocationModel;
+ unsigned PICLevel;
+ bool IsPIE;
+ std::tie(RelocationModel, PICLevel, IsPIE) = ParsePICArgs(*this, DriverArgs);
+ if (RelocationModel == llvm::Reloc::PIC_) {
+ CC1Args.push_back("+mutable-globals");
+ }
----------------
tlively wrote:
> This should also check that the user didn't pass `options::OPT_mno_mutable_globals` and a test should be added in clang/test/Driver/wasm-toolchain.c.
Sorry, I meant that if the user passes -fPIC as well as `-mno-mutable-globals`, we should give them a `diag::err_drv_argument_not_allowed_with` error, like we do above for -pthread features and below for -fwasm-exceptions features,
================
Comment at: lld/wasm/Writer.cpp:478
+ toString(*sym) + "`. Use --no-check-features to suppress.");
+ else if (sym->isExported())
+ error(Twine("mutable global exported but 'mutable-globals' feature "
----------------
sbc100 wrote:
> tlively wrote:
> > could this `if (sym->isExported())` be turned into an `assert(sym->isExported())`?
> I don't think so. What about regular internal globals that are neither imported nor exported? Unless I'm missing something?
Ah, makes sense.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D87537/new/
https://reviews.llvm.org/D87537
More information about the llvm-commits
mailing list