mkimage.sh.in 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. #!/bin/sh
  2. #-
  3. # Copyright (c) 2013 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$@\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="$2"
  90. if [ -z "$IMGSIZE" ]; then
  91. IMGSIZE="2G"
  92. else
  93. IMGSIZE="${2}G"
  94. fi
  95. : ${BOOT_FSTYPE:=vfat}
  96. : ${BOOT_FSSIZE:=64M}
  97. : ${ROOT_FSTYPE:=ext4}
  98. if [ -z "$FILENAME" ]; then
  99. FILENAME="void-${PLATFORM}-$(date +%Y%m%d).img"
  100. fi
  101. # double check PLATFORM is supported...
  102. case "$PLATFORM" in
  103. cubieboard2|odroid-u2|rpi);;
  104. *) die "The $PLATFORM is not supported, exiting..."
  105. esac
  106. for f in parted partx losetup mount mkfs.${BOOT_FSTYPE} mkfs.${ROOT_FSTYPE}; do
  107. if ! which ${f} >/dev/null; then
  108. die "Cannot find ${f}, exiting."
  109. fi
  110. done
  111. # dd conv=sparse support first appeared in coreutils-8.16, disable it in
  112. # older versions.
  113. DD_VERSION=$(dd --version|head -n1|awk '{print $3}')
  114. case "$DD_VERSION" in
  115. [8-9].1[6-9]*|[8-9].[2-9]*) DD_SPARSE="conv=sparse";;
  116. esac
  117. info_msg "Creating disk image ($IMGSIZE) ..."
  118. dd if=/dev/zero of=$FILENAME bs=$IMGSIZE count=1 ${DD_SPARSE} >/dev/null 2>&1
  119. info_msg "Creating disk image partitions/filesystems ..."
  120. parted $FILENAME mktable msdos
  121. if [ "$BOOT_FSTYPE" = "vfat" ]; then
  122. _btype="fat32"
  123. _args="-I"
  124. fi
  125. parted $FILENAME mkpart primary ${_btype} 4096s ${BOOT_FSSIZE}
  126. parted $FILENAME mkpart primary ext2 ${BOOT_FSSIZE} 100%
  127. parted $FILENAME toggle 1 boot
  128. LOOPDEV=$(losetup --show --find $FILENAME)
  129. partx -a $LOOPDEV
  130. mkfs.${BOOT_FSTYPE} $_args ${LOOPDEV}p1 >/dev/null
  131. mkfs.${ROOT_FSTYPE} ${LOOPDEV}p2 >/dev/null 2>&1
  132. info_msg "Unpacking rootfs tarball ..."
  133. ROOTFSDIR=$(mktemp -d)
  134. mount ${LOOPDEV}p2 $ROOTFSDIR
  135. mkdir -p ${ROOTFSDIR}/boot
  136. mount ${LOOPDEV}p1 ${ROOTFSDIR}/boot
  137. tar xfp $ROOTFS_TARBALL -C $ROOTFSDIR
  138. BOOT_UUID=$(blkid -o value -s UUID ${LOOPDEV}p1)
  139. ROOT_UUID=$(blkid -o value -s UUID ${LOOPDEV}p2)
  140. echo "UUID=$BOOT_UUID /boot $BOOT_FSTYPE defaults 0 0" >> ${ROOTFSDIR}/etc/fstab
  141. echo "UUID=$ROOT_UUID / $ROOT_FSTYPE defaults 0 1" >> ${ROOTFSDIR}/etc/fstab
  142. if [ -s ${ROOTFSDIR}/boot/cmdline.txt ]; then
  143. sed -e "s,rootfstype=ext4,rootfstype=${ROOT_FSTYPE}," -i ${ROOTFSDIR}/boot/cmdline.txt
  144. fi
  145. # For cubieboard we need to flash u-boot to the image.
  146. if [ "$PLATFORM" = "cubieboard2" ]; then
  147. dd if=${ROOTFSDIR}/boot/u-boot-sunxi-with-spl.bin of=${LOOPDEV} bs=1024 seek=8 >/dev/null 2>&1
  148. elif [ "$PLATFORM" = "odroid-u2" ]; then
  149. dd if=${ROOTFSDIR}/boot/E4412_S.bl1.HardKernel.bin of=${LOOPDEV} seek=1 >/dev/null 2>&1
  150. dd if=${ROOTFSDIR}/boot/bl2.signed.bin of=${LOOPDEV} seek=31 >/dev/null 2>&1
  151. dd if=${ROOTFSDIR}/boot/u-boot.bin of=${LOOPDEV} seek=63 >/dev/null 2>&1
  152. dd if=${ROOTFSDIR}/boot/E4412_S.tzsw.signed.bin of=${LOOPDEV} seek=2111 >/dev/null 2>&1
  153. fi
  154. umount ${ROOTFSDIR}/boot
  155. umount $ROOTFSDIR
  156. partx -d $LOOPDEV
  157. losetup -d $LOOPDEV
  158. rmdir $ROOTFSDIR
  159. chmod 644 $FILENAME
  160. info_msg "Successfully created $FILENAME ($PLATFORM) image."
  161. # vim: set ts=4 sw=4 et: