<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Jan 29, 2016 at 10:06 PM, David Li <span dir="ltr"><<a href="mailto:davidxl@google.com" target="_blank">davidxl@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">davidxl added inline comments.<br>
<br>
================<br>
Comment at: include/llvm/Transforms/Utils/MemorySSA.h:16<br>
@@ +15,3 @@<br>
+// instructions such loads, stores, atomics and calls. Additionally, it does a<br>
+// trivial form of "heap versioning" Every time the memory state changes in the<br>
+// program, we generate a new heap version. It generates MemoryDef/Uses/Phis<br>
----------------<br>
nit: missing period.<br>
<br>
================<br>
Comment at: include/llvm/Transforms/Utils/MemorySSA.h:18<br>
@@ +17,3 @@<br>
+// program, we generate a new heap version. It generates MemoryDef/Uses/Phis<br>
+// that are overlayed on top of the existing instructions<br>
+//<br>
----------------<br>
nit: missing period at the end.<br>
<br>
================<br>
Comment at: include/llvm/Transforms/Utils/MemorySSA.h:186<br>
@@ +185,3 @@<br>
+<br>
+  // FIXME(gbiv): MemoryUses don't have users. The quick fix for this would be<br>
+  // to make a virtual `getUsers()` with llvm_unreachable in MemoryUse, but I'd<br>
----------------<br>
In the context when user_begin() is called, the memoryAccess must be a def. Given that assumption, you can safely DownCast the memoryAccess to MemoryDef -- the problem is both Def and Phi need to be handled.<br>
<br>
================<br>
Comment at: include/llvm/Transforms/Utils/MemorySSA.h:203<br>
@@ +202,3 @@<br>
+  //<br>
+  // ...But then virtual base classes happen (diamond between MemoryAccess and<br>
+  // Def), and those are icky. Not sure if the trait system would need virtual<br>
----------------<br>
I have another suggestion of the hierarchy:<br>
<br>
Strictly speaking a MemoryDef  and MemoryUse is not the IsA relationship, but a hasA relationship -- basically a memory def is not a use, but it has any implicit may use to model the may-kill. </blockquote><div><br></div><div>Correct.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">  With that in mind,  it is probably not a good idea to factor out UseOrDef out as the common ancestor of MemoryDef and MemoryUse. Instead: </blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
1) MemoryDef should have a pointer to a memoryUse instance<br></blockquote><div><br></div><div>This is expensive to indirect.  Seriously. I measured the slowdown at about 15-20% on common memorySSA algorithms.</div><div><br></div><div>MemorySSA dominates GVN time in NewGVN, and i expect, in most other algorithms currently using memory dependence.</div><div>While it should not be optimized early, the current hierarchy is a *deliberate* tradeoff between speed and theoretical OO modeling purity :)</div><div> </div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
2) MemoryDef and Phi Node should have a common ancestor DefOrPhi as drawn above.<br>
<br>
Pros: the userList can now be moved into DefOrPhi<br>
Cons: get|setDefininingAccess method now needs to be declared as virtual in MemoryAccess base and overridden in MemoryUse and MemoryDef.  For MemoryDef, it just need to forward the call to the memoryUse it owns.<br>
<br>
To avoid virtual call, the memoryAccess can do dispatching via DownCasting depending on memoryAccess type.<br>
<br></blockquote><div><br></div><div>This seems expensive :)</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
================<br>
Comment at: include/llvm/Transforms/Utils/MemorySSA.h:333<br>
@@ +332,3 @@<br>
+  const unsigned ID;<br>
+  UserListType Users;<br>
+};<br>
----------------<br>
Is this redundant? There is one in base class.<br>
<br></blockquote><div><br></div><div>It is redundant ;)</div><div><br></div><div>I put user lists in the base class deliberately.</div><div><br></div><div>Otherwise, due to the class hierarchy, you have to check for a phi or a def.</div><div><br></div><div>Whee.</div><div><br></div><div>(The next question that usually gets asked is why none of these classes are derived from User/Value or something to handle the use lists</div><div>I spent a couple days trying to make this work but could not get it to work right.  Better attempts completely welcome.</div><div>Part of the issue you hit is that none of these things are *really* part of the IR, so a bunch of functions become quite unhappy.</div><div>It also wastes  8 bytes on the Type pointer that we don't have, need, or use).</div><div><br></div><div><br></div></div></div></div>