<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Title" content="">
<meta name="Keywords" content="">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:"맑은 고딕";}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman";}
span.hoenzb
        {mso-style-name:hoenzb;}
span.m-1612198669786183669hoenzb
        {mso-style-name:m_-1612198669786183669hoenzb;}
p.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal, li.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal, div.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal
        {mso-style-name:m_-1612198669786183669m_-7125561629070243100m_-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman";}
p.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal, li.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal, div.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal
        {mso-style-name:m_-1612198669786183669m_-7125561629070243100m_-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman";}
p.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal, li.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal, div.m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal
        {mso-style-name:m_-1612198669786183669m_-7125561629070243100m_-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman";}
span.EmailStyle23
        {mso-style-type:personal-reply;
        font-family:Calibri;
        color:windowtext;}
span.msoIns
        {mso-style-type:export-only;
        mso-style-name:"";
        text-decoration:underline;
        color:teal;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style>
</head>
<body bgcolor="white" lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri">Hello Teresa,
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri">Sorry I was working on another LLVM issue that more urgent for us, so didn’t have much time to work on smaller test case. I’ll try the new API and see if the issus is gone. Thanks!<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri">Best,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri">Taewook<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:Calibri"><o:p> </o:p></span></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="font-family:Calibri;color:black">From: </span>
</b><span style="font-family:Calibri;color:black">Teresa Johnson <tejohnson@google.com><br>
<b>Date: </b>Tuesday, August 16, 2016 at 1:37 AM<br>
<b>To: </b>Taewook Oh <twoh@fb.com><br>
<b>Cc: </b>via llvm-dev <llvm-dev@lists.llvm.org><br>
<b>Subject: </b>Re: [llvm-dev] [ThinLTO] assert(GS != DefinedGlobals.end()) failed in FunctionImport.cpp<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal">Hi Taewook, <o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I had a better fix for this approved (D23015), but when I went to merge this with the new LTO API I committed for pcc last week I discovered that his new API already has the same effect. I will update the bug with this info as well. Can
 you confirm that with a compiler built after 278338 that this problem no longer occurs?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Also, any luck on a smaller test case for the -g issue? Now that I have pcc's patches merged I will try again to see if I can trigger it, probably with some larger internal benchmarks. But if you can give me more details on that problem
 that would be great.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Let me know if you run into any other issues too!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Thanks,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">Teresa<o:p></o:p></p>
</div>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On Mon, Aug 1, 2016 at 6:57 AM, Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On Sat, Jul 30, 2016 at 6:45 AM, Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<p class="MsoNormal">Ok, good to know. <o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Any luck on a smaller test case for either of the problems? <o:p></o:p></p>
</div>
</div>
</blockquote>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I tried building all the C/C++ SPEC cpu2006 benchmarks with -g -flto=thin at head and didn't get the failure. Let me try to look into how the debug metadata is normally dropped from the imported decl. In the meantime, could you find out
 the answers to the questions I had (see below) about the linkage type of the _foo symbol and when the verifier was being run when it hit the failures? Also, was _foo imported into the module?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Also, I am going to try to see if I can construct a test case to trigger the original problem. But do you want to try to make forward progress by changing your local version of LLVM so that instead of asserting in MustPreserveGV, we instead
 conservatively return true if it isn't found in the map?<o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I have a small test case to repro the original problem.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I think that the conservative fix I describe above is probably the right approach - we could also try stripping off any .\d+ suffix and querying the module index with that. It works but I am a little wary as the variable could originally
 be named with a .\d+ suffix as well and we could inadvertently use the index for a different variable. Although they should both have index entries, but I'd rather do something conservatively correct rather than cause a subtle bug due to using the wrong index
 entry.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Will update the bugzilla entry and send a patch.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I may still need help getting a test case for the second problem (the debug metadata on the decl), although I might not be able to look at that for a couple days.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#888888"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#888888">Teresa<o:p></o:p></span></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal"><span style="color:#888888"><o:p> </o:p></span></p>
</div>
<div>
<p class="MsoNormal"><span style="color:#888888">Teresa<o:p></o:p></span></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">On Fri, Jul 29, 2016 at 11:37 PM, Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">Yes, if I drop the debug flag then the original problem (assertion failure) comes back.
</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">Thanks,</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">Taewook</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><b><span style="font-family:Calibri;color:black">From:
</span></b><span style="font-family:Calibri;color:black">Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>><br>
<b>Date: </b>Friday, July 29, 2016 at 3:52 PM</span><o:p></o:p></p>
<div>
<div>
<p class="MsoNormal"><br>
<b>To: </b>Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>><br>
<b>Cc: </b>via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Subject: </b>Re: [llvm-dev] [ThinLTO] assert(GS != DefinedGlobals.end()) failed in FunctionImport.cpp<o:p></o:p></p>
</div>
</div>
</div>
<div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">On Fri, Jul 29, 2016 at 3:40 PM, Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">It was r274523. I’m not sure it was the same module. By mistake I restarted the build with the previous version without backing
 backing up the build artifacts :(</span><o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">So a couple things were added to gold since then, index-based linkonce/weak resolution and some more aggressive internalization. I don't think either of these would have made the
 original problem go away, so I'm guessing that the latter provoked the new problem (in combination with pcc's earlier change to allow metadata attachments on decls that added that verifier assert). Presumably we started internalizing the promoted global, and
 something (presumably a later pass) then dropped the symbol. Let me see if I can provoke that particular issue with a debug ThinLTO build of SPEC (recently I have been testing non-debug). In the meantime, can you drop your debug flag and see if the first problem
 comes back?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Thanks,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Teresa<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">Thanks,</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri">Taewook</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><b><span style="font-family:Calibri;color:black">From:
</span></b><span style="font-family:Calibri;color:black">Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>><br>
<b>Date: </b>Friday, July 29, 2016 at 3:30 PM</span><o:p></o:p></p>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><br>
<b>To: </b>Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>><br>
<b>Cc: </b>via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Subject: </b>Re: [llvm-dev] [ThinLTO] assert(GS != DefinedGlobals.end()) failed in FunctionImport.cpp<o:p></o:p></p>
</div>
</div>
</div>
<div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">On Fri, Jul 29, 2016 at 2:25 PM, Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Hello Teresa,</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Thank you for your analysis. One thing to note is that the global materializer materializes the value as a function declaration, not a function definition. As I pasted on my first email,
</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">; Materializable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">; Function Attrs: nounwind uwtable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">define weak_odr void @foo(%1*) unnamed_addr #7 comdat($comdat1) align 2 personality i32 (...)* @__gxx_personality_v0 {}</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">is materialized to </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">; Function Attrs: nounwind uwtable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">declare void @foo(%"type1"*) unnamed_addr #2 align 2</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Inside IRLinker::linkGlobalValueProto, the materialized value is returned from getLinkedToGlobal(SGV) and assigned to DGV. However, as ForAlias is true and ShouldLink is false, DGV becomes nullptr later, and
 NewGV is created from copyGlobalValueProto(SGV, ShouldLink) call. Therefore, returned value from linkGlobalValueProto is different from the value obtained by ValueMap.lookup(SGV) in IRLinker::materialize.</span><o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Ah, sorry, somehow I completely missed the fact that it was brought in as a decl when I looked this morning.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">  <o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">BTW, I updated LLVM to the latest version in SVN this morning, and the assertion failure is gone. Instead, it ends up with broken module found errors:</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Global is external, but doesn't have external or weak linkage!</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">void (%2*, %2*, i32)* @"_foo.llvm.E5F1952C"</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">function declaration may not have a !dbg attachment</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">void (%2*, %2*, i32)* @"_foo.llvm.E5F1952C"</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">LLVM ERROR: Broken module found, compilation aborted!</span><o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">This looks like a promoted local from the name. What is the linkage type? Is this the verifier run right after the importing pass?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">I'm guessing the first problem went away due to luck, as I can't think of any specific change that would have affected it. Is this from the same module?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Do you know what SVN revision were you at before, even roughly?<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Teresa<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Hope this provides additional clues to fix the issue.
</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Thanks,</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Taewook</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<b><span style="font-family:Calibri;color:black">From: </span></b><span style="font-family:Calibri;color:black">Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>><br>
<b>Date: </b>Friday, July 29, 2016 at 7:05 AM</span><o:p></o:p></p>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><br>
<b>To: </b>Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>><br>
<b>Cc: </b>via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Subject: </b>Re: [llvm-dev] [ThinLTO] assert(GS != DefinedGlobals.end()) failed in FunctionImport.cpp<o:p></o:p></p>
</div>
</div>
</div>
<div>
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
On Thu, Jul 28, 2016 at 5:18 PM, Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Hello Teresa,</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Thank you for your reply. I’m trying to create a small repro but find it hard to nail down because originally it is a big build. This happens with gold linker.</span><o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
I think I need to see a smaller test case, looking through the code I'm not sure how we ended up in this situation. See analysis below.<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Thanks,</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri">Taewook</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-size:11.0pt;font-family:Calibri"> </span><o:p></o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<b><span style="font-family:Calibri;color:black">From: </span></b><span style="font-family:Calibri;color:black">Teresa Johnson <<a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a>><br>
<b>Date: </b>Thursday, July 28, 2016 at 5:08 PM<br>
<b>To: </b>Taewook Oh <<a href="mailto:twoh@fb.com" target="_blank">twoh@fb.com</a>><br>
<b>Cc: </b>via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
<b>Subject: </b>Re: [llvm-dev] [ThinLTO] assert(GS != DefinedGlobals.end()) failed in FunctionImport.cpp</span><o:p></o:p></p>
</div>
<div>
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Hi Taewook, <o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
On Thu, Jul 28, 2016 at 4:38 PM, Taewook Oh via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<o:p></o:p></p>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">Encountered “assert(GS != DefinedGlobals.end())” failure while running ThinLTO. The assertion statement is in MustPreserveGV lambda function in llvm::thinLTOInternalizeModule (lib/Transforms/IPO/FunctionImport.cpp).</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">It seems that the assertion fails because it fails to recover the "original name" of the global value. ModuleSummaryIndex::getOriginalNameBeforePromote attempts to get the original name by stripping .llvm.{HASH}, but what I observe
 is that ".1" is still appended to the expected original name. </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">Then where this extra ".1" comes from? It is appended when the global value is materialized. IRLinker::materialize function calls IRLinker::linkGlobalValueProto function, and inside that function if DGV is nullptr or ShouldLink
 is true then IRLinker::copyGlobalValueProto function is called to create a global variable in the destination module that corresponds to SGV. I found that newly created global variable has the extra ".1" added to the name of the SGV.
</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">When this happens? I don't have a complete understanding but I observed that the same global value is materialized twice during the single invocation of IRLinker::run, once with GlobalValueMaterializer and once with LocalValueMaterializer.
 First, the global value</span><o:p></o:p></p>
</div>
</div>
</blockquote>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
Looking at the IRLinker, it appears this second (local) copy should only be created if there was no copy already linked in from the same source module:<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
In IRLinker::linkGlobalValueProto, we should find the DGV created by the GlobalValueMaterializer for the same SGV (first find it by name, then if ShouldLink==true, we should find it in ValueMap and return that entry, or if ShouldLink==false, since ForAlias=true
 we should return null.<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
Then when linkGlobalValueProto returns, in IRLinker::materialize there is specific handling for this case:<o:p></o:p></p>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
  // When linking a global for an alias, it will always be linked. However we<br>
  // need to check if it was not already scheduled to satify a reference from a<br>
  // regular global value initializer. We know if it has been schedule if the<br>
  // "New" GlobalValue that is mapped here for the alias is the same as the one<br>
  // already mapped. If there is an entry in the ValueMap but the value is<br>
  // different, it means that the value already had a definition in the<br>
  // destination module (linkonce for instance), but we need a new definition<br>
  // for the alias ("New" will be different.<br>
  if (ForAlias && ValueMap.lookup(SGV) == New)<br>
    return New; <o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
AFAICT the only way we should be creating a new local copy is if foo() already had a copy in the dest module. But when we call ThinLTO internalization we are doing so before any function importing. The gold-plugin should have linked the module being compiled
 in the ThinLTO backend into an empty module from thinLTOBackendTask, so we should not already have a copy of foo() in the dest module.<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
I must be missing something...in lieu of a smaller test case, can you trace through what happens when we call linkGlobalValueProto for the local materializer, and see why we don't find the copy of SGV already materialized by the global materializer which should
 be in the ValueMap?<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
Thanks,<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
Teresa<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<div>
<div>
<div>
<div>
<div>
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Yes, the IRLinker will append an integer if it encounters a naming conflict. Normally this would happen in full LTO, but I guess is happening here since we are linking twice due to the alias.<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">; Materializable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">; Function Attrs: nounwind uwtable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">define weak_odr void @foo(%1*) unnamed_addr #7 comdat($comdat1) align 2 personality i32 (...)* @__gxx_personality_v0 {}</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">(I renamed the function and comdat)</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">is materialized with GlobalValueMaterializer, (so the IRLinker::materialize function is called with ForAlias == false), and the materialized value is</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">; Function Attrs: nounwind uwtable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">declare void @foo(%"type1"*) unnamed_addr #2 align 2</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">Then, later, the same value is materialized again with LocalValueMaterializer (so ForAlias == true for IRLinker::materialize), and the materialized value is</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">; Function Attrs: nounwind uwtable</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">define internal void @foo.1(%"type 0x7efb6ee89d80"*) unnamed_addr #2 comdat($comdat1) align 2 personality i32 (...)* @__gxx_personality_v0 !dbg !12345 {</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">  // function definition</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">}</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">(here, “type 0x7efb6ee89d80” is not “type1” )</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">So for me it seems that we need a mechanism to retrieve the original name of the global value even when it is renamed during the materialization. I submitted the bug report as well (<a href="https://urldefense.proofpoint.com/v2/url?u=https-3A__llvm.org_bugs_show-5Fbug.cgi-3Fid-3D28760-29&d=CwMFaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=kOsLCgQzH7N8ptZ7diJD9g&m=XtlNH01OW0mwOi0no2wur-HO6RY5szj-dgWaIcCki-k&s=9pGLGnxeOI3J3lvx9-ayiZJUImAefSzcGGJN5xo9_Kc&e=" target="_blank">https://llvm.org/bugs/show_bug.cgi?id=28760)</a>.</span><o:p></o:p></p>
</div>
</div>
</blockquote>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Interestingly, we are already trying to handle a similar case in that lambda (see the comment about weak values linked in as a local copy due to an alias). However, we weren't anticipating the original weak value being linked in as well, which is causing the
 rename.<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Do you have a small reproducer? Is this with gold? I need to think about the best way to handle this case. One way of course is to conservatively return true if we can't find it in the map, but I don't love that since we may miss other cases that need to be
 handled.<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Thanks,<o:p></o:p></p>
</div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
Teresa<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt;border-top-width:initial;border-right-width:initial;border-bottom-width:initial;border-top-color:initial;border-right-color:initial;border-bottom-color:initial">
<div>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt"> </span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">Thanks,</span><o:p></o:p></p>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-m1800117222592206986gmail-msonormal">
<span style="font-size:11.0pt">Taewook</span><o:p></o:p></p>
</div>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal" style="margin-bottom:12.0pt">
<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Ddev&d=CwMFaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=kOsLCgQzH7N8ptZ7diJD9g&m=XtlNH01OW0mwOi0no2wur-HO6RY5szj-dgWaIcCki-k&s=eA2ODuBrwjiWfuW-_sPfCVr1H774iHS5j89ydb7KY2E&e=" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><o:p></o:p></p>
</blockquote>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
-- <o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-family:Helvetica;color:#555555">Teresa Johnson |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> Software Engineer |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a></span><o:p></o:p></p>
</td>
</tr>
</tbody>
</table>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-m-1862324745509867527gmail-msonormal">
 <o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
-- <o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-family:Helvetica;color:#555555">Teresa Johnson |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> Software Engineer |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in;border-right-width:initial;border-bottom-width:initial;border-left-width:initial;border-right-color:initial;border-bottom-color:initial;border-left-color:initial">
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
<span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a></span><o:p></o:p></p>
</td>
</tr>
</tbody>
</table>
<p class="m-1612198669786183669m-7125561629070243100m-1658867611952278216m2823919404413710213m7471924872012567099gmail-msonormal">
 <o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">--
<o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555">Teresa Johnson |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> Software Engineer |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a></span><o:p></o:p></p>
</td>
</tr>
</tbody>
</table>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">--
<o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555">Teresa Johnson |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> Software Engineer |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |</span><o:p></o:p></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a></span><o:p></o:p></p>
</td>
</tr>
</tbody>
</table>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<p class="MsoNormal"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<p class="MsoNormal">-- <o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555">Teresa Johnson |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> Software Engineer |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a><o:p></o:p></span></p>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
</div>
</div>
<div>
<div>
<p class="MsoNormal"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<p class="MsoNormal">-- <o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555">Teresa Johnson |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> Software Engineer |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> <a href="tel:408-460-2413" target="_blank">408-460-2413</a><o:p></o:p></span></p>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<p class="MsoNormal"><br>
<br clear="all">
<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<p class="MsoNormal">-- <o:p></o:p></p>
<div>
<table class="MsoNormalTable" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td nowrap="" style="border:none;border-top:solid #D50F25 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555">Teresa Johnson |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #3369E8 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> Software Engineer |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #009939 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> <a href="mailto:tejohnson@google.com" target="_blank">tejohnson@google.com</a> |<o:p></o:p></span></p>
</td>
<td nowrap="" style="border:none;border-top:solid #EEB211 1.5pt;padding:0in 0in 0in 0in">
<p class="MsoNormal"><span style="font-family:Helvetica;color:#555555"> 408-460-2413<o:p></o:p></span></p>
</td>
</tr>
</tbody>
</table>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
</div>
</div>
</div>
</body>
</html>