blob: 0d2e897c2b0cd4605e8d69ccc750eeec4bb49b82 [file] [log] [blame]
Patrick Williamsc124f4f2015-09-15 14:41:29 -05001#
2# Creates a root filesystem out of rpm packages
3#
4
5ROOTFS_PKGMANAGE = "rpm smartpm"
6ROOTFS_PKGMANAGE_BOOTSTRAP = "run-postinsts"
7
8# Add 50Meg of extra space for Smart
9IMAGE_ROOTFS_EXTRA_SPACE_append = "${@bb.utils.contains("PACKAGE_INSTALL", "smartpm", " + 51200", "" ,d)}"
10
11# Smart is python based, so be sure python-native is available to us.
12EXTRANATIVEPATH += "python-native"
13
14# opkg is needed for update-alternatives
15RPMROOTFSDEPENDS = "rpm-native:do_populate_sysroot \
16 rpmresolve-native:do_populate_sysroot \
17 python-smartpm-native:do_populate_sysroot \
18 createrepo-native:do_populate_sysroot \
19 opkg-native:do_populate_sysroot"
20
21do_rootfs[depends] += "${RPMROOTFSDEPENDS}"
22do_populate_sdk[depends] += "${RPMROOTFSDEPENDS}"
23
24do_rootfs[recrdeptask] += "do_package_write_rpm"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050025do_rootfs[vardeps] += "PACKAGE_FEED_URIS"
26
27# RPM doesn't work with multiple rootfs generation at once due to collisions in the use of files
28# in ${DEPLOY_DIR_RPM}. This can be removed if package_update_index_rpm can be called concurrently
29do_rootfs[lockfiles] += "${DEPLOY_DIR_RPM}/rpm.lock"
30do_populate_sdk[lockfiles] += "${DEPLOY_DIR_RPM}/rpm.lock"
31
32python () {
33 if d.getVar('BUILD_IMAGES_FROM_FEEDS', True):
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050034 flags = d.getVarFlag('do_rootfs', 'recrdeptask', True)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050035 flags = flags.replace("do_package_write_rpm", "")
36 flags = flags.replace("do_deploy", "")
37 flags = flags.replace("do_populate_sysroot", "")
38 d.setVarFlag('do_rootfs', 'recrdeptask', flags)
39 d.setVar('RPM_PREPROCESS_COMMANDS', '')
40 d.setVar('RPM_POSTPROCESS_COMMANDS', '')
41
42}
43# Smart is python based, so be sure python-native is available to us.
44EXTRANATIVEPATH += "python-native"
45
46rpmlibdir = "/var/lib/rpm"