efriedma added a comment.

> Note sure what you mean. Making sure we use size_t for all array extents is 
> not something that can be fixed overnight but more importantly, it does not 
> help: Would it not overflow, the allocation would still fail.

Oh, right, it would be sizeof(APValue) * UINT_MAX, which would break in any 
practical usage.

> I don't think that would make sense in actual code, and having some sort of 
> sparse array is something I considered. And we already delay allocation in 
> some cases, but we do need to create elements to destroy them, read them, 
> etc. So while it may be possible, it seems... complicated.

Definitely not simple, sure.

> I think a more viable long term fix might be to not crash on allocation 
> failure, and/or to have a way to limit the allocation to some portion of the 
> available memory.

Making the compiler's behavior depend on the amount of memory installed in the 
user's computer seems like a non-starter.  I think we just have to stick with 
some combination of:

- Try to reduce excessive memory usage in constant folding.
- Add strict limits memory usage limits for optional constant folding
- Maybe consider disobeying the standard slightly in certain cases: the 
standard requires that we constant-fold the initializers for all global 
variables, but that might not really be viable for globals that are expensive 
to evaluate.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D155955/new/

https://reviews.llvm.org/D155955

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to