Add support for raspi3 rootfs generation for ubuntu-image consumption with all the additional changes required.

sil2100/raspi-wpasupplicant
Łukasz 'sil2100' Zemczak 6 years ago
parent 97fcf09972
commit e547599e5a

5
debian/changelog vendored

@ -2,8 +2,11 @@ livecd-rootfs (2.537) UNRELEASED; urgency=medium
* Avoid issues of hard-linking to a symbolic vmlinuz as this can lead to a * Avoid issues of hard-linking to a symbolic vmlinuz as this can lead to a
dangling symlink. dangling symlink.
* Add support for raspi3 rootfs builds (based on Ryan Finnie).
* For ubuntu-image consumption, export the kernel and initrd to
image/boot/uboot for raspi*.
-- Łukasz 'sil2100' Zemczak <lukasz.zemczak@ubuntu.com> Tue, 18 Sep 2018 10:21:30 +0200 -- Łukasz 'sil2100' Zemczak <lukasz.zemczak@ubuntu.com> Tue, 18 Sep 2018 10:45:58 +0200
livecd-rootfs (2.536) cosmic; urgency=medium livecd-rootfs (2.536) cosmic; urgency=medium

@ -555,7 +555,7 @@ case $PROJECT:${SUBPROJECT:-} in
if [ "$PROJECT:$SUBPROJECT" = "ubuntu-core:system-image" ]; then if [ "$PROJECT:$SUBPROJECT" = "ubuntu-core:system-image" ]; then
case $ARCH in case $ARCH in
armhf) armhf)
subarches="generic raspi2" subarches="generic raspi2 raspi3"
;; ;;
arm64) arm64)
subarches="generic dragonboard" subarches="generic dragonboard"
@ -593,6 +593,8 @@ case $PROJECT:${SUBPROJECT:-} in
armhf) armhf)
if [ "$devarch" = "raspi2" ]; then if [ "$devarch" = "raspi2" ]; then
linux_package="linux-image-raspi2" linux_package="linux-image-raspi2"
elif [ "$devarch" = "raspi3" ]; then
linux_package="linux-image-raspi2"
fi fi
;; ;;
ppc64el|s390x) ppc64el|s390x)
@ -660,7 +662,7 @@ case $PROJECT:${SUBPROJECT:-} in
if [ -n "$dtbs" ]; then if [ -n "$dtbs" ]; then
mv "$dtbs" $TMPDIR/assets/dtbs mv "$dtbs" $TMPDIR/assets/dtbs
case $devarch in case $devarch in
raspi2) raspi2|raspi3)
# ubuntu-device-flash does not like subdirs here, we need to tar it up # ubuntu-device-flash does not like subdirs here, we need to tar it up
if [ -e $TMPDIR/assets/dtbs/overlays ]; then if [ -e $TMPDIR/assets/dtbs/overlays ]; then
tar -C $TMPDIR/assets/dtbs -f $TMPDIR/assets/dtbs/overlays.tgz -czv overlays tar -C $TMPDIR/assets/dtbs -f $TMPDIR/assets/dtbs/overlays.tgz -czv overlays
@ -707,6 +709,9 @@ EOF
if [ "$devarch" = "raspi2" ];then if [ "$devarch" = "raspi2" ];then
tarname="raspi2.$tarname" tarname="raspi2.$tarname"
manifestname="$devarch.$manifestname" manifestname="$devarch.$manifestname"
elif [ "$devarch" = "raspi3" ];then
tarname="raspi3.$tarname"
manifestname="$devarch.$manifestname"
elif [ "$devarch" = "dragonboard" ];then elif [ "$devarch" = "dragonboard" ];then
tarname="$devarch.$tarname" tarname="$devarch.$tarname"
manifestname="$devarch.$manifestname" manifestname="$devarch.$manifestname"
@ -736,6 +741,9 @@ EOF
if [ "$devarch" = "raspi2" ];then if [ "$devarch" = "raspi2" ];then
metaname=canonical-pi2-linux metaname=canonical-pi2-linux
snapname="$devarch.kernel.snap" snapname="$devarch.kernel.snap"
elif [ "$devarch" = "raspi3" ];then
metaname=canonical-pi3-linux
snapname="$devarch.kernel.snap"
elif [ "$devarch" = "generic" ] && [ "$ARCH" = "armhf" ];then elif [ "$devarch" = "generic" ] && [ "$ARCH" = "armhf" ];then
metaname=canonical-bbb-linux metaname=canonical-bbb-linux
elif [ "$devarch" = "dragonboard" ] && [ "$ARCH" = "arm64" ];then elif [ "$devarch" = "dragonboard" ] && [ "$ARCH" = "arm64" ];then
@ -845,36 +853,46 @@ if [ "$NUMFLAVOURS" = 1 ] && [ "$LB_LINUX_FLAVOURS" != "none" ]; then
fi fi
fi fi
if [ "$SUBARCH" = "ac100" ]; then case $SUBARCH in
# create the md5sum and size files for which we are actually doing all this ac100)
md5sum $PREFIX.rootfs.tar.gz >chroot/installer.md5 # create the md5sum and size files for which we are actually doing all this
wc -c $PREFIX.rootfs.tar.gz >chroot/installer.size md5sum $PREFIX.rootfs.tar.gz >chroot/installer.md5
wc -c $PREFIX.rootfs.tar.gz >chroot/installer.size
INFO_DESC="$(lsb_release -d -s)" INFO_DESC="$(lsb_release -d -s)"
INFO_STAMP=$(date +20%y%m%d-%H:%M) INFO_STAMP=$(date +20%y%m%d-%H:%M)
echo "$INFO_DESC - $ARCH ($INFO_STAMP)" >chroot/media-info echo "$INFO_DESC - $ARCH ($INFO_STAMP)" >chroot/media-info
# make sure update-initramfs feels cosy and warm in the environment # make sure update-initramfs feels cosy and warm in the environment
lb chroot_proc install "$@" lb chroot_proc install "$@"
lb chroot_sysfs install "$@" lb chroot_sysfs install "$@"
lb chroot_devpts install "$@" lb chroot_devpts install "$@"
# re-create initrd to contain the installer.md5 file # re-create initrd to contain the installer.md5 file
Chroot chroot "env FLASH_KERNEL_SKIP=1 update-initramfs -k all -t -u -v" Chroot chroot "env FLASH_KERNEL_SKIP=1 update-initramfs -k all -t -u -v"
# create boot.img # create boot.img
Chroot chroot "abootimg --create /boot/installer-${KVERS}.img -f /boot/bootimg.cfg-$SUBARCH -r /boot/initrd.img-${KVERS} -k /boot/vmlinuz-${KVERS}" Chroot chroot "abootimg --create /boot/installer-${KVERS}.img -f /boot/bootimg.cfg-$SUBARCH -r /boot/initrd.img-${KVERS} -k /boot/vmlinuz-${KVERS}"
# clean up # clean up
lb chroot_devpts remove "$@" lb chroot_devpts remove "$@"
lb chroot_sysfs remove "$@" lb chroot_sysfs remove "$@"
lb chroot_proc remove "$@" lb chroot_proc remove "$@"
cp "chroot/boot/installer-${KVERS}.img" "$PREFIX.bootimg-$FLAVOUR"
ln -sf "$PREFIX.bootimg-$FLAVOUR" "$PREFIX.bootimg"
;;
cp "chroot/boot/installer-${KVERS}.img" "$PREFIX.bootimg-$FLAVOUR" raspi2|raspi3)
ln -sf "$PREFIX.bootimg-$FLAVOUR" "$PREFIX.bootimg" UBOOT_BOOT="image/boot/uboot"
fi mkdir -p $UBOOT_BOOT
cp $PREFIX.initrd $UBOOT_BOOT/initrd.img || true
cp $PREFIX.kernel $UBOOT_BOOT/vmlinuz || true
;;
esac
if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then
sourceslist="chroot/etc/apt/sources.list" sourceslist="chroot/etc/apt/sources.list"

@ -746,6 +746,12 @@ case $ARCH in
add_package install linux-firmware-raspi2 u-boot-rpi flash-kernel u-boot-tools add_package install linux-firmware-raspi2 u-boot-rpi flash-kernel u-boot-tools
BINARY_REMOVE_LINUX=false BINARY_REMOVE_LINUX=false
;; ;;
raspi3)
COMPONENTS='main restricted universe multiverse'
KERNEL_FLAVOURS=raspi2
add_package install linux-firmware-raspi2 u-boot-rpi flash-kernel u-boot-tools
BINARY_REMOVE_LINUX=false
;;
esac esac
;; ;;
esac esac

Loading…
Cancel
Save