mkimage.sh.in 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. #!/bin/sh
  2. #-
  3. # Copyright (c) 2013-2015 Juan Romero Pardines.
  4. # All rights reserved.
  5. #
  6. # Redistribution and use in source and binary forms, with or without
  7. # modification, are permitted provided that the following conditions
  8. # are met:
  9. # 1. Redistributions of source code must retain the above copyright
  10. # notice, this list of conditions and the following disclaimer.
  11. # 2. Redistributions in binary form must reproduce the above copyright
  12. # notice, this list of conditions and the following disclaimer in the
  13. # documentation and/or other materials provided with the distribution.
  14. #
  15. # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  16. # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  17. # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  18. # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  19. # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  20. # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  21. # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  22. # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  23. # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  24. # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  25. #-
  26. readonly PROGNAME=$(basename $0)
  27. readonly ARCH=$(uname -m)
  28. trap 'printf "\nInterrupted! exiting...\n"; cleanup; exit 0' INT TERM HUP
  29. cleanup() {
  30. umount -f ${ROOTFSDIR}/boot 2>/dev/null
  31. umount -f ${ROOTFSDIR} 2>/dev/null
  32. if [ -e "$LOOPDEV" ]; then
  33. partx -d $LOOPDEV 2>/dev/null
  34. losetup -d $LOOPDEV 2>/dev/null
  35. fi
  36. [ -d "$ROOTFSDIR" ] && rmdir $ROOTFSDIR
  37. }
  38. info_msg() {
  39. printf "\033[1m[${PLATFORM}] $@\n\033[m"
  40. }
  41. die() {
  42. echo "FATAL: $@"
  43. exit 1
  44. }
  45. usage() {
  46. cat <<_EOF
  47. Usage: $PROGNAME [options] <rootfs-tarball>
  48. The <rootfs-tarball> argument expects a tarball generated by void-mkrootfs.
  49. The platform is guessed automatically by its name.
  50. Accepted sizes suffixes: K, M, G, T, E.
  51. OPTIONS
  52. -b <fstype> Set /boot filesystem type (defaults to FAT)
  53. -B <bsize> Set /boot filesystem size (defaults to 64MB)
  54. -r <fstype> Set / filesystem type (defaults to EXT4)
  55. -s <totalsize> Set total image size (defaults to 2GB)
  56. -o <output> Set image filename (guessed automatically)
  57. -h Show this help
  58. -V Show version
  59. Resulting image will have 2 partitions, /boot and /.
  60. _EOF
  61. exit 0
  62. }
  63. #
  64. # main()
  65. #
  66. while getopts "b:B:o:r:s:hV" opt; do
  67. case $opt in
  68. b) BOOT_FSTYPE="$OPTARG";;
  69. B) BOOT_FSSIZE="$OPTARG";;
  70. o) FILENAME="$OPTARG";;
  71. r) ROOT_FSTYPE="$OPTARG";;
  72. s) IMGSIZE="$OPTARG";;
  73. V) echo "$PROGNAME @@MKLIVE_VERSION@@"; exit 0;;
  74. h) usage;;
  75. esac
  76. done
  77. shift $(($OPTIND - 1))
  78. ROOTFS_TARBALL="$1"
  79. if [ -z "$ROOTFS_TARBALL" ]; then
  80. usage
  81. elif [ ! -r "$ROOTFS_TARBALL" ]; then
  82. die "Cannot read rootfs tarball: $ROOTFS_TARBALL"
  83. fi
  84. PLATFORM="${ROOTFS_TARBALL#void-}"
  85. PLATFORM="${PLATFORM%-rootfs*}"
  86. if [ "$(id -u)" -ne 0 ]; then
  87. die "need root perms to continue, exiting."
  88. fi
  89. : ${IMGSIZE:=2G}
  90. : ${BOOT_FSTYPE:=vfat}
  91. : ${BOOT_FSSIZE:=64M}
  92. : ${ROOT_FSTYPE:=ext4}
  93. if [ -z "$FILENAME" ]; then
  94. FILENAME="void-${PLATFORM}-$(date +%Y%m%d).img"
  95. fi
  96. # double check PLATFORM is supported...
  97. case "$PLATFORM" in
  98. bananapi|beaglebone|cubieboard2|odroid-u2|rpi|rpi2);;
  99. *) die "The $PLATFORM is not supported, exiting..."
  100. esac
  101. for f in parted partx losetup mount mkfs.${BOOT_FSTYPE} mkfs.${ROOT_FSTYPE}; do
  102. if ! which ${f} >/dev/null; then
  103. die "Cannot find ${f}, exiting."
  104. fi
  105. done
  106. # dd conv=sparse support first appeared in coreutils-8.16, disable it in
  107. # older versions.
  108. DD_VERSION=$(dd --version|head -n1|awk '{print $3}')
  109. case "$DD_VERSION" in
  110. [8-9].1[6-9]*|[8-9].[2-9]*) DD_SPARSE="conv=sparse";;
  111. esac
  112. info_msg "Creating disk image ($IMGSIZE) ..."
  113. dd if=/dev/zero of=$FILENAME bs=$IMGSIZE count=1 ${DD_SPARSE} >/dev/null 2>&1
  114. info_msg "Creating disk image partitions/filesystems ..."
  115. parted $FILENAME mktable msdos
  116. if [ "$BOOT_FSTYPE" = "vfat" ]; then
  117. _btype="fat32"
  118. _args="-I -F16"
  119. fi
  120. parted $FILENAME mkpart primary ${_btype} 4096s ${BOOT_FSSIZE}
  121. parted $FILENAME mkpart primary ext2 ${BOOT_FSSIZE} 100%
  122. parted $FILENAME toggle 1 boot
  123. LOOPDEV=$(losetup --show --find --partscan $FILENAME)
  124. mkfs.${BOOT_FSTYPE} $_args ${LOOPDEV}p1 >/dev/null
  125. case "$ROOT_FSTYPE" in
  126. ext[34]) disable_journal="-O ^has_journal";;
  127. esac
  128. mkfs.${ROOT_FSTYPE} $disable_journal ${LOOPDEV}p2 >/dev/null 2>&1
  129. ROOTFSDIR=$(mktemp -d)
  130. mount ${LOOPDEV}p2 $ROOTFSDIR
  131. mkdir -p ${ROOTFSDIR}/boot
  132. mount ${LOOPDEV}p1 ${ROOTFSDIR}/boot
  133. info_msg "Unpacking rootfs tarball ..."
  134. if [ "$PLATFORM" = "beaglebone" ]; then
  135. fstab_args=",noauto"
  136. tar xfp $ROOTFS_TARBALL -C $ROOTFSDIR ./boot/MLO
  137. tar xfp $ROOTFS_TARBALL -C $ROOTFSDIR ./boot/u-boot.img
  138. touch $ROOTFSDIR/boot/uEnv.txt
  139. umount $ROOTFSDIR/boot
  140. fi
  141. tar xfp $ROOTFS_TARBALL -C $ROOTFSDIR
  142. BOOT_UUID=$(blkid -o value -s UUID ${LOOPDEV}p1)
  143. ROOT_UUID=$(blkid -o value -s UUID ${LOOPDEV}p2)
  144. fspassno="1"
  145. if [ "$ROOT_FSTYPE" = "f2fs" ]; then
  146. fspassno="0"
  147. fi
  148. echo "UUID=$ROOT_UUID / $ROOT_FSTYPE defaults 0 ${fspassno}" >> ${ROOTFSDIR}/etc/fstab
  149. echo "UUID=$BOOT_UUID /boot $BOOT_FSTYPE defaults${fstab_args} 0 2" >> ${ROOTFSDIR}/etc/fstab
  150. if [ "$PLATFORM" = "cubieboard2" -o "$PLATFORM" = "bananapi" ]; then
  151. dd if=${ROOTFSDIR}/boot/u-boot-sunxi-with-spl.bin of=${LOOPDEV} bs=1024 seek=8 >/dev/null 2>&1
  152. elif [ "$PLATFORM" = "odroid-u2" ]; then
  153. dd if=${ROOTFSDIR}/boot/E4412_S.bl1.HardKernel.bin of=${LOOPDEV} seek=1 >/dev/null 2>&1
  154. dd if=${ROOTFSDIR}/boot/bl2.signed.bin of=${LOOPDEV} seek=31 >/dev/null 2>&1
  155. dd if=${ROOTFSDIR}/boot/u-boot.bin of=${LOOPDEV} seek=63 >/dev/null 2>&1
  156. dd if=${ROOTFSDIR}/boot/E4412_S.tzsw.signed.bin of=${LOOPDEV} seek=2111 >/dev/null 2>&1
  157. fi
  158. mountpoint -q ${ROOTFSDIR}/boot && umount ${ROOTFSDIR}/boot
  159. umount $ROOTFSDIR
  160. losetup -d $LOOPDEV
  161. rmdir $ROOTFSDIR
  162. chmod 644 $FILENAME
  163. info_msg "Successfully created $FILENAME image."
  164. # vim: set ts=4 sw=4 et: