From: Saul Wold <sgw@linux.intel.com>
To: Patches and discussions about the oe-core layer
<openembedded-core@lists.openembedded.org>
Subject: Re: [PATCH BUG #1236 2/3] eglibc: Modify ldd script according to multilib config.
Date: Mon, 01 Aug 2011 10:52:26 -0700 [thread overview]
Message-ID: <4E36E7DA.9060605@linux.intel.com> (raw)
In-Reply-To: <320728d419fe369c9b660bb6e746dfc908c6e8e6.1312195779.git.lianhao.lu@intel.com>
On 08/01/2011 04:02 AM, Lianhao Lu wrote:
> Part fix of [BUGID #1236].
>
This should be [YOCTO #1236]
> 1. Collect all the values for RTLDLIST for the current multilib
> configuration to modify the ldd scripts.
>
> 2. Collect all the values for KNOWN_INTERPRETER_NAMES for the current
> multilib configuration.
>
> Signed-off-by: Lianhao Lu<lianhao.lu@intel.com>
> ---
> meta/classes/utils.bbclass | 10 ++----
> meta/recipes-core/eglibc/eglibc-ld.inc | 49 +++++++++++++++++++++++++++++++
> meta/recipes-core/eglibc/eglibc.inc | 1 +
> meta/recipes-core/eglibc/eglibc_2.13.bb | 6 +++-
> 4 files changed, 58 insertions(+), 8 deletions(-)
> create mode 100644 meta/recipes-core/eglibc/eglibc-ld.inc
>
> diff --git a/meta/classes/utils.bbclass b/meta/classes/utils.bbclass
> index f8adaea..ef4d8fb 100644
> --- a/meta/classes/utils.bbclass
> +++ b/meta/classes/utils.bbclass
> @@ -361,13 +361,9 @@ def all_multilib_tune_values(d, var, unique=True):
> variants = d.getVar("MULTILIB_VARIANTS", True) or ""
> for item in variants.split():
> localdata = bb.data.createCopy(d)
> - #Fix ME. OVERRIDES not work, we have to set DEFAULTTUNE to TUNENAME
> - #overrides = localdata.getVar("OVERRIDES", False) + ":virtclass-multilib-" + item
> - #localdata.setVar("OVERRIDES", overrides)
> - if localdata.getVar("BBEXTENDVARIANT", True) == item:
> - tunename=localdata.getVar("TUNENAME", False) or ""
> - else:
> - tunename=localdata.getVar("TUNENAME_virtclass-multilib-" + item, False) or ""
> + overrides = localdata.getVar("OVERRIDES", False) + ":virtclass-multilib-" + item
> + localdata.setVar("OVERRIDES", overrides)
> + tunename=localdata.getVar("TUNENAME_virtclass-multilib-" + item, False) or localdata.getVar("TUNENAME", False) or ""
> if tunename != "":
> localdata.setVar("DEFAULTTUNE", tunename)
> value = localdata.getVar(var, True) or ""
> diff --git a/meta/recipes-core/eglibc/eglibc-ld.inc b/meta/recipes-core/eglibc/eglibc-ld.inc
> new file mode 100644
> index 0000000..235ba6c
> --- /dev/null
> +++ b/meta/recipes-core/eglibc/eglibc-ld.inc
> @@ -0,0 +1,49 @@
> +def ld_append_if_tune_exists(d, infos, dict):
> + tune = d.getVar("DEFAULTTUNE", True) or ""
> + libdir = d.getVar("base_libdir", True) or ""
> + if dict.has_key(tune):
> + infos['ldconfig'].add('{"' + libdir + '/' + dict[tune][0] + '",' + dict[tune][1] + ' }')
> + infos['lddrewrite'].add(libdir+'/'+dict[tune][0])
> +
> +def eglibc_dl_info(d):
> + ld_info_all = {
> + "mips": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64-n32": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mipsel": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64el-n32": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64el": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips-nf": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64-nf-n32": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64-nf": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64el-nf-n32": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "mips64el-nf": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "powerpc": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "powerpc-nf": ["ld.so.1", "FLAG_ELF_LIBC6"],
> + "powerpc64": ["ld64.so.1", "FLAG_ELF_LIBC6"],
> + "powerpc64-nf": ["ld64.so.1", "FLAG_ELF_LIBC6"],
> + "core2": ["ld-linux.so.2", "FLAG_ELF_LIBC6"],
> + "core2-64": ["ld-linux-x86-64.so.2", "FLAG_ELF_LIBC6"],
> + "x86": ["ld-linux.so.2", "FLAG_ELF_LIBC6"],
> + "x86-64": ["ld-linux-x86-64.so.2", "FLAG_ELF_LIBC6"],
> + "i586": ["ld-linux.so.2", "FLAG_ELF_LIBC6"],
> + }
> +
> + infos = {'ldconfig':set(), 'lddrewrite':set()}
> + ld_append_if_tune_exists(d, infos, ld_info_all)
> + variants = d.getVar("MULTILIB_VARIANTS", True) or ""
> + for item in variants.split():
> + localdata = bb.data.createCopy(d)
> + overrides = localdata.getVar("OVERRIDES", False) + ":virtclass-multilib-" + item
> + localdata.setVar("OVERRIDES", overrides)
> + tunename=localdata.getVar("TUNENAME_virtclass-multilib-" + item, False) or localdata.getVar("TUNENAME", False) or ""
> + if tunename != "":
> + localdata.setVar("DEFAULTTUNE", tunename)
> + ld_append_if_tune_exists(localdata, infos, ld_info_all)
> +
> + infos['ldconfig'] = ','.join(infos['ldconfig'])
> + infos['lddrewrite'] = ' '.join(infos['lddrewrite'])
> + return infos
> +
> +EGLIBC_KNOWN_INTERPRETER_NAMES = "${@eglibc_dl_info(d)['ldconfig']}"
> +RTLDLIST = "${@eglibc_dl_info(d)['lddrewrite']}"
> diff --git a/meta/recipes-core/eglibc/eglibc.inc b/meta/recipes-core/eglibc/eglibc.inc
> index 1b2e630..0ed4359 100644
> --- a/meta/recipes-core/eglibc/eglibc.inc
> +++ b/meta/recipes-core/eglibc/eglibc.inc
> @@ -1,4 +1,5 @@
> require eglibc-common.inc
> +require eglibc-ld.inc
>
> STAGINGCC = "gcc-cross-intermediate"
> STAGINGCC_virtclass-nativesdk = "gcc-crosssdk-intermediate"
> diff --git a/meta/recipes-core/eglibc/eglibc_2.13.bb b/meta/recipes-core/eglibc/eglibc_2.13.bb
> index 41fe7c7..b1bfbf1 100644
> --- a/meta/recipes-core/eglibc/eglibc_2.13.bb
> +++ b/meta/recipes-core/eglibc/eglibc_2.13.bb
> @@ -3,7 +3,7 @@ require eglibc.inc
> SRCREV = "14157"
>
> DEPENDS += "gperf-native"
> -PR = "r9"
> +PR = "r10"
> PR_append = "+svnr${SRCPV}"
>
> EGLIBC_BRANCH="eglibc-2_13"
> @@ -199,6 +199,10 @@ do_compile () {
> rpcgen -h $r -o $h || oewarn "unable to generate header for $r"
> done
> )
> +
> + echo "Adjust dynamic loader list to ${EGLIBC_DYNAMIC_LOADERS}"
> + [ -z "${RTLDLIST}" ]&& return
> + sed -i ${B}/elf/ldd -e 's#^\(RTLDLIST=\).*$#\1"${RTLDLIST}"#'
> }
>
> require eglibc-package.inc
next prev parent reply other threads:[~2011-08-01 17:56 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-08-01 11:01 [PATCH BUG #1236 0/3] Unify ldd/ldconfig for all multilib eglibcs Lianhao Lu
2011-08-01 11:02 ` [PATCH BUG #1236 1/3] utils.bbclass/multilib.conf: Added misc supporting functions Lianhao Lu
2011-08-01 11:02 ` [PATCH BUG #1236 2/3] eglibc: Modify ldd script according to multilib config Lianhao Lu
2011-08-01 17:52 ` Saul Wold [this message]
2011-08-01 11:02 ` [PATCH BUG #1236 3/3] eglibc: Setting KNOWN_INTERPRETER_NAMES for ldconfig Lianhao Lu
2011-08-01 11:09 ` [PATCH BUG #1236 0/3] Unify ldd/ldconfig for all multilib eglibcs Koen Kooi
2011-08-11 22:38 ` Saul Wold
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=4E36E7DA.9060605@linux.intel.com \
--to=sgw@linux.intel.com \
--cc=openembedded-core@lists.openembedded.org \
/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