Hi,

While research requirements for binary package soname dependencies [1],
I found that the NEEDED.ELF.2 data that portage generates contains
insufficient information to uniquely distinguish all of the multilib
ABIs that may be present on a given system [2]. In order to correctly
handle multilib ABIs for binary package soname dependencies,
preserve-libs, and other possible applications involving GLEP 64 [1], we
will need more information than is currently recorded in NEEDED.ELF.2.

In order to solve this problem, I propose that we extend NEEDED.ELF.2 to
include a new field containing a multilib ABI identifier. The extension
will be backward-compatible, and NEEDED.ELF.2 will only need to be
regenerated on systems with multilib ABIs that are otherwise
indistinguishable (multilib x32 and mips systems).

The naming convention for the multilib ABI identifiers can be derived
from the set of abi_* USE flags that has been established by the
gx86-multilib project [4]. For example, if we exclude the abi_ prefix,
and apply this convention to all supported architectures, then the
complete set of multilib ABI identifiers will be as follows:

        alpha_{32,64}
        arm_{32,64}
        hppa_{32,64}
        ia_{32,64}
        m68k_{32,64}
        mips_{eabi32,eabi64,n32,n64,o32,o64}
        ppc_{32,64}
        s390_{32,64}
        sh_{32,64}
        sparc_{32,64}
        x86_{32,64,x64}

The ABIs referenced by some of the above *_32 and *_64 identifiers may
be imaginary, but they are listed anyway, since the goal is to establish
a naming convention that is as consistent and uniform as possible. The
OS is notably absent from these identifiers, since OS-independence is
one of the goals. The assumption is that, for a given installation, we
are only interested in tracking multilib ABIs for a single OS.

I have attached a python script to bug 534206 [2] that can serve as a
reference implementation, demonstrating how a file's ELF header can be
used to compute a suitable multilib ABI identifier.

Please respond with any feedback that you may have about this proposal.

[1] http://thread.gmane.org/gmane.linux.gentoo.devel/94145
[2] https://bugs.gentoo.org/show_bug.cgi?id=534206
[3] https://wiki.gentoo.org/wiki/GLEP:64
[4] https://wiki.gentoo.org/wiki/Gx86-multilib
-- 
Thanks,
Zac

Reply via email to