<div dir="ltr"><div dir="ltr">Hi Florian,<div>Sorry for the delay with this second reproducer. c-reduce was turtle slow and didn't take it very far, and bugpoint didn't like it either and needed some manual reducing. The .ll reproducer I have is still >5k lines :(</div><div><br></div><div>Repro instructions (when synced prior to reverting this commit; repro.ll is attached):</div><div>$ time ~/dev/llc repro.ll -o /tmp/repro.o</div><div><br></div><div>llc: /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/CodeGen/LiveVariables.cpp:132: void llvm::LiveVariables::HandleVirtRegUse(unsigned int, llvm::MachineBasicBlock *, llvm::MachineInstr &): Assertion `MRI->getVRegDef(reg) && "Register use before def!"' failed.</div><div>Stack dump:</div><div>0. Program arguments: /usr/local/google/home/rupprecht/dev/llc repro.ll -o /tmp/repro.o</div><div>1. Running pass 'Function Pass Manager' on module 'repro.ll'.</div><div>2. Running pass 'Live Variable Analysis' on function '@repro'</div><div> #0 0x00007f5915e1136f llvm::sys::PrintStackTrace(llvm::raw_ostream&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/Support/Unix/Signals.inc:494:13 </div><div> #1 0x00007f5915e0f5d0 llvm::sys::RunSignalHandlers() /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/Support/Signals.cpp:69:18 </div><div> #2 0x00007f5915e11778 SignalHandler(int) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/Support/Unix/Signals.inc:357:1 </div><div> #3 0x00007f59156cc0c0 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x110c0)</div><div> #4 0x00007f5914aadfcf raise (/lib/x86_64-linux-gnu/libc.so.6+0x32fcf)</div><div> #5 0x00007f5914aaf3fa abort (/lib/x86_64-linux-gnu/libc.so.6+0x343fa)</div><div> #6 0x00007f5914aa6e37 (/lib/x86_64-linux-gnu/libc.so.6+0x2be37)</div><div> #7 0x00007f5914aa6ee2 (/lib/x86_64-linux-gnu/libc.so.6+0x2bee2)</div><div> #8 0x00007f5916de41ad (/usr/local/google/home/rupprecht/src/llvm-build/dev/bin/../lib/libLLVMCodeGen.so.9svn+0x34e1ad) </div><div> #9 0x00007f5916de641e llvm::LiveVariables::runOnInstr(llvm::MachineInstr&, llvm::SmallVectorImpl<unsigned int>&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/CodeGen/LiveVariables.cpp:542:46 </div><div>#10 0x00007f5916de6b0c llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false>::isEnd() const /usr/local/google/home/rupprecht/src/llvm-project/llvm/include/llvm/ADT/ilist_iterator.h:176:31</div><div>#11 0x00007f5916de6b0c llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false> llvm::MachineInstrBundleIteratorHelper<false>::getBundleFinal<llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false> >(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false>) /usr/local/google/home/rupprecht/src/llvm-project/llvm/include/llvm/CodeGen/MachineInstrBundleIterator.h:62:0</div><div>#12 0x00007f5916de6b0c void llvm::MachineInstrBundleIteratorHelper<false>::increment<llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false> >(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::MachineInstr, true, true, void>, false, false>&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/include/llvm/CodeGen/MachineInstrBundleIterator.h:70:0 </div><div>#13 0x00007f5916de6b0c llvm::MachineInstrBundleIterator<llvm::MachineInstr, false>::operator++() /usr/local/google/home/rupprecht/src/llvm-project/llvm/include/llvm/CodeGen/MachineInstrBundleIterator.h:260:0 </div><div>#14 0x00007f5916de6b0c llvm::LiveVariables::runOnBlock(llvm::MachineBasicBlock*, unsigned int) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/CodeGen/LiveVariables.cpp:577:0 </div><div>#15 0x00007f5916de7201 llvm::LiveVariables::runOnMachineFunction(llvm::MachineFunction&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/CodeGen/LiveVariables.cpp:650:32 </div><div>#16 0x00007f5916e4abea llvm::MachineFunctionPass::runOnFunction(llvm::Function&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/CodeGen/MachineFunctionPass.cpp:73:13 </div><div>#17 0x00007f59169fcc43 llvm::FPPassManager::runOnFunction(llvm::Function&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1648:27 </div><div>#18 0x00007f59169fcf53 llvm::FPPassManager::runOnModule(llvm::Module&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1685:13 </div><div>#19 0x00007f59169fd3e8 (anonymous namespace)::MPPassManager::runOnModule(llvm::Module&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1752:27 </div><div>#20 0x00007f59169fd3e8 llvm::legacy::PassManagerImpl::run(llvm::Module&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1865:0 </div><div>#21 0x000000000021585c compileModule(char**, llvm::LLVMContext&) /usr/local/google/home/rupprecht/src/llvm-project/llvm/tools/llc/llc.cpp:609:8 </div><div>#22 0x00000000002132dd main /usr/local/google/home/rupprecht/src/llvm-project/llvm/tools/llc/llc.cpp:363:13 </div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, May 10, 2019 at 11:09 PM Jordan Rupprecht <<a href="mailto:rupprecht@google.com">rupprecht@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div>Attached a repro.cc from creduce. Repro is just:</div><div>$ cat repro.cc</div><div><div>struct b {</div><div> char aa;</div><div>};</div><div>struct __attribute__((__packed__)) d {</div><div> char : 84211;</div><div> char ak : 1;</div><div> int al : 32;</div><div> int am : 32;</div><div> char an : 5;</div><div> char : 5;</div><div> char ap : 5;</div><div> short c : 6;</div><div> int aa : 27;</div><div> int at : 32;</div><div> int a;</div><div> void e();</div><div>};</div><div>class f {</div><div> void g(const b &);</div><div> long az[];</div><div>};</div><div>void f::g(const b &h) {</div><div> d a;</div><div> a.ak = <a href="http://a.al" target="_blank">a.al</a> = <a href="http://a.am" target="_blank">a.am</a> = <a href="http://a.an" target="_blank">a.an</a> = a.ap = a.c = a.aa = h.aa;</div><div> <a href="http://a.at" target="_blank">a.at</a> = az[0];</div><div> a.e();</div><div>}</div></div><div>$ clang++ -O2 -fsanitize=address -o repro.o -c repro.cc</div><div>And I just noticed that clang w/ debug prints this before the stack:</div><div><div><br></div><div>clang-9: $SRC/llvm/lib/CodeGen/MachineTraceMetrics.cpp:639: (anonymous namespace)::DataDep::DataDep(const llvm::MachineRegisterInfo *, unsigned int, unsigned int): Assertion `!DefI.atEnd() && "Register has no defs"' failed.</div></div><div><br></div><div>creduce is going a little more slowly on the code that crashed in "Live Variable Analysis", but I'll leave that going over the weekend. Hope this initial test case helps a bit.</div></div></div></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr"><strong>From: </strong>Florian Hahn <span dir="ltr"><<a href="mailto:flo@fhahn.com" target="_blank">flo@fhahn.com</a>></span><br><strong>Date: </strong>Fri, May 10, 2019 at 4:26 PM<br><strong>To: </strong>Jordan Rupprecht<br><strong>Cc: </strong>llvm-commits<br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="auto"><div dir="ltr"></div><div dir="ltr"><br></div><div dir="ltr"><br>On 11 May 2019, at 00:22, Jordan Rupprecht <<a href="mailto:rupprecht@google.com" target="_blank">rupprecht@google.com</a>> wrote:<br><br></div><blockquote type="cite"><div dir="ltr"><div dir="ltr"><div dir="ltr">Reverted in r360481. I have creduce going on the Machine InstCombiner crash and down to "only" 7000 lines, so I think it will finish before I leave today.</div><div dir="ltr"><br></div><div>There were some crashes in other places (i.e. I don't think the bug is in this patch, it's just revealing bugs in other places), so I'll have to see if those reduce to the same thing -- I'll check that out next week.</div><div><br></div><div>Sorry for the inconvenience!</div></div><br></div></blockquote><div><br></div>No worries, thanks for letting me know. I’m curious what the problem with the machine combiner is.<div><br></div><div>Cheers<br><blockquote type="cite"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr"><strong>From: </strong>Jordan Rupprecht <span dir="ltr"><<a href="mailto:rupprecht@google.com" target="_blank">rupprecht@google.com</a>></span><br><strong>Date: </strong>Fri, May 10, 2019 at 3:28 PM<br><strong>To: </strong>Florian Hahn<br><strong>Cc: </strong>llvm-commits<br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr"><div>Here's the full crash (minus the boiler plate) for the one in Machine InstCombiner:</div><div> #9 0x00007fb8d52cf5d2 (anonymous namespace)::DataDep::DataDep(llvm::MachineRegisterInfo const*, unsigned int, unsigned int) ${LLVM_SRC}/llvm/lib/CodeGen/MachineTraceMetrics.cpp:640:13</div><div>#10 0x00007fb8d52cb644 getDataDeps(llvm::MachineInstr const&, llvm::SmallVectorImpl<(anonymous namespace)::DataDep>&, llvm::MachineRegisterInfo const*) ${LLVM_SRC}/llvm/lib/CodeGen/MachineTraceMetrics.cpp:672:22</div><div>#11 0x00007fb8d52cb064 llvm::MachineTraceMetrics::Ensemble::updateDepth(llvm::MachineTraceMetrics::TraceBlockInfo&, llvm::MachineInstr const&, llvm::SparseSet<llvm::LiveRegUnit, llvm::identity<unsigned int>, unsigned char>&) ${LLVM_SRC}/llvm/lib/CodeGen/MachineTraceMetrics.cpp:788:12</div><div>#12 0x00007fb8d52cc300 llvm::MachineTraceMetrics::Ensemble::computeInstrDepths(llvm::MachineBasicBlock const*) ${LLVM_SRC}/llvm/lib/CodeGen/MachineTraceMetrics.cpp:883:28</div><div>#13 0x00007fb8d52cde9e llvm::MachineTraceMetrics::Ensemble::getTrace(llvm::MachineBasicBlock const*) ${LLVM_SRC}/llvm/lib/CodeGen/MachineTraceMetrics.cpp:1166:8</div><div>#14 0x00007fb8d515ead4 (anonymous namespace)::MachineCombiner::combineInstructions(llvm::MachineBasicBlock*) ${LLVM_SRC}/llvm/lib/CodeGen/MachineCombiner.cpp:596:59</div><div>#15 0x00007fb8d515e342 (anonymous namespace)::MachineCombiner::runOnMachineFunction(llvm::MachineFunction&) ${LLVM_SRC}/llvm/lib/CodeGen/MachineCombiner.cpp:654:16</div><div>#16 0x00007fb8d51bf637 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) ${LLVM_SRC}/llvm/lib/CodeGen/MachineFunctionPass.cpp:73:8</div><div>#17 0x00007fb8d47dd759 llvm::FPPassManager::runOnFunction(llvm::Function&) ${LLVM_SRC}/llvm/lib/IR/LegacyPassManager.cpp:1648:23</div><div>#18 0x00007fb8d47ddb9f llvm::FPPassManager::runOnModule(llvm::Module&) ${LLVM_SRC}/llvm/lib/IR/LegacyPassManager.cpp:1685:16</div><div>#19 0x00007fb8d47de305 (anonymous namespace)::MPPassManager::runOnModule(llvm::Module&) ${LLVM_SRC}/llvm/lib/IR/LegacyPassManager.cpp:1752:23</div><div>#20 0x00007fb8d47dde45 llvm::legacy::PassManagerImpl::run(llvm::Module&) ${LLVM_SRC}/llvm/lib/IR/LegacyPassManager.cpp:1865:16</div><div>#21 0x00007fb8d47de881 llvm::legacy::PassManager::run(llvm::Module&) ${LLVM_SRC}/llvm/lib/IR/LegacyPassManager.cpp:1896:3</div><div>#22 0x00007fb8d117e15a (anonymous namespace)::EmitAssemblyHelper::EmitAssembly(clang::BackendAction, std::unique_ptr<llvm::raw_pwrite_stream, std::default_delete<llvm::raw_pwrite_stream> >) ${LLVM_SRC}/clang/lib/CodeGen/BackendUtil.cpp:894:3</div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr"><strong>From: </strong>Jordan Rupprecht <span dir="ltr"><<a href="mailto:rupprecht@google.com" target="_blank">rupprecht@google.com</a>></span><br><strong>Date: </strong>Fri, May 10, 2019 at 12:58 PM<br><strong>To: </strong>Florian Hahn<br><strong>Cc: </strong>llvm-commits<br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr">Looks like this causes some asan/msan crashes (or in some cases, test failure/miscompiles). I'll see if I can get a crash with debug+asserts enabled. In release mode, it's crashing during Machine InstCombiner/Live Variable Analysis for different repros.<div><br></div></div></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr"><strong>From: </strong>Florian Hahn via llvm-commits <span dir="ltr"><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span><br><strong>Date: </strong>Tue, May 7, 2019 at 9:45 AM<br><strong>To: </strong> <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>><br><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Author: fhahn<br>
Date: Tue May 7 09:47:27 2019<br>
New Revision: 360171<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=360171&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=360171&view=rev</a><br>
Log:<br>
[DAGCombiner] Avoid creating large tokenfactors in visitTokenFactor<br>
<br>
When simplifying TokenFactors, we potentially iterate over all<br>
operands of a large number of TokenFactors. This causes quadratic<br>
compile times in some cases and the large token factors cause additional<br>
scalability problems elsewhere.<br>
<br>
This patch adds some limits to the number of nodes explored for the<br>
cases mentioned above.<br>
<br>
Reviewers: niravd, spatel, craig.topper<br>
<br>
Reviewed By: niravd<br>
<br>
Differential Revision: <a href="https://reviews.llvm.org/D61397" rel="noreferrer" target="_blank">https://reviews.llvm.org/D61397</a><br>
<br>
Modified:<br>
llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp<br>
<br>
Modified: llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp?rev=360171&r1=360170&r2=360171&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp?rev=360171&r1=360170&r2=360171&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp (original)<br>
+++ llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp Tue May 7 09:47:27 2019<br>
@@ -1792,8 +1792,9 @@ SDValue DAGCombiner::visitTokenFactor(SD<br>
TFs.push_back(N);<br>
<br>
// Iterate through token factors. The TFs grows when new token factors are<br>
- // encountered.<br>
- for (unsigned i = 0; i < TFs.size(); ++i) {<br>
+ // encountered. Limit number of nodes to inline, to avoid quadratic compile<br>
+ // times.<br>
+ for (unsigned i = 0; i < TFs.size() && Ops.size() <= 2048; ++i) {<br>
SDNode *TF = TFs[i];<br>
<br>
// Check each of the operands.<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br>
</blockquote></div>
</blockquote></div>
</blockquote></div>
</div></blockquote></div></div></blockquote></div>
</blockquote></div>