<html>
    <head>
      <base href="https://bugs.llvm.org/">
    </head>
    <body><span class="vcard"><a class="email" href="mailto:richard-llvm@metafoo.co.uk" title="Richard Smith <richard-llvm@metafoo.co.uk>"> <span class="fn">Richard Smith</span></a>
</span> changed
          <a class="bz_bug_link 
          bz_status_RESOLVED  bz_closed"
   title="RESOLVED INVALID - Non-const extern successfully link with const value"
   href="https://bugs.llvm.org/show_bug.cgi?id=39069">bug 39069</a>
          <br>
             <table border="1" cellspacing="0" cellpadding="8">
          <tr>
            <th>What</th>
            <th>Removed</th>
            <th>Added</th>
          </tr>

         <tr>
           <td style="text-align:right;">Status</td>
           <td>NEW
           </td>
           <td>RESOLVED
           </td>
         </tr>

         <tr>
           <td style="text-align:right;">Resolution</td>
           <td>---
           </td>
           <td>INVALID
           </td>
         </tr>

         <tr>
           <td style="text-align:right;">CC</td>
           <td>
                
           </td>
           <td>richard-llvm@metafoo.co.uk
           </td>
         </tr></table>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_RESOLVED  bz_closed"
   title="RESOLVED INVALID - Non-const extern successfully link with const value"
   href="https://bugs.llvm.org/show_bug.cgi?id=39069#c1">Comment # 1</a>
              on <a class="bz_bug_link 
          bz_status_RESOLVED  bz_closed"
   title="RESOLVED INVALID - Non-const extern successfully link with const value"
   href="https://bugs.llvm.org/show_bug.cgi?id=39069">bug 39069</a>
              from <span class="vcard"><a class="email" href="mailto:richard-llvm@metafoo.co.uk" title="Richard Smith <richard-llvm@metafoo.co.uk>"> <span class="fn">Richard Smith</span></a>
</span></b>
        <pre>(In reply to Oleg Doronin from <a href="show_bug.cgi?id=39069#c0">comment #0</a>)
<span class="quote">> For the code below, I get a link error for compiler msvc on Windows, but
> clang on Linux successfully compiles, but when I run the executable I get
> segfault. Is this behavior correct?</span >

Yes.

<span class="quote">>   3. I opened the ELF format document and found no information about how to
> differentiate between const and non-const.</span >

There is no relevant difference, neither in ELF nor in the name mangling scheme
used on Linux.

<span class="quote">>   4. At the same time msvc compiler is able to specify additional
> information for extern const</span >

The name decoration scheme used on Windows includes the type of a global
variable as part of its name, which is why you happen to get a link error
there.

<span class="quote">> Can anyone explain in more detail why this is so done, not the other way
> around?</span >

Your program is ill-formed, with no diagnostic required, due to the type
mismatch between the declaration and definition of A. That means that anything
can happen -- the program can be rejected by the linker, or crash, or appear to
"work", or something else.

The name mangling scheme used on Linux only attempts to distinguish entities
where both can validly appear in the same program. As a result, it does not
include extraneous information such as the return type of a non-template
function or the type of a global variable, and cannot detect programming errors
such as this.

The name decoration scheme used on Windows includes more information in cases
like this, allowing it to detect bugs such as the one in your program (at the
cost of making symbol names more complex).

So this is all working as it should.

(For your future reference, requests for information such as "can someone
explain what's going on here" where you're not sure there's a bug are often
better suited for mailing list discussions rather than as bug reports -- the
cfe-dev list would have been a good choice for this query.)</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>