From: Remy Bohmer <linux@bohmer.net>
To: ptxdist@pengutronix.de
Subject: [ptxdist] [PATCH v4 3/7] [x86_64, multilib] Make packages install their libraries at the right place
Date: Sun, 25 Mar 2012 20:31:36 +0200 [thread overview]
Message-ID: <1332700300-25180-3-git-send-email-linux@bohmer.net> (raw)
In-Reply-To: <1332700300-25180-1-git-send-email-linux@bohmer.net>
While cross-compiling for x86_64 in a multilib configuration we need to
install the libraries conform the Filesystem Hierarchy Standard (FHS).
Summarised this will be for multilib:
* All libraries compiled for and used in 64-bit applications need to be
installed in /lib64 or /usr/lib64.
* All libraries compiled for and used in 32-bit applications need to be
installed in /lib or /usr/lib.
* All executables will still find its way in the regular /bin and /sbin
paths.
* The Operating System itself and all its libraries should only be compiled
in 64 bit mode. It should not be a mix between 32 and 64 bit libraries.
32 bit support will only contain the libraries that are required by
32-bit-applications to link against.
This is also conform what many distros derived from Redhat have in their
setup. Note that Debian based distros follow a somewhat different setup.
Note that we use the compiler toolchain to tell us at which paths we
need to install the libraries. This means that if you build for a x86_64
target _without_ multilib support the libraries will likely end up in the
classical /lib and /usr/lib directories, but that is completely steered
by the compiler toolchain configuration. (it follows the location where
the corresponding dynamic linker is expected to be installed)
So, this change makes ptxdist follow the sysroot of the compiler toolchain
more such that preliminary multilib support can be achieved. Preliminary
in the sense that only still one C-library is being installed.
In another changeset the support for a 2nd C-library installation will be
added. At least after this change (and a few subsequent ptxdist makefile
fixes) the /lib and /usr/lib area will only contain the contents that belong
there in multilib environment.
Signed-off-by: Remy Bohmer <linux@bohmer.net>
---
rules/pre/Rules.make | 6 ++++--
rules/termcap.make | 3 ++-
scripts/lib/ptxd_make_00-init.sh | 20 ++++++++++++++++++--
scripts/lib/ptxd_make_xpkg_pkg.sh | 7 +++++--
4 files changed, 29 insertions(+), 7 deletions(-)
diff --git a/rules/pre/Rules.make b/rules/pre/Rules.make
index 1d6da52..1d09a18 100644
--- a/rules/pre/Rules.make
+++ b/rules/pre/Rules.make
@@ -174,6 +174,8 @@ CROSS_ENV_PROGS := \
$(CROSS_ENV_CPP_FOR_BUILD) \
$(CROSS_ENV_LINK_FOR_BUILD)
+CROSS_LIB_DIR := $(shell ptxd_get_lib_dir)
+
#
# prepare to use pkg-config with wrapper which takes care of
# $(PTXDIST_SYSROOT_TARGET). The wrapper's magic doesn't work when
@@ -266,10 +268,10 @@ CROSS_ENV := \
#
CROSS_AUTOCONF_SYSROOT_USR := \
- --prefix=/usr --sysconfdir=/etc --localstatedir=/var
+ --prefix=/usr --sysconfdir=/etc --localstatedir=/var --libdir=/usr/$(CROSS_LIB_DIR)
CROSS_AUTOCONF_SYSROOT_ROOT := \
- --prefix=
+ --libdir=/$(CROSS_LIB_DIR) --prefix=
CROSS_AUTOCONF_ARCH := \
--host=$(PTXCONF_GNU_TARGET) \
diff --git a/rules/termcap.make b/rules/termcap.make
index 4222840..4cbcb5a 100644
--- a/rules/termcap.make
+++ b/rules/termcap.make
@@ -44,7 +44,8 @@ TERMCAP_ENV := $(CROSS_ENV)
# autoconf
#
TERMCAP_AUTOCONF := \
- $(CROSS_AUTOCONF_ROOT) \
+ --prefix= \
+ $(CROSS_AUTOCONF_ARCH) \
--enable-install-termcap
# ----------------------------------------------------------------------------
diff --git a/scripts/lib/ptxd_make_00-init.sh b/scripts/lib/ptxd_make_00-init.sh
index eed2a2e..bd8f6a0 100644
--- a/scripts/lib/ptxd_make_00-init.sh
+++ b/scripts/lib/ptxd_make_00-init.sh
@@ -137,6 +137,19 @@ ptxd_init_collectionconfig() {
#
+# out: 'lib' or 'lib64', derived from the ld-{linux,uClibc}.so.? from the compiler toolchain
+#
+ptxd_get_lib_dir() {
+ local dl lib_dir
+
+ dl="$(ptxd_cross_cc_v | \
+ sed -n -e 's/.* -dynamic-linker \([^ ]*\).*/\1/p')"
+ lib_dir="${dl%%/ld-*.so.*}"
+ echo "${lib_dir#/}"
+}
+export -f ptxd_get_lib_dir
+
+#
# setup compiler and pkgconfig environment
#
# in:
@@ -158,6 +171,9 @@ ptxd_init_cross_env() {
prefix=( ${PTXDIST_PATH_SYSROOT_PREFIX} )
IFS="${orig_IFS}"
+ local -a lib_dir
+ lib_dir=$(ptxd_get_lib_dir)
+
# add "-isystem <DIR>/include"
local -a cppflags
cppflags=( "${prefix[@]/%//include}" )
@@ -165,7 +181,7 @@ ptxd_init_cross_env() {
# add "-L<DIR>/lib -Wl,-rpath-link -Wl,<DIR>"
local -a ldflags
- ldflags=( "${prefix[@]/%//lib}" )
+ ldflags=( "${prefix[@]/%//${lib_dir}}" )
ldflags=( "${ldflags[@]/#/-L}" "${ldflags[@]/#/-Wl,-rpath-link -Wl,}" )
export \
@@ -184,7 +200,7 @@ ptxd_init_cross_env() {
# add <DIR>/lib/pkgconfig and <DIR>/share/pkgconfig
local -a pkg_libdir
- pkg_libdir=( "${prefix[@]/%//lib/pkgconfig}" "${prefix[@]/%//share/pkgconfig}" )
+ pkg_libdir=( "${prefix[@]/%//${lib_dir}/pkgconfig}" "${prefix[@]/%//share/pkgconfig}" )
#
# PKG_CONFIG_PATH contains additional pkg-config search
diff --git a/scripts/lib/ptxd_make_xpkg_pkg.sh b/scripts/lib/ptxd_make_xpkg_pkg.sh
index c03f19e..73ff2c2 100644
--- a/scripts/lib/ptxd_make_xpkg_pkg.sh
+++ b/scripts/lib/ptxd_make_xpkg_pkg.sh
@@ -597,6 +597,8 @@ ptxd_install_spec() {
export -f ptxd_install_spec
ptxd_install_package() {
+ local lib_dir=$(ptxd_get_lib_dir)
+
for dir in "${pkg_pkg_dir}/"{,usr/}{bin,sbin,libexec}; do
find "${dir}" \( -type f -o -type l \) \
-perm /111 2>/dev/null | while read file; do
@@ -605,7 +607,7 @@ ptxd_install_package() {
done
done
- for dir in "${pkg_pkg_dir}/"{,usr/}lib; do
+ for dir in "${pkg_pkg_dir}/"{,usr/}${lib_dir}; do
find "${dir}" \( -type f -o -type l \) \
-a -name "*.so*" 2>/dev/null | while read file; do
ptxd_install_generic - "${file#${pkg_pkg_dir}}" ||
@@ -635,10 +637,11 @@ ptxd_install_shared() {
export -f ptxd_install_shared
ptxd_install_lib() {
+ local lib_dir=$(ptxd_get_lib_dir)
local lib="$1"
shift
- local file="$(for dir in "${pkg_pkg_dir}/"{,usr/}lib; do
+ local file="$(for dir in "${pkg_pkg_dir}/"{,usr/}${lib_dir}; do
find "${dir}" -type f -path "${dir}/${lib}.so*"; done 2>/dev/null)"
if [ ! -f "${file}" ]; then
--
1.7.5.4
--
ptxdist mailing list
ptxdist@pengutronix.de
next prev parent reply other threads:[~2012-03-25 18:31 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-25 18:31 [ptxdist] [PATCH v4 1/7] [x86_64] libgcc need to be install in /lib64 instead of /lib Remy Bohmer
2012-03-25 18:31 ` [ptxdist] [PATCH v4 2/7] [x86_64, multilib] Remove all hardcoded paths from glibc.make Remy Bohmer
2012-03-28 10:52 ` Michael Olbrich
2012-03-28 15:24 ` Remy Bohmer
2012-03-25 18:31 ` Remy Bohmer [this message]
2012-03-27 14:13 ` [ptxdist] [PATCH v4 3/7] [x86_64, multilib] Make packages install their libraries at the right place Michael Olbrich
2012-03-27 19:57 ` Remy Bohmer
2012-03-25 18:31 ` [ptxdist] [PATCH v4 4/7] [x86_64, multilib] Install Zlib " Remy Bohmer
2012-03-25 18:31 ` [ptxdist] [PATCH v4 5/7] [x86_64, multilib] Install Ncurses " Remy Bohmer
2012-03-25 18:31 ` [ptxdist] [PATCH v4 6/7] [x86_64, multilib] Install Readline " Remy Bohmer
2012-03-27 14:09 ` Michael Olbrich
2012-03-27 17:07 ` Remy Bohmer
2012-03-25 18:31 ` [ptxdist] [PATCH v4 7/7] [x86_64, multilib] Install Procps " Remy Bohmer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1332700300-25180-3-git-send-email-linux@bohmer.net \
--to=linux@bohmer.net \
--cc=ptxdist@pengutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox