aaron.ballman added a comment.

In D155955#4532433 <https://reviews.llvm.org/D155955#4532433>, @cor3ntin wrote:

> In D155955#4532385 <https://reviews.llvm.org/D155955#4532385>, @aaron.ballman 
> wrote:
>
>> In D155955#4528792 <https://reviews.llvm.org/D155955#4528792>, @efriedma 
>> wrote:
>>
>>>> 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.
>>
>> 100% agreed
>>
>>> - Add strict limits memory usage limits for optional constant folding
>>
>> This seems reasonable to me, but I think this should be user controllable so 
>> that users with different resource constraints can override whatever default 
>> value we pick.
>>
>>> - 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.
>>
>> If we can use an existing implementation limit 
>> (http://eel.is/c++draft/implimits) to justify our decision, great; 
>> otherwise, I think we should ask WG21 for an official escape hatch so that 
>> we don't have conformance issues.
>
> Forgot to reply to that, it's already conforming

Oh, excellent!

> - A variable or temporary object o is constant-initialized if [..] the 
> full-expression of its initialization is a constant expression 
> http://eel.is/c++draft/expr.const#2
> - An expression E is a core constant expression unless [...] it would exceed 
> the implementation-defined limits http://eel.is/c++draft/expr.const#5
> - Limits may constrain quantities that include those described below or 
> others. http://eel.is/c++draft/implimits#2.sentence-1
>
> On the last point, i think a *explicit* limit would be nice but i chatted 
> with core and they agreed the current wording was sufficient - and they 
> didn't seem super enthusiastic about adding limits.

"or others" is an amazing amount of latitude for Core to give us, how handy! :-D

FWIW, I personally think having explicit limits is far better than relying on 
"or others" to do the heavy lifting, but we've got what we need at least.


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