<div dir="ltr">when diffing, perhaps we should compare the actual representation, tying same-name-and-structure objects together, though types arise from different parses, rather than the usually tighter scoping</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jun 18, 2021 at 12:47 AM Bill Wendling <<a href="mailto:morbo@google.com">morbo@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 class="gmail_default" style="font-family:arial,sans-serif"><div class="gmail_default">Some context. Here are the type definitions and global definition:</div><div class="gmail_default"><br></div><div class="gmail_default"> %struct.vmcs_layout = type { i32, [2048 x %struct.vmcs_entry] }<br> %struct.vmcs_entry = type { i16, i16 }<br></div><div class="gmail_default"> ...</div><div class="gmail_default"> @vmcs_layout = internal global %struct.vmcs_layout zeroinitializer, align 4, !dbg !10400<br></div><div class="gmail_default"><br></div><div class="gmail_default">It seems like it's applying the ".663" suffix because of a name clash with the other type.</div><font color="#888888" style="font-family:Arial,Helvetica,sans-serif"><div class="gmail_default" style="font-family:arial,sans-serif"><br></div><div class="gmail_default" style="font-family:arial,sans-serif">-bw</div></font></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 17, 2021 at 5:00 PM Yonghyun Hwang <<a href="mailto:yonghyun@google.com" target="_blank">yonghyun@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 class="gmail_default" style="font-family:monospace,monospace"><div class="gmail_default">Hello,</div><div class="gmail_default"><br></div><div class="gmail_default">I'm using the 'llvm-diff' tool to diff two llvm assembly files. While doing that, I've observed that the 'llvm-diff' tool shows lots of diffs even when the same assembly files are given as command line arguments. For example, if we run</div><div class="gmail_default"><br></div><div class="gmail_default">$ llvm-diff test.ll test.ll</div><div class="gmail_default"><br></div><div class="gmail_default">'llvm-diff' shows lots of diffs for "static" global variables. This is an example.</div><div class="gmail_default"><br></div><div class="gmail_default">// in test.c</div><div class="gmail_default">static struct vmcs_layout vmcs_layout;<br></div><div class="gmail_default"><br></div><div class="gmail_default">output for 'llvm-diff' is as follows.</div><div class="gmail_default"><br></div><div class="gmail_default"> > %3 = load i32, i32* getelementptr inbounds (%<b>struct.vmcs_layout.663</b>, %struct.vmcs_layout.663* @vmcs_layout, i64 0, i32 0), align 4<br> < %3 = load i32, i32* getelementptr inbounds (%<b>struct.vmcs_layout</b>, %struct.vmcs_layout* @vmcs_layout, i64 0, i32 0), align 4<br><br></div><div class="gmail_default">The difference is a suffix, 663. Is this behavior intentional for 'llvm-diff'? If it's intentional, how can I update 'llvm-diff' tool to see "no" diffs for the same .ll file?</div><div class="gmail_default"><br></div><div class="gmail_default">Thank you,</div><div class="gmail_default">Yonghyun</div></div></div>
</blockquote></div>
</blockquote></div>