<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - daemon shouldn't depend on libpulse"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=55180#c8">Comment # 8</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - daemon shouldn't depend on libpulse"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=55180">bug 55180</a>
              from <span class="vcard"><a class="email" href="mailto:pierre-bugzilla@ossman.eu" title="Pierre Ossman <pierre-bugzilla@ossman.eu>"> <span class="fn">Pierre Ossman</span></a>
</span></b>
        <pre>(In reply to <a href="show_bug.cgi?id=55180#c5">comment #5</a>)
<span class="quote">> 
> Applications can't use the functions in libpulsecommon without linking to it
> directly, and they should not link to it directly.
> </span >

Actually they can. A short primer on ELF dynamic linking:

When you create an ELF binary, two lists gets put in the result:

 a) A list of missing symbols. E.g. malloc() and pa_simple_new().

 b) A list of _suggested_ libraries where these symbols can be found.

These two lists are not connected in any way. There is no information about
which symbol comes from where, or even if all libraries are needed or
sufficient.

At runtime the system will load all the libraries in list b). It will also load
all libraries that they depend on. So libpulse.so is in b), but
libpulsecommon.so will also get loaded in round 2 because libpulse.so depends
on it.

After this is done, it will start resolving symbols. libpulse.so gets priority
because it was loaded first, but it will not refrain from also looking in
libpulsecommon.so for symbols.


In other words; an application will see all the symbols of your library, _plus_
all the symbols of each and every library that gets loaded as a dependency.


The only fool-proof way of hiding symbols is to put everything in a single .so
file and completely avoid putting those symbols in the export list. Once you
have two .so files you've already lost.

The more common approach is to not try to prevent misuse, but to encourage
proper use. Do this by documenting. No one is going to run objdump on your .so
files to figure out the API. They will be reading your headers and
documentation. So use those files to clearly separate public from private
stuff.

<span class="quote">> Having separate copies of the common functionality in libpulse and
> libpulsecore sounds reasonable to me. It would somewhat increase the size on
> disk and memory, but that doesn't sound too bad to me. libpulsecommon could
> still exist as a static library (included in libpulse and libpulsecore) to
> avoid compiling things twice. To see if others have different views, I think
> it would be a good idea to bring up this topic on the mailing list, if
> you're going to work on this.</span >

Not entirely sure libtool will let us to the right thing here. Static libraries
usually don't get compiled with -fPIC. And getting an entire .a file linked is
generally a bit pesky. I don't think compile time is that much of a problem?

<span class="quote">> 
> BTW, are you having some practical problems with the current setup, or do
> you want to fix this only because it's ugly to link the daemon to libpulse?</span >

Sorry, it was a while since I did this so I've forgotten the details. :/
The primary issue was reducing the amount of stuff we needed to ship though.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the QA Contact for the bug.</li>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>