populate_sdk_*: Sync SDK and regular rootfs functions
authorMark Hatle <mark.hatle@windriver.com>
Mon, 1 Aug 2011 17:34:51 +0000 (12:34 -0500)
committerRichard Purdie <richard.purdie@linuxfoundation.org>
Tue, 2 Aug 2011 13:32:11 +0000 (14:32 +0100)
In order for things to be easier to maintain in the future, sync up
the sdk and rootfs versions.

(From OE-Core rev: 3c78da15457d8d20c9964cd845f6e021d442aaae)

Signed-off-by: Mark Hatle <mark.hatle@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
meta/classes/populate_sdk_deb.bbclass
meta/classes/populate_sdk_rpm.bbclass
meta/classes/rootfs_rpm.bbclass

index 25d90c7..1bf1b95 100644 (file)
@@ -11,30 +11,38 @@ populate_sdk_post_deb () {
 
 fakeroot populate_sdk_deb () {
 
+       # update index
        package_update_index_deb
 
-       export INSTALL_TASK_DEB="populate_sdk"
-       export INSTALL_PACKAGES_LINGUAS_DEB=""
-       export INSTALL_PACKAGES_ATTEMPTONLY_DEB=""
-
-       #install target
+       ## install target ##
+       # This needs to work in the same way as rootfs_deb.bbclass
        echo "Installing TARGET packages"
+
+       mkdir -p ${IMAGE_ROOTFS}/var/dpkg/alternatives
+
        export INSTALL_ROOTFS_DEB="${SDK_OUTPUT}/${SDKTARGETSYSROOT}"
        export INSTALL_BASEARCH_DEB="${DPKG_ARCH}"
        export INSTALL_ARCHS_DEB="${PACKAGE_ARCHS}"
        export INSTALL_PACKAGES_NORMAL_DEB="${TOOLCHAIN_TARGET_TASK}"
+       export INSTALL_PACKAGES_ATTEMPTONLY_DEB=""
+       export PACKAGES_LINGUAS_DEB=""
+       export INSTALL_TASK_DEB="populate_sdk-target"
 
        package_install_internal_deb
+
        populate_sdk_post_deb ${INSTALL_ROOTFS_DEB}
 
        populate_sdk_log_check populate_sdk
 
-       #install host
-       echo "Installing HOST packages"
+       ## install nativesdk ##
+       echo "Installing NATIVESDK packages"
        export INSTALL_ROOTFS_DEB="${SDK_OUTPUT}"
        export INSTALL_BASEARCH_DEB="${SDK_ARCH}"
-       export INSTALL_PACKAGES_NORMAL_DEB="${TOOLCHAIN_HOST_TASK}"
        export INSTALL_ARCHS_DEB="${SDK_PACKAGE_ARCHS}"
+       export INSTALL_PACKAGES_NORMAL_DEB="${TOOLCHAIN_HOST_TASK}"
+       export INSTALL_PACKAGES_ATTEMPTONLY_DEB=""
+       export PACKAGES_LINGUAS_DEB=""
+       export INSTALL_TASK_DEB="populate_sdk-nativesdk"
 
        package_install_internal_deb
        populate_sdk_post_deb ${SDK_OUTPUT}/${SDKPATHNATIVE}
index 560e40c..5fb0234 100644 (file)
@@ -26,21 +26,49 @@ fakeroot populate_sdk_rpm () {
        package_update_index_rpm
        package_generate_rpm_conf
 
-       export INSTALL_PACKAGES_ATTEMPTONLY_RPM=""
-       export INSTALL_PACKAGES_LINGUAS_RPM=""
-       export INSTALL_PROVIDENAME_RPM="/bin/sh"
-       export INSTALL_TASK_RPM="populate_sdk"
-
-
-       #install target
+       ## install target ##
+       # This needs to work in the same way as rootfs_rpm.bbclass!
+       #
        export INSTALL_ROOTFS_RPM="${SDK_OUTPUT}/${SDKTARGETSYSROOT}"
        export INSTALL_PLATFORM_RPM="${TARGET_ARCH}"
        export INSTALL_CONFBASE_RPM="${RPMCONF_TARGET_BASE}"
        export INSTALL_PACKAGES_NORMAL_RPM="${TOOLCHAIN_TARGET_TASK}"
+       export INSTALL_PACKAGES_ATTEMPTONLY_RPM=""
+       export INSTALL_PACKAGES_LINGUAS_RPM=""
+       export INSTALL_PROVIDENAME_RPM=""
+       export INSTALL_TASK_RPM="populate_sdk-target"
+
+       # Setup base system configuration
+       mkdir -p ${INSTALL_ROOTFS_RPM}/etc/rpm/
+       mkdir -p ${INSTALL_ROOTFS_RPM}${rpmlibdir}
+       mkdir -p ${INSTALL_ROOTFS_RPM}${rpmlibdir}/log
+       cat > ${INSTALL_ROOTFS_RPM}${rpmlibdir}/DB_CONFIG << EOF
+# ================ Environment
+set_data_dir            .
+set_create_dir          .
+set_lg_dir              ./log
+set_tmp_dir             ./tmp
+
+# -- thread_count must be >= 8
+set_thread_count        64
+
+# ================ Logging
+
+# ================ Memory Pool
+set_mp_mmapsize         268435456
+
+# ================ Locking
+set_lk_max_locks        16384
+set_lk_max_lockers      16384
+set_lk_max_objects      16384
+mutex_set_max           163840
+
+# ================ Replication
+EOF
 
        # List must be prefered to least preferred order
        INSTALL_PLATFORM_EXTRA_RPM=""
-       for each_arch in ${PACKAGE_ARCHS} ; do
+       for each_arch in ${MULTILIB_PACKAGE_ARCHS} ${PACKAGE_ARCHS} ; do
                INSTALL_PLATFORM_EXTRA_RPM="$each_arch $INSTALL_PLATFORM_EXTRA_RPM"
        done
        export INSTALL_PLATFORM_EXTRA_RPM
@@ -48,11 +76,16 @@ fakeroot populate_sdk_rpm () {
        package_install_internal_rpm
        populate_sdk_post_rpm ${INSTALL_ROOTFS_RPM}
 
-       #install host
+       ## install nativesdk ##
+       echo "Installing NATIVESDK packages"
        export INSTALL_ROOTFS_RPM="${SDK_OUTPUT}"
        export INSTALL_PLATFORM_RPM="${SDK_ARCH}"
        export INSTALL_CONFBASE_RPM="${RPMCONF_HOST_BASE}"
        export INSTALL_PACKAGES_NORMAL_RPM="${TOOLCHAIN_HOST_TASK}"
+       export INSTALL_PACKAGES_ATTEMPTONLY_RPM=""
+       export INSTALL_PACKAGES_LINGUAS_RPM=""
+       export INSTALL_PROVIDENAME_RPM="/bin/sh"
+       export INSTALL_TASK_RPM="populate_sdk_rpm-nativesdk"
 
        # List must be prefered to least preferred order
        INSTALL_PLATFORM_EXTRA_RPM=""
@@ -80,3 +113,20 @@ fakeroot populate_sdk_rpm () {
                resolve_package_rpm foo ${RPMCONF_TARGET_BASE}.conf || true
        fi
 }
+
+python () {
+    ml_package_archs = ""
+    multilibs = d.getVar('MULTILIBS', True) or ""
+    for ext in multilibs.split():
+        eext = ext.split(':')
+        if len(eext) > 1 and eext[0] == 'multilib':
+            localdata = bb.data.createCopy(d)
+            overrides = localdata.getVar("OVERRIDES", False) + ":virtclass-multilib-" + eext[1]
+            localdata.setVar("OVERRIDES", overrides)
+            # TEMP: OVERRIDES isn't working right
+            localdata.setVar("DEFAULTTUNE", localdata.getVar("DEFAULTTUNE_virtclass-multilib-" + eext[1], False) or "")
+            ml_package_archs += localdata.getVar("PACKAGE_ARCHS", True) or ""
+            #bb.note("ML_PACKAGE_ARCHS %s %s %s" % (eext[1], localdata.getVar("PACKAGE_ARCHS", True) or "(none)", overrides))
+    bb.data.setVar('MULTILIB_PACKAGE_ARCHS', ml_package_archs, d)
+}
+
index 4f627a5..7c06064 100644 (file)
@@ -55,6 +55,13 @@ fakeroot rootfs_rpm_do_rootfs () {
        # install packages
        # This needs to work in the same way as populate_sdk_rpm.bbclass!
        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}"
+       export INSTALL_PACKAGES_LINGUAS_RPM="${LINGUAS_INSTALL}"
+       export INSTALL_PROVIDENAME_RPM=""
+       export INSTALL_TASK_RPM="rootfs_rpm_do_rootfs"
 
        # Setup base system configuration
        mkdir -p ${INSTALL_ROOTFS_RPM}/etc/rpm/
@@ -85,14 +92,6 @@ mutex_set_max           163840
 # ================ Replication
 EOF
 
-       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}"
-       export INSTALL_PACKAGES_LINGUAS_RPM="${LINGUAS_INSTALL}"
-       export INSTALL_PROVIDENAME_RPM=""
-       export INSTALL_TASK_RPM="rootfs_rpm_do_rootfs"
-
        # List must be prefered to least preferred order
        INSTALL_PLATFORM_EXTRA_RPM=""
        for each_arch in ${MULTILIB_PACKAGE_ARCHS} ${PACKAGE_ARCHS}; do