[OE-core] [PATCH 0/1] fix IMAGE_LINGUAS did not support multilib correctly
Hongxu Jia
hongxu.jia at windriver.com
Thu Jan 14 06:48:15 UTC 2016
Hi Ross,
I found you added this patch to 'Consolidated Pull', but not merged finally.
Did it cause build failure or introduce trouble?
//Hongxu
On 12/10/2015 06:41 PM, Hongxu Jia wrote:
> Test steps:
>
> 1. Make use of service in meta-skeleton to test the issue.
> The app invoke setlocale(LC_CTYPE, "en_US.UTF-8") in C.
>
> --- a/meta-skeleton/recipes-skeleton/service/service/skeleton_test.c
> +++ b/meta-skeleton/recipes-skeleton/service/service/skeleton_test.c
> @@ -1,12 +1,13 @@
> -#include <unistd.h>
> -
> -/* This demo does nothing except for testing /etc/init.d/skeleton */
> +#include <locale.h>
> +#include <stdio.h>
> +#include <errno.h>
> +#include <string.h>
>
> int main(int argc, char *argv[])
> {
> - daemon(0, 0);
> - while (1) {
> - sleep(1);
> - }
> - return 0;
> + char *p = setlocale (LC_CTYPE, "en_US.UTF-8");
> + if (p == NULL)
> + printf("setlocale failed: %s\n", strerror(errno));
> + else
> + printf("p %s\n", p);
> }
>
> --- a/meta-skeleton/recipes-skeleton/service/service_0.1.bb
> +++ b/meta-skeleton/recipes-skeleton/service/service_0.1.bb
> @@ -1,4 +1,4 @@
> -SUMMARY = "The canonical example of init scripts"
> +SUMMARY = "The example to test multilib of setlocale"
> SECTION = "base"
> LICENSE = "GPLv2"
> LIC_FILES_CHKSUM = "file://${WORKDIR}/COPYRIGHT;md5=349c872e0066155e1818b786938876a4"
> @@ -8,24 +8,14 @@ SRC_URI = "file://skeleton \
> file://COPYRIGHT \
> "
>
> +FILES_${PN} += "${libdir}/setlocale"
> +
> do_compile () {
> - ${CC} ${WORKDIR}/skeleton_test.c -o ${WORKDIR}/skeleton-test
> + ${CC} ${WORKDIR}/skeleton_test.c -o ${WORKDIR}/setlocale
> }
>
> do_install () {
> - install -d ${D}${sysconfdir}/init.d
> - cat ${WORKDIR}/skeleton | \
> - sed -e 's,/etc,${sysconfdir},g' \
> - -e 's,/usr/sbin,${sbindir},g' \
> - -e 's,/var,${localstatedir},g' \
> - -e 's,/usr/bin,${bindir},g' \
> - -e 's,/usr,${prefix},g' > ${D}${sysconfdir}/init.d/skeleton
> - chmod a+x ${D}${sysconfdir}/init.d/skeleton
> -
> - install -d ${D}${sbindir}
> - install -m 0755 ${WORKDIR}/skeleton-test ${D}${sbindir}/
> + install -d ${D}${libdir}
> + install -m 0755 ${WORKDIR}/setlocale ${D}${libdir}/
> }
>
> -RDEPENDS_${PN} = "initscripts"
> -
> -CONFFILES_${PN} += "${sysconfdir}/init.d/skeleton"
>
>
> 2. On qemux86-64, enable multilib, add non-multilib and
> multilib service to image, assign 'en-us' to IMAGE_LINGUAS
> vim local.conf
> ...
> MACHINE ?= "qemux86-64"
>
> require conf/multilib.conf
> MULTILIBS = "multilib:lib32"
> DEFAULTTUNE_virtclass-multilib-lib32 = "core2-32"
>
> IMAGE_INSTALL_append = " file service lib32-service"
> IMAGE_LINGUAS_append = " en-us"
> ...
>
> vim bblayers.conf
> ...
> BBLAYERS ?= " \
> /buildarea/raid0/hjia/poky/meta \
> /buildarea/raid0/hjia/poky/meta-yocto \
> /buildarea/raid0/hjia/poky/meta-skeleton \
> "
> ...
>
> 2. Build non-multilib image
> $ bitbake core-image-minimal
>
> 3. Run qemu
> $ runqemu qemux86-64 core-image-minimal slirp nographic
>
> 4. In qemu, invoke multilib /usr/lib/setlocale and non-multilib
> /usr/lib64/setlocale success
>
> root at qemux86-64:~# file /usr/lib/setlocale
> /usr/lib/setlocale: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=0caa404112fe8963dd1418757fc4bdee0cab272d, stripped
> root at qemux86-64:~# /usr/lib/setlocale
> p en_US.UTF-8
>
> root at qemux86-64:~# file /usr/lib64/setlocale
> /usr/lib64/setlocale: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=b8c88222213ffbd4603b34337b3db71aba43c968, stripped
> root at qemux86-64:~#
> root at qemux86-64:~# /usr/lib64/setlocale
> p en_US.UTF-8
>
> 5. Both locale-base-en-us and lib32-locale-base-en-us installed
> root at qemux86-64:~# ls /usr/lib64/locale/en_US/
> LC_ADDRESS LC_CTYPE LC_MEASUREMENT LC_MONETARY LC_NUMERIC LC_TELEPHONE
> LC_COLLATE LC_IDENTIFICATION LC_MESSAGES
>
> root at qemux86-64:~# ls /usr/lib/locale/en_US/
> LC_ADDRESS LC_CTYPE LC_MEASUREMENT LC_MONETARY LC_NUMERIC LC_TELEPHONE
> LC_COLLATE LC_IDENTIFICATION LC_MESSAGES
>
> 6. Build multilib image
> $ bitbake lib32-core-image-minimal
>
> 7. Run qemu
> $ runqemu qemux86-64 lib32-core-image-minimal slirp nographic
>
> 8. Both locale-base-en-us and lib32-locale-base-en-us installed
> root at qemux86-64:~# ls /usr/lib64/locale/en_US/
> LC_ADDRESS LC_CTYPE LC_MEASUREMENT LC_MONETARY LC_NUMERIC LC_TELEPHONE
> LC_COLLATE LC_IDENTIFICATION LC_MESSAGES
>
> root at qemux86-64:~# ls /usr/lib/locale/en_US/
> LC_ADDRESS LC_CTYPE LC_MEASUREMENT LC_MONETARY LC_NUMERIC LC_TELEPHONE
> LC_COLLATE LC_IDENTIFICATION LC_MESSAGES
>
> 9. Disable multilib and build core-image-minimal
> only locale-base-en-us is installed
>
> root at qemux86-64:~# /usr/lib/setlocale
> p en_US.UTF-8
>
> root at qemux86-64:~# file /usr/lib/setlocale
> /usr/lib/setlocale: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=bc6d1a23619ad5629f8e064ce8e426d5d8b20434, stripped
>
> root at qemux86-64:~# ls /usr/lib/locale/en_US/
> LC_ADDRESS LC_CTYPE LC_MEASUREMENT LC_MONETARY LC_NUMERIC LC_TELEPHONE
> LC_COLLATE LC_IDENTIFICATION LC_MESSAGES LC_NAME LC_PAPER LC_TIME
>
> //Hongxu
>
> The following changes since commit 5e3e2e0cbb0a49986f4653e64c4c8d2b5461645e:
>
> poky.conf: Bump for 2.1 development (2015-12-10 00:13:13 +0000)
>
> are available in the git repository at:
>
> git://git.pokylinux.org/poky-contrib hongxu/fix-locale
> http://git.pokylinux.org/cgit.cgi/poky-contrib/log/?h=hongxu/fix-locale
>
> Hongxu Jia (1):
> image/multilib bbclass: install multilib and non-multilib language
> pkgs for image recipes
>
> meta/classes/image.bbclass | 20 +++++++++++++++++++-
> meta/classes/multilib.bbclass | 9 +++++++++
> 2 files changed, 28 insertions(+), 1 deletion(-)
>
More information about the Openembedded-core
mailing list