diff options
author | Nicolas Dechesne <nicolas.dechesne@linaro.org> | 2016-09-09 11:43:04 +0200 |
---|---|---|
committer | Nicolas Dechesne <nicolas.dechesne@linaro.org> | 2016-09-09 10:09:06 +0000 |
commit | c09cc66652fa41b372d0d0663613d9375a366af9 (patch) | |
tree | 2da676a645c06204a61b084098fce30cbc8f8b82 /lt-qcom-debian-images-arm64 | |
parent | 842367188baea5c26144583bace48a58c6035700 (diff) |
lt-qcom-*: move build shell scripts in a standalone shell script
Using Jenkins include-raw instructions, so that it is easier to maintain the
build instructions and possibly easier to factorize later on.
Also changed the indentation in lt-qcom*/builders.sh.
This is expected to be a no-op patch.
Change-Id: I4812db69e06d97ab063b1e841563239c5db36156
Signed-off-by: Nicolas Dechesne <nicolas.dechesne@linaro.org>
Diffstat (limited to 'lt-qcom-debian-images-arm64')
-rw-r--r-- | lt-qcom-debian-images-arm64/builders.sh | 301 |
1 files changed, 301 insertions, 0 deletions
diff --git a/lt-qcom-debian-images-arm64/builders.sh b/lt-qcom-debian-images-arm64/builders.sh new file mode 100644 index 0000000000..16e63aaaee --- /dev/null +++ b/lt-qcom-debian-images-arm64/builders.sh @@ -0,0 +1,301 @@ +#!/bin/bash + +set -ex + +trap cleanup_exit INT TERM EXIT + +cleanup_exit() +{ + cd ${WORKSPACE} + sudo kpartx -dv out/${VENDOR}-${OS_FLAVOUR}-*.sd.img || true + rm -rf lci-build-tools + rm -rf builddir* + rm -rf out + git clean -fdx +} + +sudo apt-get update +sudo apt-get install -y kpartx python-pycurl device-tree-compiler zip libfdt-dev mtools android-tools-fsutils +wget -q \ + http://repo.linaro.org/ubuntu/linaro-tools/pool/main/l/linaro-image-tools/linaro-image-tools_2016.05-1linarojessie1_amd64.deb \ + http://repo.linaro.org/ubuntu/linaro-tools/pool/main/l/linaro-image-tools/python-linaro-image-tools_2016.05-1linarojessie1_all.deb +sudo dpkg -i --force-all *.deb +rm -f *.deb + +# get the boot image tools, and keep track of commit info in the traces +git clone git://codeaurora.org/quic/kernel/skales +(cd skales && git log -1) +export PATH=`pwd`/skales:$PATH + +export LANG=C +export make_bootwrapper=false +export make_install=true +export kernel_flavour=lt-qcom +export kernel_config="defconfig distro.config" +export MAKE_DTBS=true +export ARCH=arm64 +export tcbindir="${HOME}/srv/toolchain/arm64-tc-14.09/bin" +export toolchain_url=http://releases.linaro.org/14.09/components/toolchain/binaries/gcc-linaro-aarch64-linux-gnu-4.9-2014.09_linux.tar.xz + +test -d lci-build-tools || git clone https://git.linaro.org/git/ci/lci-build-tools.git lci-build-tools +bash -x lci-build-tools/jenkins_kernel_build_inst + +# Create the hardware pack +cat << EOF > ${VENDOR}-lt-qcom.default +format: '3.0' +name: ${VENDOR}-lt-qcom +architectures: +- arm64 +origin: Linaro +maintainer: Linaro Platform <linaro-dev@lists.linaro.org> +support: supported +serial_tty: ${SERIAL_CONSOLE} +kernel_addr: '0x80208000' +initrd_addr: '0x83000000' +load_addr: '0x60008000' +dtb_addr: '0x61000000' +partition_layout: bootfs_rootfs +mmc_id: '0:1' +kernel_file: boot/Image-*-qcom +initrd_file: boot/initrd.img-*-qcom +dtb_file: lib/firmware/*-qcom/device-tree/msm8916-mtp.dtb +boot_script: boot.scr +boot_min_size: 64 +extra_serial_options: +- console=tty0 +- console=${SERIAL_CONSOLE},115200n8 +assume_installed: +- adduser +- apt +- apt-utils +- debconf-i18n +- debian-archive-keyring +- gcc-4.9 +- gnupg +- ifupdown +- initramfs-tools +- iproute2 +- irqbalance +- isc-dhcp-client +- kmod +- netbase +- udev +- linaro-artwork +sources: + qcom: http://repo.linaro.org/ubuntu/qcom-overlay ${OS_FLAVOUR} main + repo: http://repo.linaro.org/ubuntu/linaro-overlay ${OS_FLAVOUR} main + debian: http://ftp.debian.org/debian/ ${OS_FLAVOUR} main contrib non-free + backports: http://ftp.debian.org/debian/ ${OS_FLAVOUR}-backports main +packages: +- linux-image-arm64 +- linux-headers-arm64 +- firmware-linux +- wcnss-wlan +- wcnss-bt +- wcnss-start +EOF + +# Build information +cat > out/HEADER.textile << EOF + +h4. QCOM Landing Team - Snapdragon 410 - Debian + +Build description: +* Build URL: "$BUILD_URL":$BUILD_URL +* OS flavour: $OS_FLAVOUR +* Kernel tree: "$GIT_URL":$GIT_URL +* Kernel branch: $KERNEL_BRANCH +* Kernel version: "$GIT_COMMIT":$GIT_URL/commit/$GIT_COMMIT +* Kernel defconfig: $kernel_config +EOF + +# Download license file and firmware +rm -f license.txt +wget https://git.linaro.org/landing-teams/working/qualcomm/lt-docs.git/blob_plain/HEAD:/license/license.txt + +rm -rf qcom_firmware && mkdir qcom_firmware && cd qcom_firmware +wget -q ${QCOM_FIRMWARE} +echo "${QCOM_FIRMWARE_MD5} $(basename ${QCOM_FIRMWARE})" > MD5 +md5sum -c MD5 +unzip $(basename ${QCOM_FIRMWARE}) +cd - +rm -f qcom_firmware/linux-board-support-package-*/proprietary-linux/wlan/macaddr0 +rm -f qcom_firmware/linux-board-support-package-*/proprietary-linux/firmware.tar +sudo MTOOLS_SKIP_CHECK=1 mcopy -i qcom_firmware/linux-board-support-package-*/bootloaders-linux/NON-HLOS.bin \ + ::image/modem.* ::image/mba.mbn qcom_firmware/linux-board-support-package-*/proprietary-linux + +for rootfs in ${ROOTFS}; do + + rootfs_arch=$(echo $rootfs | cut -f2 -d,) + rootfs_sz=$(echo $rootfs | cut -f3 -d,) + rootfs=$(echo $rootfs | cut -f1 -d,) + + cat ${VENDOR}-lt-qcom.default > ${VENDOR}-lt-qcom + + # additional packages in desktop images + [ "${rootfs}" = "alip" ] && cat << EOF >> ${VENDOR}-lt-qcom +- xserver-xorg-video-freedreno +- gstreamer1.0-plugins-v4l2 +- 96boards-artwork +EOF + + rm -f `ls hwpack_${VENDOR}-lt-qcom_*_${rootfs_arch}_supported.tar.gz` + VERSION=`date +%Y%m%d`-${BUILD_NUMBER} + linaro-hwpack-create --debug --backports ${VENDOR}-lt-qcom ${VERSION} + linaro-hwpack-replace -t `ls hwpack_${VENDOR}-lt-qcom_*_${rootfs_arch}_supported.tar.gz` -p `ls linux-image-*-${VENDOR}-lt-qcom_*.deb` -r linux-image -d -i + linaro-hwpack-replace -t `ls hwpack_${VENDOR}-lt-qcom_*_${rootfs_arch}_supported.tar.gz` -p `ls linux-headers-*-${VENDOR}-lt-qcom_*.deb` -r linux-headers -d -i + + # Get rootfs + export ROOTFS_BUILD_NUMBER=`wget -q --no-check-certificate -O - https://ci.linaro.org/jenkins/job/debian-${rootfs_arch}-rootfs/label=docker-jessie-${rootfs_arch},rootfs=${rootfs}/lastSuccessfulBuild/buildNumber` + export ROOTFS_BUILD_TIMESTAMP=`wget -q --no-check-certificate -O - https://ci.linaro.org/jenkins/job/debian-${rootfs_arch}-rootfs/label=docker-jessie-${rootfs_arch},rootfs=${rootfs}/lastSuccessfulBuild/buildTimestamp?format=yyyyMMdd` + export ROOTFS_BUILD_URL="http://snapshots.linaro.org/debian/images/${rootfs}-${rootfs_arch}/${ROOTFS_BUILD_NUMBER}/linaro-${OS_FLAVOUR}-${rootfs}-${ROOTFS_BUILD_TIMESTAMP}-${ROOTFS_BUILD_NUMBER}.tar.gz" + wget --progress=dot -e dotbytes=2M ${ROOTFS_BUILD_URL} + + # Create pre-built image(s) + linaro-media-create --dev fastmodel --output-directory ${WORKSPACE}/out --image-file ${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.sd.img --image-size 2G --binary linaro-${OS_FLAVOUR}-${rootfs}-${ROOTFS_BUILD_TIMESTAMP}-${ROOTFS_BUILD_NUMBER}.tar.gz --hwpack hwpack_${VENDOR}-lt-qcom_*.tar.gz --hwpack-force-yes --bootloader uefi + + # Create eMMC rootfs image(s) + mkdir rootfs + for device in $(sudo kpartx -avs out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.sd.img | cut -d' ' -f3); do + partition=$(echo ${device} | cut -d'p' -f3) + [ "${partition}" = "2" ] && sudo mount -o loop /dev/mapper/${device} rootfs + done + + sudo rm -rf rootfs/dev rootfs/boot rootfs/var/lib/apt/lists + sudo mkdir rootfs/dev rootfs/boot rootfs/var/lib/apt/lists + + # clean up fstab + sudo sed -i '/UUID/d' rootfs/etc/fstab + + # add license file in the generated rootfs + sudo cp -f license.txt rootfs/etc/license.txt + + # add firmware (adreno, venus and WCN) + sudo cp -a qcom_firmware/linux-board-support-package-*/proprietary-linux/* rootfs/lib/firmware + + sudo mkfs.ext4 -L rootfs out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img.raw ${rootfs_sz} + mkdir rootfs2 + sudo mount -o loop out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img.raw rootfs2 + sudo cp -a rootfs/* rootfs2 + rootfs_sz_real=$(sudo du -sh rootfs2 | cut -f1) + sudo umount rootfs2 rootfs + sudo ext2simg -v out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img.raw out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img + sudo kpartx -dv out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.sd.img + sudo rm -rf rootfs out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.sd.img rootfs2 out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img.raw + + # Compress image(s) + gzip -9 out/${VENDOR}-${OS_FLAVOUR}-${rootfs}-${PLATFORM_NAME}-${VERSION}.img + + cat >> out/HEADER.textile << EOF +* Linaro Debian ${rootfs}: "http://snapshots.linaro.org/debian/images/${rootfs}-${rootfs_arch}/${ROOTFS_BUILD_NUMBER}":http://snapshots.linaro.org/debian/images/${rootfs}-${rootfs_arch}/${ROOTFS_BUILD_NUMBER} , size: ${rootfs_sz_real} +EOF +done + +# Move all relevant DTBs in out/ +for f in ${DTBS} ; do + mv out/dtbs/${f} out/ +done +rm -rf out/dtbs + +# Create device tree table +dtbTool -o out/dt.img -s 2048 out/ + +# Create boot image +mkbootimg \ + --kernel out/Image \ + --ramdisk out/initrd.img-* \ + --output out/boot-${VENDOR}-${OS_FLAVOUR}-${PLATFORM_NAME}-${VERSION}.img \ + --dt out/dt.img \ + --pagesize "2048" \ + --base "0x80000000" \ + --cmdline "root=/dev/disk/by-partlabel/rootfs rw rootwait console=tty0 console=${SERIAL_CONSOLE},115200n8" +gzip -9 out/boot-${VENDOR}-${OS_FLAVOUR}-${PLATFORM_NAME}-${VERSION}.img + +# Final preparation for publishing +cp -a linux-*.deb out/ + +####################################### +# let's create the SD install image now +####################################### + +TMPKEYDIR=$(mktemp -d /tmp/qcom.XXXXXX) +cat > ${TMPKEYDIR}/private-key-wrapper.py << EOF +#!/usr/bin/python + +import os +import sys + +def main(): + private_key = os.environ.get("PRIVATE_KEY", "Undefined") + if private_key == "Undefined": + sys.exit("PRIVATE_KEY is not defined.") + + buffer = private_key.replace(' ','\n') + with open('linaro-private-key', 'w') as f: + f.write('-----BEGIN RSA PRIVATE KEY-----\n') + f.write(buffer) + f.write('\n-----END RSA PRIVATE KEY-----\n') + +if __name__ == "__main__": + main() +EOF +python ${TMPKEYDIR}/private-key-wrapper.py +chmod 0600 ${WORKSPACE}/linaro-private-key + +eval `ssh-agent` >/dev/null 2>/dev/null +ssh-add ${WORKSPACE}/linaro-private-key >/dev/null 2>/dev/null +rm -rf ${WORKSPACE}/linaro-private-key ${TMPKEYDIR} + +mkdir -p ~/.ssh +ssh-keyscan dev-private-git.linaro.org >> ~/.ssh/known_hosts +cat << EOF >> ~/.ssh/config +Host dev-private-git.linaro.org + User git +EOF +chmod 0600 ~/.ssh/* || true + +git clone --depth 1 ssh://dev-private-git.linaro.org/landing-teams/working/qualcomm/db410c_bootloader.git +# record commit info in build log +cd db410c_bootloader +git log -1 + +cd emmc_linux +cp ../../out/boot-${VENDOR}-${OS_FLAVOUR}-${PLATFORM_NAME}-${VERSION}.img.gz boot.img.gz +cp ../../out/${VENDOR}-${OS_FLAVOUR}-alip-${PLATFORM_NAME}-${VERSION}.img.gz rootfs.img.gz +gunzip *.img.gz + +cat << EOF >> os.json +{ +"name": "Linaro Linux Desktop for DragonBoard 410c - Build #${BUILD_NUMBER}", +"url": "http://builds.96boards.org/releases/dragonboard410c", +"version": "${VERSION}", +"release_date": "`date +%Y-%m-%d`", +"description": "Linaro Linux with LXDE desktop based on Debian (${OS_FLAVOUR}) for DragonBoard 410c" +} +EOF + +cd ../sd_install +# quick hack for now, need to create the proper job that builds the initrd +wget --progress=dot -e dotbytes=2M http://people.linaro.org/~nicolas.dechesne/boot-burn.img +cd .. +./build sdcard_install_debian + +# add license.txt file +rm -f license.txt +wget https://git.linaro.org/landing-teams/working/qualcomm/lt-docs.git/blob_plain/HEAD:/license/license.txt +cp license.txt out/dragonboard410c_sdcard_install_debian + +# create archive for publishing +zip -rj ../out/dragonboard410c_sdcard_install_debian-${BUILD_NUMBER}.zip out/dragonboard410c_sdcard_install_debian +cd .. + +# Create MD5SUMS file +(cd out && md5sum * > MD5SUMS.txt) + +# Publish to snapshots +test -d ${HOME}/bin || mkdir ${HOME}/bin +wget https://git.linaro.org/ci/publishing-api.git/blob_plain/HEAD:/linaro-cp.py -O ${HOME}/bin/linaro-cp.py +time python ${HOME}/bin/linaro-cp.py \ + --server ${PUBLISH_SERVER} \ + --link-latest \ + out snapshots/dragonboard410c/${VENDOR}/debian/${BUILD_NUMBER} |