summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoshua Lock <josh@linux.intel.com>2010-08-11 16:53:03 +0100
committerJoshua Lock <josh@linux.intel.com>2010-08-11 18:04:52 +0100
commitf05fd8dc5cc197635690d89c767fee7a8236897e (patch)
treeb13436e2528269106d0247ad054e46a4318b485f
parent69ac39b90eec55831a9b601913a089838307b200 (diff)
downloadpoky-f05fd8dc5cc197635690d89c767fee7a8236897e.tar.gz
meta-ide-support: A dummy recipe to install everthing for target development
Move the environment-setup script generation into a separate class and adapt meta-toolchain to use it. Add a new dummy target, meta-ide-support, to install an appropriately configured script to TMPDIR and ensure all of the required packages for target development are available. Signed-off-by: Joshua Lock <josh@linux.intel.com>
-rw-r--r--meta/classes/toolchain-scripts.bbclass51
-rw-r--r--meta/packages/meta/meta-ide-support.bb15
-rw-r--r--meta/packages/meta/meta-toolchain.bb24
3 files changed, 68 insertions, 22 deletions
diff --git a/meta/classes/toolchain-scripts.bbclass b/meta/classes/toolchain-scripts.bbclass
new file mode 100644
index 0000000000..8934e0bc56
--- /dev/null
+++ b/meta/classes/toolchain-scripts.bbclass
@@ -0,0 +1,51 @@
1# This function creates an environment-setup-script for use in a deployable SDK
2toolchain_create_sdk_env_script () {
3 # Create environment setup script
4 script=${SDK_OUTPUT}/${SDKPATH}/environment-setup-${MULTIMACH_TARGET_SYS}
5 rm -f $script
6 touch $script
7 echo 'export PATH=${SDKPATHNATIVE}${bindir_nativesdk}:${SDKPATHNATIVE}${bindir_nativesdk}/${MULTIMACH_TARGET_SYS}:$PATH' >> $script
8 echo 'export PKG_CONFIG_SYSROOT_DIR=${SDKTARGETSYSROOT}' >> $script
9 echo 'export PKG_CONFIG_PATH=${SDKTARGETSYSROOT}${libdir}/pkgconfig' >> $script
10 echo 'export CONFIG_SITE=${SDKPATH}/site-config-${MULTIMACH_TARGET_SYS}' >> $script
11 echo 'export CC=${TARGET_PREFIX}gcc' >> $script
12 echo 'export CXX=${TARGET_PREFIX}g++' >> $script
13 echo 'export CONFIGURE_FLAGS="--target=${TARGET_SYS} --host=${TARGET_SYS} --build=${SDK_ARCH}-linux"' >> $script
14 if [ "${TARGET_OS}" = "darwin8" ]; then
15 echo 'export TARGET_CFLAGS="-I${SDKTARGETSYSROOT}${includedir}"' >> $script
16 echo 'export TARGET_LDFLAGS="-L${SDKTARGETSYSROOT}${libdir}"' >> $script
17 # Workaround darwin toolchain sysroot path problems
18 cd ${SDK_OUTPUT}${SDKTARGETSYSROOT}/usr
19 ln -s /usr/local local
20 fi
21 echo 'export CFLAGS="${TARGET_CC_ARCH}"' >> $script
22 echo 'export CXXFLAGS="${TARGET_CC_ARCH}"' >> $script
23 echo "alias opkg='LD_LIBRARY_PATH=${SDKPATHNATIVE}${libdir_nativesdk} ${SDKPATHNATIVE}${bindir_nativesdk}/opkg-cl -f ${SDKPATHNATIVE}/${sysconfdir}/opkg-sdk.conf -o ${SDKPATHNATIVE}'" >> $script
24 echo "alias opkg-target='LD_LIBRARY_PATH=${SDKPATHNATIVE}${libdir_nativesdk} ${SDKPATHNATIVE}${bindir_nativesdk}/opkg-cl -f ${SDKTARGETSYSROOT}${sysconfdir}/opkg.conf -o ${SDKTARGETSYSROOT}'" >> $script
25}
26
27# This function creates an environment-setup-script in the TMPDIR which enables a Poky IDE to integrate with the
28# build tree
29toolchain_create_tree_env_script () {
30 script=${TMPDIR}/environment-setup-${MULTIMACH_TARGET_SYS}
31 rm -f $script
32 touch $script
33 echo 'export PATH=${PATH}' >> $script
34 echo 'export PKG_CONFIG_SYSROOT_DIR=${STAGING_DIR}/${TARGET_SYS}' >> $script
35 echo 'export PKG_CONFIG_PATH=${STAGING_DIR}/${TARGET_SYS}${libdir}/pkgconfig' >> $script
36
37 echo 'export CONFIG_SITE="${@siteinfo_get_files(d)}"' >> $script
38
39 echo 'export CC=${TARGET_PREFIX}gcc' >> $script
40 echo 'export CXX=${TARGET_PREFIX}g++' >> $script
41 echo 'export CONFIGURE_FLAGS="--target=${TARGET_SYS} --host=${TARGET_SYS} --build=${BUILD_SYS}"' >> $script
42 if [ "${TARGET_OS}" = "darwin8" ]; then
43 echo 'export TARGET_CFLAGS="-I${STAGING_DIR}${TARGET_SYS}${includedir}"' >> $script
44 echo 'export TARGET_LDFLAGS="-L${STAGING_DIR}${TARGET_SYS}${libdir}"' >> $script
45 # Workaround darwin toolchain sysroot path problems
46 cd ${SDK_OUTPUT}${SDKTARGETSYSROOT}/usr
47 ln -s /usr/local local
48 fi
49 echo 'export CFLAGS="${TARGET_CC_ARCH}"' >> $script
50 echo 'export CXXFLAGS="${TARGET_CC_ARCH}"' >> $script
51}
diff --git a/meta/packages/meta/meta-ide-support.bb b/meta/packages/meta/meta-ide-support.bb
new file mode 100644
index 0000000000..0d564baa5c
--- /dev/null
+++ b/meta/packages/meta/meta-ide-support.bb
@@ -0,0 +1,15 @@
1DESCRIPTION = "Meta package for ensuring the build directory contains all appropriate toolchain packages for using an IDE"
2LICENSE = "MIT"
3DEPENDS = "virtual/libc"
4RDEPENDS = "task-sdk-host"
5PR = "r0"
6
7inherit meta toolchain-scripts
8
9do_populate_ide_support () {
10 toolchain_create_tree_env_script
11}
12
13do_populate_ide_support[nostamp] = "1"
14do_populate_ide_support[recrdeptask] = "do_package_write"
15addtask populate_ide_support before do_build after do_install
diff --git a/meta/packages/meta/meta-toolchain.bb b/meta/packages/meta/meta-toolchain.bb
index a53569b55b..585adb4e13 100644
--- a/meta/packages/meta/meta-toolchain.bb
+++ b/meta/packages/meta/meta-toolchain.bb
@@ -2,7 +2,7 @@ DESCRIPTION = "Meta package for building a installable toolchain"
2LICENSE = "MIT" 2LICENSE = "MIT"
3DEPENDS = "opkg-native opkg-utils-native virtual/fakeroot-native sed-native" 3DEPENDS = "opkg-native opkg-utils-native virtual/fakeroot-native sed-native"
4 4
5inherit meta 5inherit meta toolchain-scripts
6 6
7SDK_DIR = "${WORKDIR}/sdk" 7SDK_DIR = "${WORKDIR}/sdk"
8SDK_OUTPUT = "${SDK_DIR}/image" 8SDK_OUTPUT = "${SDK_DIR}/image"
@@ -79,27 +79,7 @@ do_populate_sdk() {
79 cat $sitefile >> $siteconfig 79 cat $sitefile >> $siteconfig
80 done 80 done
81 81
82 # Create environment setup script 82 toolchain_create_sdk_env_script
83 script=${SDK_OUTPUT}/${SDKPATH}/environment-setup-${MULTIMACH_TARGET_SYS}
84 touch $script
85 echo 'export PATH=${SDKPATHNATIVE}${bindir_nativesdk}:${SDKPATHNATIVE}${bindir_nativesdk}/${MULTIMACH_TARGET_SYS}:$PATH' >> $script
86 echo 'export PKG_CONFIG_SYSROOT_DIR=${SDKTARGETSYSROOT}' >> $script
87 echo 'export PKG_CONFIG_PATH=${SDKTARGETSYSROOT}${libdir}/pkgconfig' >> $script
88 echo 'export CONFIG_SITE=${SDKPATH}/site-config-${MULTIMACH_TARGET_SYS}' >> $script
89 echo 'export CC=${TARGET_PREFIX}gcc' >> $script
90 echo 'export CXX=${TARGET_PREFIX}g++' >> $script
91 echo 'export CONFIGURE_FLAGS="--target=${TARGET_SYS} --host=${TARGET_SYS} --build=${SDK_ARCH}-linux"' >> $script
92 if [ "${TARGET_OS}" = "darwin8" ]; then
93 echo 'export TARGET_CFLAGS="-I${SDKTARGETSYSROOT}${includedir}"' >> $script
94 echo 'export TARGET_LDFLAGS="-L${SDKTARGETSYSROOT}${libdir}"' >> $script
95 # Workaround darwin toolchain sysroot path problems
96 cd ${SDK_OUTPUT}${SDKTARGETSYSROOT}/usr
97 ln -s /usr/local local
98 fi
99 echo 'export CFLAGS="${TARGET_CC_ARCH}"' >> $script
100 echo 'export CXXFLAGS="${TARGET_CC_ARCH}"' >> $script
101 echo "alias opkg='LD_LIBRARY_PATH=${SDKPATHNATIVE}${libdir_nativesdk} ${SDKPATHNATIVE}${bindir_nativesdk}/opkg-cl -f ${SDKPATHNATIVE}/${sysconfdir}/opkg-sdk.conf -o ${SDKPATHNATIVE}'" >> $script
102 echo "alias opkg-target='LD_LIBRARY_PATH=${SDKPATHNATIVE}${libdir_nativesdk} ${SDKPATHNATIVE}${bindir_nativesdk}/opkg-cl -f ${SDKTARGETSYSROOT}${sysconfdir}/opkg.conf -o ${SDKTARGETSYSROOT}'" >> $script
103 83
104 # Add version information 84 # Add version information
105 versionfile=${SDK_OUTPUT}/${SDKPATH}/version-${MULTIMACH_TARGET_SYS} 85 versionfile=${SDK_OUTPUT}/${SDKPATH}/version-${MULTIMACH_TARGET_SYS}