|
@@ -7,48 +7,17 @@ if [ $(id -u) -ne 0 ];then
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
|
|
-printf "Checking if sfdisk is installed"
|
|
+f=0
|
|
-sfdisk=$(which sfdisk)
|
|
+for tool in parted sfdisk mkfs.ext4 tune2fs;do
|
|
-
|
|
+ if ! which $tool >/dev/null; then
|
|
-if [ ! -z $sfdisk -a -x $sfdisk ];then
|
|
+ echo "Checking if $tool is installed... failed"
|
|
- printf "...okay\n"
|
|
+ f=1
|
|
-else
|
|
+ fi
|
|
- printf "...failed\n"
|
|
+done
|
|
- exit 1
|
|
+if [ $f -eq 1 ];then exit 1;fi
|
|
-fi
|
|
|
|
-
|
|
|
|
-printf "Checking if parted is installed"
|
|
|
|
-parted=$(which parted)
|
|
|
|
-
|
|
|
|
-if [ ! -z $parted -a -x $parted ];then
|
|
|
|
- printf "...okay\n"
|
|
|
|
-else
|
|
|
|
- printf "...failed\n"
|
|
|
|
- exit 1
|
|
|
|
-fi
|
|
|
|
-
|
|
|
|
-printf "Checking if mke2fs is installed"
|
|
|
|
-mke2fs=$(which mke2fs)
|
|
|
|
-
|
|
|
|
-if [ ! -z $mke2fs -a -x $mke2fs ];then
|
|
|
|
- printf "...okay\n"
|
|
|
|
-else
|
|
|
|
- printf "...failed\n"
|
|
|
|
- exit 1
|
|
|
|
-fi
|
|
|
|
-
|
|
|
|
-printf "Checking if tune2fs is installed"
|
|
|
|
-tune2fs=$(which tune2fs)
|
|
|
|
-
|
|
|
|
-if [ ! -z $tune2fs -a -x $tune2fs ];then
|
|
|
|
- printf "...okay\n"
|
|
|
|
-else
|
|
|
|
- printf "...failed\n"
|
|
|
|
- exit 1
|
|
|
|
-fi
|
|
|
|
|
|
|
|
if [ -z $1 ];then
|
|
if [ -z $1 ];then
|
|
- printf "Please give your compact flash or USB device as first parameter\n"
|
|
+ printf "Please give your compact flash device as first parameter\n"
|
|
exit 1
|
|
exit 1
|
|
else
|
|
else
|
|
if [ -z $2 ];then
|
|
if [ -z $2 ];then
|
|
@@ -72,13 +41,13 @@ else
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
if [ -b $1 ];then
|
|
if [ -b $1 ];then
|
|
- printf "Using $1 as CF/USB disk for installation\n"
|
|
+ printf "Using $1 as CF disk for installation\n"
|
|
- printf "This will destroy all data on $1, are you sure?\n"
|
|
+ echo "WARNING: This will destroy all data on $1 - type Yes to continue!"
|
|
- printf "Type "y" to continue\n"
|
|
|
|
read y
|
|
read y
|
|
- if [ "$y" = "y" ];then
|
|
+ if [ "$y" = "Yes" ];then
|
|
- $sfdisk -l $1 2>&1 |grep 'No medium'
|
|
+ env LC_ALL=C sfdisk -l $1 2>&1 |grep 'No medium'
|
|
if [ $? -eq 0 ];then
|
|
if [ $? -eq 0 ];then
|
|
|
|
+ echo "No medium found"
|
|
exit 1
|
|
exit 1
|
|
else
|
|
else
|
|
printf "Starting with installation\n"
|
|
printf "Starting with installation\n"
|
|
@@ -99,40 +68,31 @@ if [ $(mount | grep $1| wc -l) -ne 0 ];then
|
|
exit 1
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
|
|
-
|
|
|
|
-if [ $($sfdisk -l $1 2>/dev/null|grep Empty|wc -l) -ne 4 ];then
|
|
|
|
- printf "Partitions already exist, should I wipe them?\n"
|
|
|
|
- printf "Type y to continue\n"
|
|
|
|
- read y
|
|
|
|
- if [ $y = "y" ];then
|
|
|
|
- printf "Wiping existing partitions\n"
|
|
|
|
- dd if=/dev/zero of=$1 bs=512 count=1 >/dev/null 2>&1
|
|
|
|
- else
|
|
|
|
- printf "Exiting.\n"
|
|
|
|
- exit 1
|
|
|
|
- fi
|
|
|
|
-fi
|
|
|
|
-
|
|
|
|
printf "Create partition and filesystem for rb532\n"
|
|
printf "Create partition and filesystem for rb532\n"
|
|
rootpart=${1}2
|
|
rootpart=${1}2
|
|
-$parted -s $1 mklabel msdos
|
|
+parted -s $1 mklabel msdos >/dev/null 2>&1
|
|
sleep 2
|
|
sleep 2
|
|
-maxsize=$(env LC_ALL=C $parted $1 -s unit cyl print |awk '/^Disk/ { print $3 }'|sed -e 's/cyl//')
|
|
+maxsize=$(env LC_ALL=C parted $1 -s unit cyl print |awk '/^Disk/ { print $3 }'|sed -e 's/cyl//')
|
|
rootsize=$(($maxsize-2))
|
|
rootsize=$(($maxsize-2))
|
|
|
|
|
|
-$parted -s $1 unit cyl mkpart primary ext2 0 2
|
|
+parted -s $1 unit cyl mkpart primary ext2 0 2 >/dev/null 2>&1
|
|
-$parted -s $1 unit cyl mkpart primary ext2 2 $rootsize
|
|
+parted -s $1 unit cyl mkpart primary ext2 2 $rootsize >/dev/null 2>&1
|
|
-$parted -s $1 unit cyl mkpart primary fat32 $rootsize $maxsize
|
|
+parted -s $1 unit cyl mkpart primary fat32 $rootsize $maxsize >/dev/null 2>&1
|
|
-$parted -s $1 set 1 boot on
|
|
+parted -s $1 set 1 boot on >/dev/null 2>&1
|
|
-$sfdisk --change-id $1 1 27
|
|
+sfdisk --change-id $1 1 27 >/dev/null 2>&1
|
|
-$sfdisk --change-id $1 3 88
|
|
+sfdisk --change-id $1 3 88 >/dev/null 2>&1
|
|
sleep 2
|
|
sleep 2
|
|
-$mke2fs ${1}2
|
|
+mkfs.ext4 -q -O ^huge_file ${1}2
|
|
sync
|
|
sync
|
|
-dd if=$3 of=${1}1 bs=2048
|
|
+dd if=$3 of=${1}1 bs=2048 >/dev/null 2>&1
|
|
|
|
+if [ $? -eq 0 ];then
|
|
|
|
+ printf "Installation of kernel successful.\n"
|
|
|
|
+else
|
|
|
|
+ printf "Installation of kernel failed.\n"
|
|
|
|
+fi
|
|
sync
|
|
sync
|
|
sleep 2
|
|
sleep 2
|
|
-$tune2fs -c 0 -i 0 -m 1 ${rootpart} >/dev/null
|
|
+tune2fs -c 0 -i 0 -m 1 ${rootpart} >/dev/null 2>&1
|
|
if [ $? -eq 0 ];then
|
|
if [ $? -eq 0 ];then
|
|
printf "Successfully disabled filesystem checks on ${rootpart}\n"
|
|
printf "Successfully disabled filesystem checks on ${rootpart}\n"
|
|
else
|
|
else
|
|
@@ -141,7 +101,7 @@ else
|
|
fi
|
|
fi
|
|
|
|
|
|
tmp=$(mktemp -d)
|
|
tmp=$(mktemp -d)
|
|
-mount -t ext2 ${rootpart} $tmp
|
|
+mount -t ext4 ${rootpart} $tmp
|
|
printf "Extracting install archive\n"
|
|
printf "Extracting install archive\n"
|
|
tar -C $tmp -xzpf $2
|
|
tar -C $tmp -xzpf $2
|
|
printf "Fixing permissions\n"
|
|
printf "Fixing permissions\n"
|