<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:x="urn:schemas-microsoft-com:office:excel" 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=utf-8">
<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:等线;
        panose-1:2 1 6 0 3 1 1 1 1 1;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:"\@等线";
        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:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.msonormal0, li.msonormal0, div.msonormal0
        {mso-style-name:msonormal;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@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="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal">Thanks Martin.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Hi net-dev, and/or security-dev Reviewers,<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Please help review and sponsor this patch if acceptable. <o:p>
</o:p></p>
<p class="MsoNormal">It does not tend to bring any functionality changes, instead to propose an early fix, for the build (linking) errors with further toolchain (GCC 10).
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">JBS: <a href="https://bugs.openjdk.java.net/browse/JDK-8235903" target="_blank">
https://bugs.openjdk.java.net/browse/JDK-8235903</a> <br>
Webrev: <a href="http://cr.openjdk.java.net/~qpzhang/8235903/webrev.01/" target="_blank">
http://cr.openjdk.java.net/~qpzhang/8235903/webrev.01/</a><o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Regards<o:p></o:p></p>
<p class="MsoNormal">Patrick<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><b>From:</b> Martin Buchholz <martinrb@google.com> <br>
<b>Sent:</b> Monday, December 16, 2019 10:44 AM<br>
<b>To:</b> Patrick Zhang OS <patrick@os.amperecomputing.com>; net-dev <net-dev@openjdk.java.net>; OpenJDK <security-dev@openjdk.java.net><br>
<b>Cc:</b> core-libs-dev <core-libs-dev@openjdk.java.net><br>
<b>Subject:</b> Re: RFR: JDK-8235903: GCC default -fno-common exposes "multiple definition" link errors<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">forwarded to other teams for review.<o:p></o:p></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">On Fri, Dec 13, 2019 at 3:14 AM Patrick Zhang OS <<a href="mailto:patrick@os.amperecomputing.com">patrick@os.amperecomputing.com</a>> wrote:<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">
<p class="MsoNormal" style="margin-bottom:12.0pt">Hi <br>
<br>
Please review this patch, if it should be reviewed by any group other than core-libs, please help forward it. Thanks.<br>
<br>
JBS: <a href="https://bugs.openjdk.java.net/browse/JDK-8235903" target="_blank">https://bugs.openjdk.java.net/browse/JDK-8235903</a>
<br>
Webrev: <a href="http://cr.openjdk.java.net/~qpzhang/8235903/webrev.01/" target="_blank">
http://cr.openjdk.java.net/~qpzhang/8235903/webrev.01/</a><br>
<br>
A recent GCC patch (supposed to be in GCC 10) exposes a couple of "multiple definition" link errors when building the jdk tip.<br>
<br>
[PATCH] PR85678: Change default to -fno-common<br>
<a href="https://gcc.gnu.org/ml/gcc-patches/2019-10/msg01847.html" target="_blank">https://gcc.gnu.org/ml/gcc-patches/2019-10/msg01847.html</a>
<br>
<br>
For example, the error message looks like:<br>
* For target support_native_java.base_libjava_BUILD_LIBJAVA_link:<br>
build/support/native/java.base/libjava/childproc.o:(.bss+0x0): multiple definition of `parentPathv'<br>
build/support/native/java.base/libjava/ProcessImpl_md.o:(.bss+0x0): first defined here<br>
collect2: error: ld returned 1 exit status<br>
<br>
This was not an issue because the original default -fcommon allowed "global variables defined without an initializer" be handled as COMMON symbols, so it would not warn the problem like "same variable is accidentally defined in more than one compilation unit".<br>
<br>
About -fcommon vs -fno-cmmon:<br>
<a href="https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#index-fno-common" target="_blank">https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#index-fno-common</a>
<br>
<br>
Moving forward, building jdk with latest versions of GCC will trigger this error. Specifying "--with-extra-cflags='-fcommon'"  can make it work, but it just got things hidden again.<br>
<br>
In addition, -fcommon's behavior "is inconsistent with C++, and on many targets implies a speed and code size penalty on global variable references. It is mainly useful to enable legacy code to link without errors."<br>
<br>
Last, in case that other jdk developers would revisit this problem once again, I suggest fixing the error explicitly instead of using "-fcommon"<br>
<br>
Regards<br>
Patrick<o:p></o:p></p>
</blockquote>
</div>
</div>
</body>
</html>