<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882" 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=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:SimSun;
        panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:SimSun;
        panose-1:2 1 6 0 3 1 1 1 1 1;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        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",serif;}
span.EmailStyle17
        {mso-style-type:personal;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.25in 1.0in 1.25in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal"><a name="_MailEndCompose"><span style="color:#1F497D">I’ve submitted a BZ for this issue as below:<o:p></o:p></span></a></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p style="margin:0in;margin-bottom:.0001pt"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:black">Bug 42626 - lld-link crash when build openssl with LTO<o:p></o:p></span></p>
<p style="margin:0in;margin-bottom:.0001pt"><a href="https://bugs.llvm.org/show_bug.cgi?id=42626"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif">https://bugs.llvm.org/show_bug.cgi?id=42626</span></a><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:black"><o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><span style="color:#1F497D">Thanks<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:#1F497D">Steven<o:p></o:p></span></p>
</div>
<p class="MsoNormal"><span style="color:#1F497D"><o:p> </o:p></span></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><a name="_____replyseparator"></a><b>From:</b> llvm-dev [mailto:llvm-dev-bounces@lists.llvm.org]
<b>On Behalf Of </b>Shi, Steven via llvm-dev<br>
<b>Sent:</b> Monday, July 15, 2019 4:40 PM<br>
<b>To:</b> 'Rui Ueyama' <ruiu@google.com><br>
<b>Cc:</b> llvm-dev@lists.llvm.org<br>
<b>Subject:</b> [llvm-dev] lld-link crash when build openssl with LTO<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Hi Rui,<o:p></o:p></p>
<p class="MsoNormal">We met a lld-link crash problem when build 32bits openssl1.0 with LTO in uefi firmware. We narrow down and figure out a simple test case to reproduce this problem as blow. Please advise. Thank you!<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">$ cat main.c<o:p></o:p></p>
<p class="MsoNormal">void TlsDriverEntryPoint ()<o:p></o:p></p>
<p class="MsoNormal">{<o:p></o:p></p>
<p class="MsoNormal">  unsigned char *ret = 0;<o:p></o:p></p>
<p class="MsoNormal">  const unsigned char cryptopro_ext[17] = {0x00,0x00,0x00,0x00, 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01};<o:p></o:p></p>
<p class="MsoNormal">  int length =17;<o:p></o:p></p>
<p class="MsoNormal">  const char *Source;<o:p></o:p></p>
<p class="MsoNormal">  Source  = (void*)cryptopro_ext;<o:p></o:p></p>
<p class="MsoNormal">  while (length--) {<o:p></o:p></p>
<p class="MsoNormal">    *(ret++) = *(Source++);<o:p></o:p></p>
<p class="MsoNormal">  }<o:p></o:p></p>
<p class="MsoNormal">}<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">$ cat memcpy.c<o:p></o:p></p>
<p class="MsoNormal">typedef unsigned int size_t;<o:p></o:p></p>
<p class="MsoNormal">void *memcpy(void *dest, const void *src, size_t n)<o:p></o:p></p>
<p class="MsoNormal">{<o:p></o:p></p>
<p class="MsoNormal">  return 0;<o:p></o:p></p>
<p class="MsoNormal">}<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">$ cat makefile<o:p></o:p></p>
<p class="MsoNormal">CC_FLAGS=  -Oz -flto -target i686-unknown-windows<o:p></o:p></p>
<p class="MsoNormal">CC = /home/jshi19/llvm/llvm-project/releaseinstall/bin/clang<o:p></o:p></p>
<p class="MsoNormal">DLINK_FLAGS = /MACHINE:X86 /DLL /ENTRY:TlsDriverEntryPoint<o:p></o:p></p>
<p class="MsoNormal">DLINK = /home/jshi19/llvm/llvm-project/releaseinstall/bin/lld-link<o:p></o:p></p>
<p class="MsoNormal">SLINK_FLAGS =<o:p></o:p></p>
<p class="MsoNormal">SLINK = /home/jshi19/llvm/llvm-project/releaseinstall/bin/llvm-lib<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">build:<o:p></o:p></p>
<p class="MsoNormal">        "$(CC)" $(CC_FLAGS) -c -o main.obj  main.c<o:p></o:p></p>
<p class="MsoNormal">        "$(CC)" $(CC_FLAGS) -c -o memcpy.obj  memcpy.c<o:p></o:p></p>
<p class="MsoNormal">        "$(SLINK)" $(SLINK_FLAGS) /OUT:main.lib main.obj<o:p></o:p></p>
<p class="MsoNormal">        "$(SLINK)" $(SLINK_FLAGS) /OUT:memcpy.lib memcpy.obj<o:p></o:p></p>
<p class="MsoNormal">        "$(DLINK)" /OUT:f.dll $(DLINK_FLAGS) main.lib  memcpy.lib<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">$ make<o:p></o:p></p>
<p class="MsoNormal">"/home/jshi19/llvm/llvm-project/releaseinstall/bin/clang" -Oz -flto -target i686-unknown-windows -c -o main.obj  main.c<o:p></o:p></p>
<p class="MsoNormal">"/home/jshi19/llvm/llvm-project/releaseinstall/bin/clang" -Oz -flto -target i686-unknown-windows -c -o memcpy.obj  memcpy.c<o:p></o:p></p>
<p class="MsoNormal">"/home/jshi19/llvm/llvm-project/releaseinstall/bin/llvm-lib"  /OUT:main.lib main.obj<o:p></o:p></p>
<p class="MsoNormal">"/home/jshi19/llvm/llvm-project/releaseinstall/bin/llvm-lib"  /OUT:memcpy.lib memcpy.obj<o:p></o:p></p>
<p class="MsoNormal">"/home/jshi19/llvm/llvm-project/releaseinstall/bin/lld-link" /OUT:f.dll /MACHINE:X86 /DLL /ENTRY:TlsDriverEntryPoint  main.lib  memcpy.lib<o:p></o:p></p>
<p class="MsoNormal">Stack dump:<o:p></o:p></p>
<p class="MsoNormal">0.      Program arguments: /home/jshi19/llvm/llvm-project/releaseinstall/bin/lld-link /OUT:f.dll /MACHINE:X86 /DLL /ENTRY:TlsDriverEntryPoint main.lib memcpy.lib<o:p></o:p></p>
<p class="MsoNormal">#0 0x000055f11ed8585a llvm::sys::PrintStackTrace(llvm::raw_ostream&) /home/jshi19/llvm/llvm-project/llvm/lib/Support/Unix/Signals.inc:498:0<o:p></o:p></p>
<p class="MsoNormal">#1 0x000055f11ed83684 llvm::sys::RunSignalHandlers() /home/jshi19/llvm/llvm-project/llvm/lib/Support/Signals.cpp:68:0<o:p></o:p></p>
<p class="MsoNormal">#2 0x000055f11ed837c2 SignalHandler(int) /home/jshi19/llvm/llvm-project/llvm/lib/Support/Unix/Signals.inc:357:0<o:p></o:p></p>
<p class="MsoNormal">#3 0x00007f172a5f2890 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x12890)<o:p></o:p></p>
<p class="MsoNormal">#4 0x000055f11edd8025 lld::coff::DefinedRegular::getChunk() const /home/jshi19/llvm/llvm-project/lld/COFF/Symbols.h:176:0<o:p></o:p></p>
<p class="MsoNormal">#5 0x000055f11edd8025 operator() /home/jshi19/llvm/llvm-project/lld/COFF/MarkLive.cpp:46:0<o:p></o:p></p>
<p class="MsoNormal">#6 0x000055f11edd8025 lld::coff::markLive(llvm::ArrayRef<lld::coff::Chunk*>) /home/jshi19/llvm/llvm-project/lld/COFF/MarkLive.cpp:55:0<o:p></o:p></p>
<p class="MsoNormal">#7 0x000055f11edb763e std::vector<lld::coff::Chunk*, std::allocator<lld::coff::Chunk*> >::~vector() /usr/include/c++/7/bits/stl_vector.h:434:0<o:p></o:p></p>
<p class="MsoNormal">#8 0x000055f11edb763e lld::coff::LinkerDriver::link(llvm::ArrayRef<char const*>) /home/jshi19/llvm/llvm-project/lld/COFF/Driver.cpp:1840:0<o:p></o:p></p>
<p class="MsoNormal">#9 0x000055f11edb7d08 lld::coff::link(llvm::ArrayRef<char const*>, bool, llvm::raw_ostream&) /home/jshi19/llvm/llvm-project/lld/COFF/Driver.cpp:78:0<o:p></o:p></p>
<p class="MsoNormal">#10 0x000055f11ecfa044 main /home/jshi19/llvm/llvm-project/lld/tools/lld/lld.cpp:155:0<o:p></o:p></p>
<p class="MsoNormal">#11 0x00007f17290c9b97 __libc_start_main /build/glibc-OTsEL5/glibc-2.27/csu/../csu/libc-start.c:344:0<o:p></o:p></p>
<p class="MsoNormal">#12 0x000055f11ed555ba _start (/home/jshi19/llvm/llvm-project/releaseinstall/bin/lld-link+0x25a5ba)<o:p></o:p></p>
<p class="MsoNormal">Segmentation fault (core dumped)<o:p></o:p></p>
<p class="MsoNormal">makefile:12: recipe for target 'build' failed<o:p></o:p></p>
<p class="MsoNormal">make: *** [build] Error 139<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Steven<o:p></o:p></p>
<p class="MsoNormal">Thanks<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</div>
</body>
</html>