<html>
    <head>
      <base href="https://bugs.freedesktop.org/">
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED - initial-exec TLS model breaks dlopen'ed libGL"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=35268#c27">Comment # 27</a>
              on <a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED - initial-exec TLS model breaks dlopen'ed libGL"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=35268">bug 35268</a>
              from <span class="vcard"><a class="email" href="mailto:bugdal@aerifal.cx" title="Rich Felker <bugdal@aerifal.cx>"> <span class="fn">Rich Felker</span></a>
</span></b>
        <pre>A couple issues with latest patches by Sora Lee:

1. There is no need for __attribute__((__tls_model__("global-dynamic"))). It's
rightly the default whenever it's needed by the ABI. The attribute should just
be removed.

2. There's at least one more place where the invalid initial-exec asm is
duplicated, in src/mapi/entry_x86{,-64}_tls.h.

3. Per the ABI, calling the TLSDESC function requires the stack pointer to be
aligned mod 16 (as for all function calls). This might not break in practice
but should be done.

I have a draft patch with all of these changes that seems to be working. Once I
check it over again I'll post it here.

Perhaps more to the point, though, the asm seems largely useless and I think it
should just be removed. Modern GCC generates exactly the same code for the C
stubs as what you get by doing the TLSDESC access in asm, except for some
functions that take char args where gcc performs a spurious zero/sign-extend
operation on the argument regissters before tail-calling through the dispatch.
Supposedly this is a known gcc bug that's going to be improved in gcc 9.</pre>
        </div>
      </p>


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

      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>