diff options
author | Dexuan Cui <dexuan.cui@intel.com> | 2011-09-14 22:30:14 +0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-09-15 11:23:56 +0100 |
commit | c2bbc59b215aebed4771e7735a76648abbe86bbd (patch) | |
tree | b2496ae274dd698f50645581b8d0ea17823fd9da | |
parent | 90ded12e485657f776fa9dac6567c9c84c28fa63 (diff) | |
download | poky-c2bbc59b215aebed4771e7735a76648abbe86bbd.tar.gz |
package_deb.bbclass, populate_sdk_deb.bbclass: fix meta-toolchain-gmae build
[YOCTO #1070]
Currently with deb packaging, we have 2 issues when running
"bitbake meta-toolchain-gmae".
1) when MACHINE="qemux86", SDKMACHINE="i686", INSTALL_BASEARCH_DEB is "i686",
too. This causes the following ERROR:
| E: Couldn't find package task-sdk-host-nativesdk
NOTE: package meta-toolchain-gmae-1.0-r6: task do_populate_sdk: Failed
This is becasue: due to the DPKG_ARCH mapping, we create such a deb package
tmp/deploy/deb/i686-nativesdk/task-sdk-host-nativesdk_1.0-r10_i386.deb; dpkg
can't recoginze the package. We need to map INSTALL_BASEARCH_DEB in the same
way.
2) when MACHINE="qemux86", SDKMACHINE="x86_64", INSTALL_BASEARCH_DEB is
"x86_64", too.
We get such an ERROR:
| E: Couldn't find package task-cross-canadian-i586
NOTE: package meta-toolchain-gmae-1.0-r6: task do_populate_sdk: Failed
This is because: dpkg can't recognize the generated package
tmp/deploy/deb/x86_64-nativesdk/task-cross-canadian-i586_1.0-r0_i386.deb
Here the "i386" suffix is incorrect and should be "x86_64" -- the i386
comes from the line
DPKG_ARCH_i586 ?= "i386" in package_deb.bbclass.
However, for canadian package, actually here the overriding of DPKG (from
"x86-64" to "i386") should not happen -- it accidently happens just because
TARGET_ARCH exists in OVERRIDES. We can move the overriding logic to the
anonymous python function to work this around.
(From OE-Core rev: 63010b9ee89643c8e83656783231f0a7848d9e45)
Signed-off-by: Lianhao Lu <lianhao.lu@intel.com>
Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/classes/package_deb.bbclass | 10 | ||||
-rw-r--r-- | meta/classes/populate_sdk_deb.bbclass | 6 |
2 files changed, 9 insertions, 7 deletions
diff --git a/meta/classes/package_deb.bbclass b/meta/classes/package_deb.bbclass index 87e20da843..5a32047322 100644 --- a/meta/classes/package_deb.bbclass +++ b/meta/classes/package_deb.bbclass | |||
@@ -6,13 +6,7 @@ inherit package | |||
6 | 6 | ||
7 | IMAGE_PKGTYPE ?= "deb" | 7 | IMAGE_PKGTYPE ?= "deb" |
8 | 8 | ||
9 | # Map TARGET_ARCH to Debian's ideas about architectures | ||
10 | DPKG_ARCH ?= "${TARGET_ARCH}" | 9 | DPKG_ARCH ?= "${TARGET_ARCH}" |
11 | DPKG_ARCH_x86 ?= "i386" | ||
12 | DPKG_ARCH_i486 ?= "i386" | ||
13 | DPKG_ARCH_i586 ?= "i386" | ||
14 | DPKG_ARCH_i686 ?= "i386" | ||
15 | DPKG_ARCH_pentium ?= "i386" | ||
16 | 10 | ||
17 | PKGWRITEDIRDEB = "${WORKDIR}/deploy-debs" | 11 | PKGWRITEDIRDEB = "${WORKDIR}/deploy-debs" |
18 | 12 | ||
@@ -418,6 +412,10 @@ python () { | |||
418 | bb.data.setVarFlag('do_package_write_deb', 'depends', " ".join(deps), d) | 412 | bb.data.setVarFlag('do_package_write_deb', 'depends', " ".join(deps), d) |
419 | bb.data.setVarFlag('do_package_write_deb', 'fakeroot', "1", d) | 413 | bb.data.setVarFlag('do_package_write_deb', 'fakeroot', "1", d) |
420 | bb.data.setVarFlag('do_package_write_deb_setscene', 'fakeroot', "1", d) | 414 | bb.data.setVarFlag('do_package_write_deb_setscene', 'fakeroot', "1", d) |
415 | |||
416 | # Map TARGET_ARCH to Debian's ideas about architectures | ||
417 | if bb.data.getVar('DPKG_ARCH', d, True) in ["x86", "i486", "i586", "i686", "pentium"]: | ||
418 | bb.data.setVar('DPKG_ARCH', 'i386', d) | ||
421 | } | 419 | } |
422 | 420 | ||
423 | python do_package_write_deb () { | 421 | python do_package_write_deb () { |
diff --git a/meta/classes/populate_sdk_deb.bbclass b/meta/classes/populate_sdk_deb.bbclass index 40516b856c..2cff69e827 100644 --- a/meta/classes/populate_sdk_deb.bbclass +++ b/meta/classes/populate_sdk_deb.bbclass | |||
@@ -2,6 +2,10 @@ do_populate_sdk[depends] += "dpkg-native:do_populate_sysroot apt-native:do_popul | |||
2 | do_populate_sdk[recrdeptask] += "do_package_write_deb" | 2 | do_populate_sdk[recrdeptask] += "do_package_write_deb" |
3 | 3 | ||
4 | 4 | ||
5 | DEB_SDK_ARCH = "${@[bb.data.getVar('SDK_ARCH', d, 1), "i386"]\ | ||
6 | [bb.data.getVar('SDK_ARCH', d, 1) in \ | ||
7 | ["x86", "i486", "i586", "i686", "pentium"]]}" | ||
8 | |||
5 | populate_sdk_post_deb () { | 9 | populate_sdk_post_deb () { |
6 | 10 | ||
7 | local target_rootfs=$1 | 11 | local target_rootfs=$1 |
@@ -37,7 +41,7 @@ fakeroot populate_sdk_deb () { | |||
37 | ## install nativesdk ## | 41 | ## install nativesdk ## |
38 | echo "Installing NATIVESDK packages" | 42 | echo "Installing NATIVESDK packages" |
39 | export INSTALL_ROOTFS_DEB="${SDK_OUTPUT}" | 43 | export INSTALL_ROOTFS_DEB="${SDK_OUTPUT}" |
40 | export INSTALL_BASEARCH_DEB="${SDK_ARCH}" | 44 | export INSTALL_BASEARCH_DEB="${DEB_SDK_ARCH}" |
41 | export INSTALL_ARCHS_DEB="${SDK_PACKAGE_ARCHS}" | 45 | export INSTALL_ARCHS_DEB="${SDK_PACKAGE_ARCHS}" |
42 | export INSTALL_PACKAGES_NORMAL_DEB="${TOOLCHAIN_HOST_TASK}" | 46 | export INSTALL_PACKAGES_NORMAL_DEB="${TOOLCHAIN_HOST_TASK}" |
43 | export INSTALL_PACKAGES_ATTEMPTONLY_DEB="" | 47 | export INSTALL_PACKAGES_ATTEMPTONLY_DEB="" |