<div dir="ltr">I suspect something is pulling the RHS of the memorydef and caching it for calls it should not be used for.<div>In particular, i suspect we are about to discover we can't cache the results from both versions of getClobberingMemoryAccess together, or that the cache is not always getting consistently written.</div><div><br></div><div><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, May 2, 2016 at 11:16 AM, George Burgess IV <span dir="ltr"><<a href="mailto:george.burgess.iv@gmail.com" target="_blank">george.burgess.iv@gmail.com</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">Yeah, that sounds like a fun bug. I'll take a look later today and see what I can find out. :)<div><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Apr 29, 2016 at 2:55 PM, Geoff Berry <span dir="ltr"><<a href="mailto:gberry@codeaurora.org" target="_blank">gberry@codeaurora.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div bgcolor="#FFFFFF" text="#000000">
<p>Hi guys,</p>
<p>I think I have run into another CachingMemorySSAWalker cache
bug. It's a bit tricky to reproduce, so I'd like to start by
trying to show you what is happening when running EarlyCSE with my
local changes to use MemorySSA. I've attached a debug log that
shows that the value returned by getClobberingMemoryAccess(Inst)
after a call to removeMemoryAccess is wrong. The MemorySSA node
in question is MemoryUse(7), and the corruption happens after a
call to remove MemoryUse(2), at which point its clobber value
changes to '1 = MemoryDef(liveOnEntry)'. The interesting thing is
that is doesn't seem to be the first call to
getClobberingMemoryAccess after the removal that causes the
corruption, but rather the second. You'll notice that I added
calls to getClobberingMemoryAccess when doing MSSA.dump(), which
is what I'm using to attempt to figure out when the cache gets
corrupted.<br>
</p>
Hopefully this is enough information to debug the problem. If not
perhaps we can look at getting my EarlyCSE changes checked in in a
disabled state so you can reproduce the problem directly. I'm also
happy to help debug it farther.<span><font color="#888888"><br>
<pre cols="72">--
Geoff Berry
Employee of Qualcomm Innovation Center, Inc.
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project
</pre>
</font></span></div>
</blockquote></div><br></div></div></div></div>
</blockquote></div><br></div>