<div dir="ltr"><div dir="ltr">On Tue, 3 Sep 2019 at 17:59, Kamil Rytarowski via Phabricator via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a>> wrote:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">krytarowski added a comment.<br>
<br>
In D66361#1656037 <<a href="https://reviews.llvm.org/D66361#1656037" rel="noreferrer" target="_blank">https://reviews.llvm.org/D66361#1656037</a>>, @rsmith wrote:<br>
<br>
> In D66361#1655903 <<a href="https://reviews.llvm.org/D66361#1655903" rel="noreferrer" target="_blank">https://reviews.llvm.org/D66361#1655903</a>>, @krytarowski wrote:<br>
><br>
> > This change broke on NetBSD.<br>
> ><br>
> > <a href="http://lab.llvm.org:8011/builders/netbsd-amd64/builds/22003/steps/run%20unit%20tests/logs/FAIL%3A%20Clang%3A%3Astack-exhaustion.cpp" rel="noreferrer" target="_blank">http://lab.llvm.org:8011/builders/netbsd-amd64/builds/22003/steps/run%20unit%20tests/logs/FAIL%3A%20Clang%3A%3Astack-exhaustion.cpp</a><br>
><br>
><br>
> Test disabled for NetBSD in r370801. If you're interested in investigating why this isn't working there, feel free, but this is only a best-effort mitigation for the case where things have already gone wrong, so there are limits to how much effort it makes sense to resolve this.<br>
><br>
> Does NetBSD set a hard stack rlimit of less than 8MB by any chance?<br>
<br>
<br>
The stack rlimit is restricted by default to 4MB. The maximum at least on amd64 is 128MB... but if someone really needs it, it could by bypassed with more stacks.<br>
<br>
$ ulimit -a<br>
time(cpu-seconds) unlimited<br>
file(blocks) unlimited<br>
coredump(blocks) unlimited<br>
data(kbytes) 262144<br>
stack(kbytes) 4096<br>
lockedmem(kbytes) 10847213<br>
memory(kbytes) 32541640<br>
nofiles(descriptors) 1024<br>
processes 1024<br>
threads 1024<br>
vmemory(kbytes) unlimited<br>
sbsize(bytes) unlimited<br>
<br>
Should the limit by raised by default in the system?<br></blockquote><div><br></div><div>Clang expects 8MB stacks. When possible (if CLANG_HAVE_RLIMITS is enabled at configure-time) it will increase the soft stack rlimit to 8MB if it can.</div><div><br></div><div>It could be that that's failing here, either because CLANG_HAVE_RLIMITS is configured as 0, or because the hard stack limit is set below 8MB, or maybe because this kernel doesn't apply new stack limits that are set after a thread begins running. In the former case, there's not much we can do; without a working getrlimit, we can't guess how much stack is even available. In the latter cases, we could ask the system what the actual limit is, and apply our stack overflow mitigation when we reach that instead of when we reach (nearly) 8MB.</div><div><br></div><div>Can you find out which of these (if any) is the case?</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Repository:<br>
rG LLVM Github Monorepo<br>
<br>
CHANGES SINCE LAST ACTION<br>
<a href="https://reviews.llvm.org/D66361/new/" rel="noreferrer" target="_blank">https://reviews.llvm.org/D66361/new/</a><br>
<br>
<a href="https://reviews.llvm.org/D66361" rel="noreferrer" target="_blank">https://reviews.llvm.org/D66361</a><br>
<br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a><br>
</blockquote></div></div>