<div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">On Sun, Oct 30, 2016 at 6:48 PM, Daniel Berlin <span dir="ltr"><<a href="mailto:dberlin@dberlin.org" target="_blank">dberlin@dberlin.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">In particular:<br>"<div><span class="">I'm not so sure that it's sufficient. Suppose, for instance, that I wanted to insert a MemoryDef between 1 and 2 in the below AccessList:<div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 0 = MemoryDef(liveOnEntry)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 1 = MemoryDef(0)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></span></div></div></div></div></span><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class=""><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 2 = MemoryDef(1)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 3 = MemoryUse(1)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Invoking createMemoryAccess followed by RAUW of 1's uses with 4 would result in:</div></span><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">....</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">"</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Which is why this is not the way one does this, anywhere.</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">If you wish to *replace* an existing access, the normal way is:<br><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div></div></div></div></div></div></div></blockquote><div><br></div><div>As my original post indicates, I wish to insert an access, not replace anything. I've inserted a new memory instruction (memmove, memcpy, or memset), into the IR and wish to keep the MSSA tree synchronized.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> MemoryAccess *Def = OldMemAcc->getDefiningAccess()<wbr>;<br></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> NewMemAcc =</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> MSSA-><wbr>createMemoryAccessAfter(Repl, Def, OldMemAccess->getMemoryInst())<wbr>;</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> OldMemAcc-><wbr>replaceAllUsesWith(NewMemAcc);</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">It doesn't make any sense to create a replacing access with the thing you are going to replace as the definition.</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div></div></div></div></div></div></div></blockquote><div>Really, I don't want to replace anything. I'm interested in insertions. We have removals and replacements. So might insertion also be a valid concept with MSSA?<br> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">The same thing, btw, would happen in normal LLVM SSA IR if you used the thing you are replacing in the definition of the replacement.<br><br></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%c = add %a, %b</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%e = add %c, %d</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">If you wish to replace the first, you can't do this:</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%c = add %a, %b</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%tmp = add %a, %c</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%e = add %c, %d</div><div><br></div><div>because calling %c->replaceAllUsesWith %tmp</div><div>will result in:<br><br></div><div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%tmp = add %a, %tmp</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">%e = add %c, %d</div></div><div><br></div><div><br></div><div>IE the behavior you are citing is completely consistent with existing LLVM IR. If you define a replacement partially in terms of the thing it is replacing, it breaks.</div></div></div></div></div></div></div></div></blockquote><div><br>Not replacing, please believe me.<br> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div><br></div></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote"><div><div class="h5">On Sun, Oct 30, 2016 at 1:56 PM, Daniel Berlin <span dir="ltr"><<a href="mailto:dberlin@dberlin.org" target="_blank">dberlin@dberlin.org</a>></span> wrote:<br></div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div class="h5"><span>For starters, createDefinedAccess is private, so nobody can use it.</span><div>Second, the API calls that use it explicitly take a defining access to avoid the problem you cite. </div><div><br></div><div>Can you produce a case where normal usage of the update API actually does the wrong thing?</div><div><br></div></div></div><div><div><div class="h5">I'm entirely unsure what actual usage problem you are trying to solve, so I can't help explain how to do it.</div></div><div><div class="m_-5437082179567694066gmail-h5"><br><br><div class="gmail_quote"><div><div class="h5"><div dir="ltr">On Sun, Oct 30, 2016, 1:17 PM Bryant Wong <<a href="mailto:314472@gmail.com" target="_blank">314472@gmail.com</a>> wrote:<br></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"><div><div class="h5"><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Thanks for clearing up my misunderstanding regarding MemoryUses.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">On Sun, Oct 30, 2016 at 2:04 PM, Daniel Berlin <span dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><<a href="mailto:dberlin@dberlin.org" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" target="_blank">dberlin@dberlin.org</a>></span> wrote:<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">On Sun, Oct 30, 2016 at 3:03 AM, bryant <span dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><<a href="mailto:3.14472+reviews.llvm.org@gmail.com" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" target="_blank">3.14472+reviews.llvm.org@gmai<wbr>l.com</a>></span> wrote:<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">bryant created this revision.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
bryant added reviewers: dberlin, george.burgess.iv.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
bryant added a subscriber: llvm-commits.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
bryant set the repository for this revision to rL LLVM.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
An invariant of AccessLists is that the defining access of a Use or Def is the nearest preceding Def node.</blockquote></span><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">False</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">This is correct for def's but not for uses.</div><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> </div><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"> For instance, within a BasicBlock:<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
0 = MemoryDef(liveOnEntry)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
1 = MemoryDef(0)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
2 = MemoryUse(n)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
3 = MemoryDef(m)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
1 is the nearest parent Def of 2 and 3, and m and n must be 1.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></blockquote><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></span><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Given the above, this is incorrect.</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">n may be 0</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">IE the following is perfectly legal</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 0 = MemoryDef(liveOnEntry)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 1 = MemoryDef(0)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></span> 2 = MemoryUse(0)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 3 = MemoryDef(1)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> </div><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
This patch simplifies the interfaces of createMemoryAccessBefore/After<wbr>, and augments them to maintain this invariant.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">
Additionally, when inserting a new Def after an existing Def, there is currently no (clean) way to update the users of the old Def to use the new Def. </blockquote><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></span><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">RAUW works exactly to do this case.</div><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> </div></span></div></div></div></blockquote><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">I'm not so sure that it's sufficient. Suppose, for instance, that I wanted to insert a MemoryDef between 1 and 2 in the below AccessList:</div></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 0 = MemoryDef(liveOnEntry)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 1 = MemoryDef(0)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></span></div></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 2 = MemoryDef(1)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> 3 = MemoryUse(1)<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Invoking createMemoryAccess followed by RAUW of 1's uses with 4 would result in:<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br></div></div></div></div></div></div></div><span class=""><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">So RAUW needs to happen before setting 4's defining access to 1, but this isn't possible with the current createDefiningAccess. What other options are there? RAUW with a bogus Def, create, then re-RAUW to the newly created Def? I feel like I'm missing something obvious, so clarification would be much appreciated.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></div></div></div><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"> </div><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_extra m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><div class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><span class="m_-5437082179567694066gmail-m_-868984512930983029m_-6466548616601174784m_7998958474538251886gmail- m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><blockquote class="gmail_quote m_-5437082179567694066gmail-m_-868984512930983029gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">So createDefiningAccess now permits the option of updating the users.<br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></blockquote><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></span><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg">Please, no.</div><div class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"><br class="m_-5437082179567694066gmail-m_-868984512930983029gmail_msg"></div></div></div></div>
</blockquote></div></div></div></span></blockquote></div></div></div></div></blockquote></div><br></div></div></div>
</blockquote></div><br></div></div>