<html><head></head><body bgcolor="#FFFFFF"><div><span class="Apple-style-span" style="-webkit-tap-highlight-color: rgba(26, 26, 26, 0.296875); -webkit-composition-fill-color: rgba(175, 192, 227, 0.230469); -webkit-composition-frame-color: rgba(77, 128, 180, 0.230469); ">On Nov 1, 2011, at 4:47 AM, Nicolas Geoffray <<a href="mailto:nicolas.geoffray@gmail.com">nicolas.geoffray@gmail.com</a>> wrote:</span><br></div><div><br></div><div></div><blockquote type="cite"><div>Thanks for the review Gordon.<br><br><div class="gmail_quote">On Tue, Nov 1, 2011 at 2:21 AM, Gordon Henriksen <span dir="ltr"><<a href="mailto:gordonhenriksen@mac.com">gordonhenriksen@mac.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div class="im">On <a href="tel:2011-10-31" value="+4520111031">2011-10-31</a>, at 17:21, Nicolas Geoffray wrote:<br>
<br>
> Here's a patch to allow a GCStrategy to customize the places where it wants to insert safe points. I'm not sure who maintains the GC code today in LLVM (I'd be happy to take ownership, if needed).<br>
><br>
> The patch just adds up a custom safepoints flag, similar to the way the GCStrategy can customize intrinsics lowering, or roots initialization. It works pretty well, as I've tested it on VMKit. So the patch in itself should not be controversial.<br>

<br>
</div>Seems a perfectly reasonable patch on its own merits.<br>
<br>
I would be curious what your findCustomSafePoints implementation looks like. Perhaps it's possible to extract some of it into the framework.<br></blockquote><div><br></div><div>The code for my findCustomSafePoints is like this:</div>
<div><br></div><div><div>void MyGC::findCustomSafePoints(GCFunctionInfo& FI, MachineFunction &MF) {</div><div>  for (MachineFunction::iterator BBI = MF.begin(),</div><div>                                 BBE = MF.end(); BBI != BBE; ++BBI) {</div>
<div>    for (MachineBasicBlock::iterator MI = BBI->begin(),</div><div>                                     ME = BBI->end(); MI != ME; ++MI) {</div><div>      if (MI->getDesc().isCall()) {</div><div>               /// Standard code need for adding a post call safe point;</div>
<div>      } else if (MI->getDebucLoc().getCol() == 1) {</div><div>              /// Standard code need for adding a post call safe point;</div><div>      }</div><div>  }</div><div>}</div></div><div><br></div><div>So it really looks like what we already have, except this special trick about checking the debug location. Piggy backing on the debug location is easy and works for me because:</div>
<div>1) Debug locations are passed from LLVM Instructions to MachineInstruction</div><div>2) I don't have column numbers in my front-end.</div><div><br></div><div>The instructions that get this special marker on the debug location are instructions that may trigger a segmentation fault. Because I enter a signal handler, that may invoke a collection, I need to know the roots at the faulting instruction's address.</div></div>
</div></blockquote><div><br></div>I have my doubts about the robustness of this strategy, but if it's working well enough for your needs, then great.<div><br></div><div>Your patch seems appropriately factored. The alternative would seem to be calling a virtualized predicate on each machine instruction, as I don't think your debug info approach is something we would want to ‘bless’ just yet.</div><div><br></div><div>You may need to align your safe point machine code analysis with [GCStrategy.cpp]LowerIntrinsics::CouldBecomeSafePoint. Note that this predicate operates on IR instructions instead of machine code.<br><br>— Gordon</div></body></html>