about summary refs log tree commit diff
path: root/mkrootfs.sh.in
diff options
context:
space:
mode:
authorJuan RP <xtraeme@gmail.com>2014-01-21 23:13:26 +0100
committerJuan RP <xtraeme@gmail.com>2014-01-21 23:13:26 +0100
commit0756604fb0a26c7e17b22f4311e980d7fd16ae0e (patch)
tree49beef57f378dc3f8a8a0da0fd40ab2fb4a73c0c /mkrootfs.sh.in
parentbe13cabb849d179a2932ce7798a88f1174874a3f (diff)
downloadhrmpf-0756604fb0a26c7e17b22f4311e980d7fd16ae0e.tar.gz
hrmpf-0756604fb0a26c7e17b22f4311e980d7fd16ae0e.tar.xz
hrmpf-0756604fb0a26c7e17b22f4311e980d7fd16ae0e.zip
mkrootfs: added new flags: -k <xbps-keys-dir> and -m <platform> (rpi|odroid*).
Diffstat (limited to 'mkrootfs.sh.in')
-rw-r--r--mkrootfs.sh.in30
1 files changed, 21 insertions, 9 deletions
diff --git a/mkrootfs.sh.in b/mkrootfs.sh.in
index d199938..1cdf33e 100644
--- a/mkrootfs.sh.in
+++ b/mkrootfs.sh.in
@@ -1,6 +1,6 @@
 #!/bin/sh
 #-
-# Copyright (c) 2013 Juan Romero Pardines.
+# Copyright (c) 2013-2014 Juan Romero Pardines.
 # All rights reserved.
 #
 # Redistribution and use in source and binary forms, with or without
@@ -27,6 +27,7 @@
 readonly PROGNAME=$(basename $0)
 readonly ARCH=$(uname -m)
 readonly PKGBASE="base-system"
+readonly VOIDRSAPUBKEY="60:ae:0c:d6:f0:95:17:80:bc:93:46:7a:89:af:a3:2d"
 
 trap 'die "Interrupted! exiting..."' INT TERM HUP
 
@@ -42,7 +43,7 @@ die() {
 }
 
 usage() {
-    echo "Usage: $PROGNAME [-a rpi] [-p 'pkg1 pkg2'] [-V]"
+    echo "Usage: $PROGNAME [-k xbps-keys-dir] [-m rpi|odroid-u2] [-p 'pkg1 pkg2'] [-V]"
 }
 
 mount_pseudofs() {
@@ -75,7 +76,7 @@ register_binfmt() {
         return 0
     fi
     case "${_ARCH}" in
-        armv6l)
+        armv?l)
             echo ':arm:M::\x7fELF\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x28\x00:\xff\xff\xff\xff\xff\xff\xff\x00\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff\xff:/usr/bin/qemu-arm-static:' > /proc/sys/fs/binfmt_misc/register
             cp -f $(which qemu-arm-static) $rootfs/usr/bin || die "failed to copy qemu-arm-static to the rootfs"
             ;;
@@ -88,9 +89,10 @@ register_binfmt() {
 #
 # main()
 #
-while getopts "a:hp:V" opt; do
+while getopts "k:m:hp:V" opt; do
     case $opt in
-        a) TARGET_ARCH="$OPTARG";;
+        k) KEYSDIR="$OPTARG";;
+        m) TARGET_ARCH="$OPTARG";;
         p) EXTRA_PKGS="$OPTARG";;
         h) usage; exit 0;;
         V) echo "$PROGNAME @@MKLIVE_VERSION@@"; exit 0;;
@@ -115,16 +117,26 @@ done
 # Sanitize target arch.
 #
 case "$TARGET_ARCH" in
-    rpi) _ARCH=armv6l; QEMU_BIN=qemu-arm-static;;
+    rpi) _ARCH="armv6l"; QEMU_BIN=qemu-arm-static;;
+    odroid*) _ARCH="armv7l"; QEMU_BIN=qemu-arm-static;;
     *) ;;
 esac
 
+if [ -z "$KEYSDIR" ]; then
+    KEYSDIR="/var/db/xbps/keys" # use void default
+fi
 #
 # Check if package base-system is available.
 #
+rootfs=$(mktemp -d || die "FATAL: failed to create tempdir, exiting...")
+if [ ! -f "$KEYSDIR/${VOIDRSAPUBKEY}.plist" ]; then
+    die "cannot find xbps keyst to install binary packages, exiting."
+fi
+mkdir -p $rootfs/var/db/xbps/keys
+cp $KEYSDIR/${VOIDRSAPUBKEY}.plist $rootfs/var/db/xbps/keys
+
 run_cmd "xbps-query -R -ppkgver $PKGBASE"
 
-rootfs=$(mktemp -d || die "FATAL: failed to create tempdir, exiting...")
 chmod 755 $rootfs
 
 PKGS="${PKGBASE}"
@@ -144,8 +156,8 @@ sed -e "s/\#\(${LOCALE}.*\)/\1/g" -i $rootfs/etc/default/libc-locales
 # Reconfigure packages for target architecture: must be reconfigured
 # thru the qemu user mode binary.
 #
-if [ -n "$TARGET_ARCH" ]; then
-    info_msg "Reconfiguring packages for $TARGET_ARCH ..."
+if [ -n "${_ARCH}" ]; then
+    info_msg "Reconfiguring packages for ${_ARCH} ..."
     register_binfmt
     run_cmd "xbps-reconfigure -r $rootfs base-directories"
     run_cmd "chroot $rootfs xbps-reconfigure shadow"