diff options
author | Abdoulaye Walsimou Gaye <awg@embtoolkit.org> | 2013-04-05 00:12:26 +0200 |
---|---|---|
committer | Abdoulaye Walsimou Gaye <awg@embtoolkit.org> | 2013-04-05 00:12:26 +0200 |
commit | e656ae635a85965714e6e3e47c2cc56318b18b33 (patch) | |
tree | a3faf13b1bd62021319debb744637451661670a2 /defconfigs/arm/arm-ic-build.sh | |
parent | f6b69f902f18c6e307113e9a2db8bf284c1a8efe (diff) | |
download | embtoolkit-e656ae635a85965714e6e3e47c2cc56318b18b33.tar.gz embtoolkit-e656ae635a85965714e6e3e47c2cc56318b18b33.tar.bz2 embtoolkit-e656ae635a85965714e6e3e47c2cc56318b18b33.tar.xz |
Build system: add continuous integration build script
Signed-off-by: Abdoulaye Walsimou Gaye <awg@embtoolkit.org>
Diffstat (limited to 'defconfigs/arm/arm-ic-build.sh')
-rwxr-xr-x | defconfigs/arm/arm-ic-build.sh | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/defconfigs/arm/arm-ic-build.sh b/defconfigs/arm/arm-ic-build.sh new file mode 100755 index 0000000..6c71fa3 --- /dev/null +++ b/defconfigs/arm/arm-ic-build.sh @@ -0,0 +1,116 @@ +#!/bin/sh + +arm_perror() { + echo "[IC-BUILD-ERROR] ARM: $1" +} + +cibuild_kconfig=$workspace/cibuild-arm.kconfig +rm -rf $cibuild_kconfig + +set_arch_family() { + case "$archvariant" in + arm9tdmi|arm920t|arm922t) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_ARM9TDMI_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + arm968e-s) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_ARM9E_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + arm1020e|arm1022e|arm1026ej-s) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_ARM10E_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + xscale) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_XSCALE_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + arm1136j-s|arm1136jf-s|arm1176jz-s|arm1176jzf-s|mpcore) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_ARM11_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + cortex-a7|cortex-a8|cortex-a9|cortex-a15) + echo "CONFIG_EMBTK_ARCH_ARM_FAMILY_CORTEX_"$(echo $archvariant | tr a-z A-Z)"=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unknown ARM architecture family for $archvariant" + exit 1 + ;; + esac +} + +set_endian() { + case "$endian" in + LITTLE) + echo "CONFIG_EMBTK_ARCH_ARM_LITTLE_ENDIAN=y" >> $cibuild_kconfig + ;; + BIG) + echo "CONFIG_EMBTK_ARCH_ARM_LITTLE_ENDIAN=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unknown ARM endianness for $archvariant" + exit 1 + ;; + esac +} + +set_float() { + case "$float" in + softfloat) + echo "CONFIG_EMBTK_SOFTFLOAT=y" >> $cibuild_kconfig + ;; + hardfloat) + echo "CONFIG_EMBTK_HARDFLOAT=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unknown ARM floating point type $float for $archvariant" + exit 1 + ;; + esac +} + +set_os() { + case "$os" in + LINUX) + echo "CONFIG_EMBTK_OS_LINUX=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unsupported OS $os for ARM, please help to support it" + exit 1 + ;; + esac +} + +set_xcompiler() { + case "$toolchain" in + GCC) + echo "CONFIG_EMBTK_GCC_TOOLCHAIN=y" >> $cibuild_kconfig + ;; + Clang+llvm) + echo "CONFIG_EMBTK_LLVM_ONLY_TOOLCHAIN=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unsupported cross compiler $toolchain for ARM, please help to support it" + exit 1 + ;; + esac +} + +set_clibrary() { + case "$clibrary" in + eglibc) + echo "CONFIG_EMBTK_CLIB_EGLIBC=y" >> $cibuild_kconfig + ;; + uClibc) + echo "CONFIG_EMBTK_CLIB_UCLIBC=y" >> $cibuild_kconfig + ;; + *) + arm_perror "Unsupported c library $clibrary for ARM, please help to support it" + exit 1 + ;; + esac +} + +set_os +set_endian +set_arch_family +set_float +set_xcompiler +set_clibrary + +cat $cibuild_kconfig >> $workspace/.config && rm -rf $cibuild_kconfig |