summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard@openedhand.com>2007-09-01 22:17:06 +0000
committerRichard Purdie <richard@openedhand.com>2007-09-01 22:17:06 +0000
commitc6938aad87ce4b9ce25ecd020ecddfe62b319bcf (patch)
treebf38fd54cc10deb22025853094b3e33c4043d1b2
parenta7c63ec4828e08e0812f69a5be04422e5dd7b30a (diff)
downloadpoky-c6938aad87ce4b9ce25ecd020ecddfe62b319bcf.tar.gz
Factor ipkg index and conf file creation into package_ipk.bbclass
git-svn-id: https://svn.o-hand.com/repos/poky/trunk@2637 311d38ba-8fff-0310-9ca6-ca027cbcb966
-rw-r--r--meta/classes/meta.bbclass4
-rw-r--r--meta/classes/package_ipk.bbclass44
-rw-r--r--meta/classes/rootfs_ipk.bbclass35
-rw-r--r--meta/classes/task.bbclass27
-rw-r--r--meta/conf/bitbake.conf1
-rw-r--r--meta/packages/meta/meta-toolchain.bb29
6 files changed, 88 insertions, 52 deletions
diff --git a/meta/classes/meta.bbclass b/meta/classes/meta.bbclass
new file mode 100644
index 0000000000..d35c40bccd
--- /dev/null
+++ b/meta/classes/meta.bbclass
@@ -0,0 +1,4 @@
1
2PACKAGES = ""
3
4do_build[recrdeptask] = "do_build" \ No newline at end of file
diff --git a/meta/classes/package_ipk.bbclass b/meta/classes/package_ipk.bbclass
index d88d11b994..1175d1e751 100644
--- a/meta/classes/package_ipk.bbclass
+++ b/meta/classes/package_ipk.bbclass
@@ -4,6 +4,9 @@ BOOTSTRAP_EXTRA_RDEPENDS += "ipkg-collateral ipkg ipkg-link"
4DISTRO_EXTRA_RDEPENDS += "ipkg-collateral ipkg ipkg-link" 4DISTRO_EXTRA_RDEPENDS += "ipkg-collateral ipkg ipkg-link"
5IMAGE_PKGTYPE ?= "ipk" 5IMAGE_PKGTYPE ?= "ipk"
6 6
7IPKGCONF_TARGET = "${STAGING_ETCDIR_NATIVE}/ipkg.conf"
8IPKGCONF_SDK = "${STAGING_ETCDIR_NATIVE}/ipkg-sdk.conf"
9
7python package_ipk_fn () { 10python package_ipk_fn () {
8 from bb import data 11 from bb import data
9 bb.data.setVar('PKGFN', bb.data.getVar('PKG',d), d) 12 bb.data.setVar('PKGFN', bb.data.getVar('PKG',d), d)
@@ -60,6 +63,47 @@ python package_ipk_install () {
60 raise bb.build.FuncFailed 63 raise bb.build.FuncFailed
61} 64}
62 65
66#
67# Update the Packages index files in ${DEPLOY_DIR_IPK}
68#
69package_update_index_ipk () {
70 set -x
71
72 ipkgarchs="${PACKAGE_ARCHS}"
73
74 if [ ! -z "${DEPLOY_KEEP_PACKAGES}" ]; then
75 return
76 fi
77
78 touch ${DEPLOY_DIR_IPK}/Packages
79 ipkg-make-index -r ${DEPLOY_DIR_IPK}/Packages -p ${DEPLOY_DIR_IPK}/Packages -l ${DEPLOY_DIR_IPK}/Packages.filelist -m ${DEPLOY_DIR_IPK}
80
81 for arch in $ipkgarchs; do
82 if [ -e ${DEPLOY_DIR_IPK}/$arch/ ] ; then
83 touch ${DEPLOY_DIR_IPK}/$arch/Packages
84 ipkg-make-index -r ${DEPLOY_DIR_IPK}/$arch/Packages -p ${DEPLOY_DIR_IPK}/$arch/Packages -l ${DEPLOY_DIR_IPK}/$arch/Packages.filelist -m ${DEPLOY_DIR_IPK}/$arch/
85 fi
86 done
87}
88
89#
90# Generate an ipkg conf file ${IPKGCONF_TARGET} suitable for use against
91# the target system and an ipkg conf file ${IPKGCONF_SDK} suitable for
92# use against the host system in sdk builds
93#
94package_generate_ipkg_conf () {
95 mkdir -p ${STAGING_ETCDIR_NATIVE}/
96 echo "src oe file:${DEPLOY_DIR_IPK}" > ${IPKGCONF_TARGET}
97 echo "src oe file:${DEPLOY_DIR_IPK}" > ${IPKGCONF_SDK}
98 ipkgarchs="${PACKAGE_ARCHS}"
99 priority=1
100 for arch in $ipkgarchs; do
101 echo "arch $arch $priority" >> ${IPKGCONF_TARGET}
102 echo "arch ${BUILD_ARCH}-$arch-sdk $priority" >> ${IPKGCONF_SDK}
103 priority=$(expr $priority + 5)
104 done
105}
106
63python do_package_ipk () { 107python do_package_ipk () {
64 import sys, re, fcntl, copy 108 import sys, re, fcntl, copy
65 109
diff --git a/meta/classes/rootfs_ipk.bbclass b/meta/classes/rootfs_ipk.bbclass
index 3709f89743..3c9d03f9dd 100644
--- a/meta/classes/rootfs_ipk.bbclass
+++ b/meta/classes/rootfs_ipk.bbclass
@@ -8,41 +8,16 @@
8do_rootfs[depends] += "ipkg-native:do_populate_staging ipkg-utils-native:do_populate_staging" 8do_rootfs[depends] += "ipkg-native:do_populate_staging ipkg-utils-native:do_populate_staging"
9do_rootfs[recrdeptask] += "do_package_write_ipk" 9do_rootfs[recrdeptask] += "do_package_write_ipk"
10 10
11IPKG_ARGS = "-f ${T}/ipkg.conf -o ${IMAGE_ROOTFS}" 11IPKG_ARGS = "-f ${IPKGCONF_TARGET} -o ${IMAGE_ROOTFS}"
12
13rootfs_ipk_do_indexes () {
14 set -x
15
16 ipkgarchs="${PACKAGE_ARCHS}"
17
18 if [ -z "${DEPLOY_KEEP_PACKAGES}" ]; then
19 touch ${DEPLOY_DIR_IPK}/Packages
20 ipkg-make-index -r ${DEPLOY_DIR_IPK}/Packages -p ${DEPLOY_DIR_IPK}/Packages -l ${DEPLOY_DIR_IPK}/Packages.filelist -m ${DEPLOY_DIR_IPK}
21 fi
22
23 for arch in $ipkgarchs; do
24 if [ -z "${DEPLOY_KEEP_PACKAGES}" ]; then
25 if [ -e ${DEPLOY_DIR_IPK}/$arch/ ] ; then
26 touch ${DEPLOY_DIR_IPK}/$arch/Packages
27 ipkg-make-index -r ${DEPLOY_DIR_IPK}/$arch/Packages -p ${DEPLOY_DIR_IPK}/$arch/Packages -l ${DEPLOY_DIR_IPK}/$arch/Packages.filelist -m ${DEPLOY_DIR_IPK}/$arch/
28 fi
29 fi
30 done
31}
32 12
33fakeroot rootfs_ipk_do_rootfs () { 13fakeroot rootfs_ipk_do_rootfs () {
34 set -x 14 set -x
35 15
36 rootfs_ipk_do_indexes 16 package_update_index_ipk
17 package_generate_ipkg_conf
37 18
38 mkdir -p ${T} 19 mkdir -p ${T}
39 echo "src oe file:${DEPLOY_DIR_IPK}" > ${T}/ipkg.conf 20
40 ipkgarchs="${PACKAGE_ARCHS}"
41 priority=1
42 for arch in $ipkgarchs; do
43 echo "arch $arch $priority" >> ${T}/ipkg.conf
44 priority=$(expr $priority + 5)
45 done
46 ipkg-cl ${IPKG_ARGS} update 21 ipkg-cl ${IPKG_ARGS} update
47 if [ ! -z "${LINGUAS_INSTALL}" ]; then 22 if [ ! -z "${LINGUAS_INSTALL}" ]; then
48 ipkg-cl ${IPKG_ARGS} install glibc-localedata-i18n 23 ipkg-cl ${IPKG_ARGS} install glibc-localedata-i18n
@@ -58,7 +33,7 @@ fakeroot rootfs_ipk_do_rootfs () {
58 export OFFLINE_ROOT=${IMAGE_ROOTFS} 33 export OFFLINE_ROOT=${IMAGE_ROOTFS}
59 export IPKG_OFFLINE_ROOT=${IMAGE_ROOTFS} 34 export IPKG_OFFLINE_ROOT=${IMAGE_ROOTFS}
60 mkdir -p ${IMAGE_ROOTFS}/etc/ipkg/ 35 mkdir -p ${IMAGE_ROOTFS}/etc/ipkg/
61 grep "^arch" ${T}/ipkg.conf >${IMAGE_ROOTFS}/etc/ipkg/arch.conf 36 grep "^arch" ${IPKGCONF_TARGET} >${IMAGE_ROOTFS}/etc/ipkg/arch.conf
62 37
63 for i in ${IMAGE_ROOTFS}${libdir}/ipkg/info/*.preinst; do 38 for i in ${IMAGE_ROOTFS}${libdir}/ipkg/info/*.preinst; do
64 if [ -f $i ] && ! sh $i; then 39 if [ -f $i ] && ! sh $i; then
diff --git a/meta/classes/task.bbclass b/meta/classes/task.bbclass
new file mode 100644
index 0000000000..4edd704829
--- /dev/null
+++ b/meta/classes/task.bbclass
@@ -0,0 +1,27 @@
1# Task packages are only used to pull in other packages
2# via their dependencies. They are empty.
3ALLOW_EMPTY = "1"
4
5# By default, only the task package itself is in PACKAGES.
6# -dbg and -dev flavours are handled by the anonfunc below.
7# This means that task recipes used to build multiple task
8# packages have to modify PACKAGES after inheriting task.bbclass.
9PACKAGES = "${PN}"
10
11# By default, task packages do not depend on a certain architecture.
12# Only if dependencies are modified by MACHINE_FEATURES, packages
13# need to be set to MACHINE_ARCH after inheriting task.bbclass
14PACKAGE_ARCH = "all"
15
16# This automatically adds -dbg and -dev flavours of all PACKAGES
17# to the list. Their dependencies (RRECOMMENDS) are handled as usual
18# by package_depchains in a following step.
19python () {
20 packages = bb.data.getVar('PACKAGES', d, 1).split()
21 genpackages = []
22 for pkg in packages:
23 for postfix in ['-dbg', '-dev']:
24 genpackages.append(pkg+postfix)
25 bb.data.setVar('PACKAGES', ' '.join(packages+genpackages), d)
26}
27
diff --git a/meta/conf/bitbake.conf b/meta/conf/bitbake.conf
index 7adc8ee9dc..24c3aa1c72 100644
--- a/meta/conf/bitbake.conf
+++ b/meta/conf/bitbake.conf
@@ -171,6 +171,7 @@ STAGING_BINDIR_CROSS = "${STAGING_DIR}/${BUILD_SYS}/bin/${HOST_SYS}"
171STAGING_BINDIR_NATIVE = "${STAGING_DIR}/${BUILD_SYS}/bin" 171STAGING_BINDIR_NATIVE = "${STAGING_DIR}/${BUILD_SYS}/bin"
172STAGING_LIBDIR = "${STAGING_DIR}/${HOST_SYS}/lib" 172STAGING_LIBDIR = "${STAGING_DIR}/${HOST_SYS}/lib"
173STAGING_LIBDIR_NATIVE = "${STAGING_DIR}/${BUILD_SYS}/lib" 173STAGING_LIBDIR_NATIVE = "${STAGING_DIR}/${BUILD_SYS}/lib"
174STAGING_ETCDIR_NATIVE = "${STAGING_DIR}/${BUILD_SYS}/etc"
174STAGING_INCDIR = "${STAGING_DIR}/${HOST_SYS}/include" 175STAGING_INCDIR = "${STAGING_DIR}/${HOST_SYS}/include"
175STAGING_DATADIR = "${STAGING_DIR}/${HOST_SYS}/share" 176STAGING_DATADIR = "${STAGING_DIR}/${HOST_SYS}/share"
176STAGING_LOADER_DIR = "${STAGING_DIR}/${HOST_SYS}/loader" 177STAGING_LOADER_DIR = "${STAGING_DIR}/${HOST_SYS}/loader"
diff --git a/meta/packages/meta/meta-toolchain.bb b/meta/packages/meta/meta-toolchain.bb
index 1a1bde46c0..a0f38404b0 100644
--- a/meta/packages/meta/meta-toolchain.bb
+++ b/meta/packages/meta/meta-toolchain.bb
@@ -1,21 +1,15 @@
1DESCRIPTION = "Meta package for building a installable toolchain" 1DESCRIPTION = "Meta package for building a installable toolchain"
2LICENSE = "MIT" 2LICENSE = "MIT"
3DEPENDS = "ipkg-native ipkg-utils-native fakeroot-native sed-native" 3DEPENDS = "ipkg-native ipkg-utils-native fakeroot-native sed-native"
4PR = "r3"
5 4
6inherit sdk 5inherit sdk meta
7
8PACKAGES = ""
9
10BUILD_ALL_DEPS = "1"
11do_build[recrdeptask] = "do_build"
12 6
13SDK_DIR = "${WORKDIR}/sdk" 7SDK_DIR = "${WORKDIR}/sdk"
14SDK_OUTPUT = "${SDK_DIR}/image" 8SDK_OUTPUT = "${SDK_DIR}/image"
15SDK_DEPLOY = "${TMPDIR}/deploy/sdk" 9SDK_DEPLOY = "${TMPDIR}/deploy/sdk"
16 10
17IPKG_HOST = "ipkg-cl -f ${SDK_DIR}/ipkg-host.conf -o ${SDK_OUTPUT}" 11IPKG_HOST = "ipkg-cl -f ${IPKGCONF_SDK} -o ${SDK_OUTPUT}"
18IPKG_TARGET = "ipkg-cl -f ${SDK_DIR}/ipkg-target.conf -o ${SDK_OUTPUT}/${prefix}" 12IPKG_TARGET = "ipkg-cl -f ${IPKGCONF_TARGET} -o ${SDK_OUTPUT}/${prefix}"
19 13
20HOST_INSTALL = "task-poky-standalone-sdk-host" 14HOST_INSTALL = "task-poky-standalone-sdk-host"
21 15
@@ -30,20 +24,11 @@ do_populate_sdk() {
30 rm -rf ${SDK_OUTPUT} 24 rm -rf ${SDK_OUTPUT}
31 mkdir -p ${SDK_OUTPUT} 25 mkdir -p ${SDK_OUTPUT}
32 26
33 cat <<EOF >${SDK_DIR}/ipkg-host.conf 27 package_generate_ipkg_conf
34src oe file:${DEPLOY_DIR_IPK} 28
35EOF 29 for arch in ${PACKAGE_ARCHS}; do
36 cat <<EOF >${SDK_DIR}/ipkg-target.conf
37src oe file:${DEPLOY_DIR_IPK}
38EOF
39 ipkgarchs="${PACKAGE_ARCHS}"
40 priority=1
41 for arch in $ipkgarchs; do
42 echo "arch $arch $priority" >> ${SDK_DIR}/ipkg-target.conf
43 echo "arch ${BUILD_ARCH}-$arch-sdk $priority" >> ${SDK_DIR}/ipkg-host.conf
44 priority=$(expr $priority + 5)
45 revipkgarchs="$arch $revipkgarchs" 30 revipkgarchs="$arch $revipkgarchs"
46 done 31 done
47 32
48 rm -r ${SDK_OUTPUT} 33 rm -r ${SDK_OUTPUT}
49 mkdir -p ${SDK_OUTPUT} 34 mkdir -p ${SDK_OUTPUT}