]> code.ossystems Code Review - openembedded-core.git/commitdiff
rootfs_rpm: Fix rootfs generation using RPM packages
authorMark Hatle <mark.hatle@windriver.com>
Fri, 25 Feb 2011 23:31:50 +0000 (17:31 -0600)
committerRichard Purdie <rpurdie@linux.intel.com>
Tue, 1 Mar 2011 11:46:46 +0000 (11:46 +0000)
[BUG #756]

Fix bug #756.  The rootfs contains a control file /etc/rpm/platform
that specifies the default system platform, as well as patterns for
compatible architectures.  This file was not being setup properly due
to a misunderstanding of the format in a previous patch.

Signed-off-by: Mark Hatle <mark.hatle@windriver.com>
meta/classes/package_rpm.bbclass
meta/classes/populate_sdk_rpm.bbclass
meta/classes/rootfs_rpm.bbclass

index 7cbdae62567cd85e51fd499fb05b09625f86e0c9..60127d2ef4035aaa628b0a5020915f8cbc6e3c64 100644 (file)
@@ -155,7 +155,8 @@ resolve_package_rpm () {
 # install a bunch of packages using rpm
 # the following shell variables needs to be set before calling this func:
 # INSTALL_ROOTFS_RPM - install root dir
-# INSTALL_PLATFORM_RPM - extra platform
+# INSTALL_PLATFORM_RPM - main platform
+# INSTALL_PLATFORM_EXTRA_RPM - extra platform
 # INSTALL_CONFBASE_RPM - configuration file base name
 # INSTALL_PACKAGES_NORMAL_RPM - packages to be installed
 # INSTALL_PACKAGES_ATTEMPTONLY_RPM - packages attemped to be installed only
@@ -166,7 +167,8 @@ resolve_package_rpm () {
 package_install_internal_rpm () {
 
        local target_rootfs="${INSTALL_ROOTFS_RPM}"
-       local platforms="${INSTALL_PLATFORM_RPM}"
+       local platform="${INSTALL_PLATFORM_RPM}"
+       local platform_extra="${INSTALL_PLATFORM_EXTRA_RPM}"
        local confbase="${INSTALL_CONFBASE_RPM}"
        local package_to_install="${INSTALL_PACKAGES_NORMAL_RPM}"
        local package_attemptonly="${INSTALL_PACKAGES_ATTEMPTONLY_RPM}"
@@ -176,9 +178,10 @@ package_install_internal_rpm () {
 
        # Setup base system configuration
        mkdir -p ${target_rootfs}/etc/rpm/
-       if [ ! -z "$platforms" ]; then
-               for pt in $platforms ; do
-                       echo "$pt-unknown-linux" >> ${target_rootfs}/etc/rpm/platform
+       echo "${platform}-poky-linux-gnu" > ${target_rootfs}/etc/rpm/platform
+       if [ ! -z "$platform_extra" ]; then
+               for pt in $platform_extra ; do
+                       echo "$pt-.*-linux.*" >> ${target_rootfs}/etc/rpm/platform
                done
        fi
 
@@ -764,7 +767,7 @@ python do_package_rpm () {
        os.chmod(pkgwritedir, 0755)
 
        cmd = rpmbuild
-       cmd = cmd + " --nodeps --short-circuit --target " + pkgarch + " --buildroot " + pkgd
+       cmd = cmd + " --nodeps --short-circuit --target " + pkgarch + "-poky-linux-gnu --buildroot " + pkgd
        cmd = cmd + " --define '_topdir " + workdir + "' --define '_rpmdir " + pkgwritedir + "'"
        cmd = cmd + " --define '_build_name_fmt %%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.rpm'"
        cmd = cmd + " --define '_use_internal_dependency_generator 0'"
index d1797806e2f76a3b153228162becad03b73c17c5..0afe042fd665a6214c07eb4b03c5eb5bc6a983dc 100644 (file)
@@ -33,10 +33,17 @@ fakeroot populate_sdk_rpm () {
 
        #install target
        export INSTALL_ROOTFS_RPM="${SDK_OUTPUT}/${SDKTARGETSYSROOT}"
-       export INSTALL_PLATFORM_RPM="${PACKAGE_ARCHS}"
+       export INSTALL_PLATFORM_RPM="${TARGET_ARCHS}"
        export INSTALL_CONFBASE_RPM="${RPMCONF_TARGET_BASE}"
        export INSTALL_PACKAGES_NORMAL_RPM="${TOOLCHAIN_TARGET_TASK}"
 
+       # List must be prefered to least preferred order
+       INSTALL_PLATFORM_RPM=""
+       for each_arch in ${PACKAGE_ARCHS} ; do
+               INSTALL_PLATFORM_RPM="$each_arch $INSTALL_PLATFORM_RPM"
+       done
+       export INSTALL_PLATFORM_RPM
+
        package_install_internal_rpm
        populate_sdk_post_rpm ${INSTALL_ROOTFS_RPM}
 
@@ -45,6 +52,7 @@ fakeroot populate_sdk_rpm () {
        export INSTALL_PLATFORM_RPM="${SDK_ARCH}"
        export INSTALL_CONFBASE_RPM="${RPMCONF_HOST_BASE}"
        export INSTALL_PACKAGES_NORMAL_RPM="${TOOLCHAIN_HOST_TASK}"
+       export INSTALL_PLATFORM_EXTRA_RPM=""
        for arch in ${PACKAGE_ARCHS}; do
                sdkarch=`echo $arch | sed -e 's/${HOST_ARCH}/${SDK_ARCH}/'`
                extension="-nativesdk"
@@ -52,9 +60,10 @@ fakeroot populate_sdk_rpm () {
                    extension=""
                fi
                if [ -e ${DEPLOY_DIR_RPM}/$sdkarch$extension ]; then
-                       INSTALL_PLATFORM_RPM="$INSTALL_PLATFORM_RPM $sdkarch"
+                       INSTALL_PLATFORM_EXTRA_RPM="$sdkarch $INSTALL_PLATFORM_EXTRA_RPM"
                fi
        done
+       export INSTALL_PLATFORM_EXTRA_RPM
 
        package_install_internal_rpm
        populate_sdk_post_rpm ${INSTALL_ROOTFS_RPM}
index a722e68ae1c32ed78fdd915c370167a220d5d87e..caafbdc721687d819238808aede5b7a73f08fb06 100644 (file)
@@ -48,6 +48,7 @@ fakeroot rootfs_rpm_do_rootfs () {
 
        #install pacakges
        export INSTALL_ROOTFS_RPM="${IMAGE_ROOTFS}"
+       export INSTALL_PLATFORM_RPM="${TARGET_ARCH}"
        export INSTALL_CONFBASE_RPM="${RPMCONF_TARGET_BASE}"
        export INSTALL_PACKAGES_NORMAL_RPM="${PACKAGE_INSTALL}"
        export INSTALL_PACKAGES_ATTEMPTONLY_RPM="${PACKAGE_INSTALL_ATTEMPTONLY}"
@@ -56,9 +57,9 @@ fakeroot rootfs_rpm_do_rootfs () {
        export INSTALL_TASK_RPM="populate_sdk"
 
        # List must be prefered to least preferred order
-       INSTALL_PLATFORM_RPM=""
+       INSTALL_PLATFORM_EXTRA_RPM=""
        for each_arch in ${PACKAGE_ARCHS} ; do
-               INSTALL_PLATFORM_RPM="$each_arch $INSTALL_PLATFORM_RPM"
+               INSTALL_PLATFORM_EXTRA_RPM="$each_arch $INSTALL_PLATFORM_EXTRA_RPM"
        done
        export INSTALL_PLATFORM_RPM