fix for dietpi (final)

This commit is contained in:
Clemens Arth 2020-09-18 21:31:21 +02:00
parent d17cdade6d
commit 058cfc339b
1 changed files with 33 additions and 26 deletions

View File

@ -79,7 +79,7 @@ function set_autoexpand() {
fi fi
if ([[ -f "$mountdir/etc/rc.local" ]] && [[ "$(md5sum "$mountdir/etc/rc.local" | cut -d ' ' -f 1)" != "1c579c7d5b4292fd948399b6ece39009" ]]); then if ([[ -f "$mountdir/etc/rc.local" ]] && [[ "$(md5sum "$mountdir/etc/rc.local" | cut -d ' ' -f 1)" != "1c579c7d5b4292fd948399b6ece39009" ]]); then
echo "Creating new /etc/rc.local" info "Creating new /etc/rc.local"
isok=1 isok=1
rclocal=1 rclocal=1
boothook=/etc/rc.local boothook=/etc/rc.local
@ -87,7 +87,7 @@ function set_autoexpand() {
mv "$mountdir/etc/rc.local" "$mountdir/etc/rc.local.bak" mv "$mountdir/etc/rc.local" "$mountdir/etc/rc.local.bak"
fi fi
elif [[ -d "$mountdir/var/lib/dietpi/postboot.d" ]]; then elif [[ -d "$mountdir/var/lib/dietpi/postboot.d" ]]; then
echo "Using postboot hooks..." info "Using postboot hooks..."
isok=1 isok=1
rclocal=0 rclocal=0
boothook=/var/lib/dietpi/postboot.d/inflatefs.sh boothook=/var/lib/dietpi/postboot.d/inflatefs.sh
@ -95,25 +95,25 @@ function set_autoexpand() {
if [ "$isok" -eq "1" ]; then if [ "$isok" -eq "1" ]; then
#####Do not touch the following lines##### #####Do not touch the following lines#####
cat <<\EOF1 > "$mountdir$boothook" cat <<\EOF1 > "$mountdir$boothook"
#!/bin/bash #!/bin/bash
do_expand_rootfs() { do_expand_rootfs() {
ROOT_PART=$(mount | sed -n 's|^/dev/\(.*\) on / .*|\1|p') ROOT_PART=$(mount | sed -n 's|^/dev/\(.*\) on / .*|\1|p')
DEV_PART=$(echo "$ROOT_PART" | cut -f1 -d"p") DEV_PART=$(echo "$ROOT_PART" | cut -f1 -d"p")
PART_NUM=${ROOT_PART#"${DEV_PART}p"} PART_NUM=${ROOT_PART#"${DEV_PART}p"}
if [ "$PART_NUM" = "$ROOT_PART" ]; then if [ "$PART_NUM" = "$ROOT_PART" ]; then
echo "$ROOT_PART is not an SD card. Don't know how to expand" echo "$ROOT_PART is not an SD card. Don't know how to expand"
return 0 return 0
fi fi
# Get the starting offset of the root partition # Get the starting offset of the root partition
PART_START=$(parted /dev/${DEV_PART} -ms unit s p | grep "^${PART_NUM}" | cut -f 2 -d: | sed 's/[^0-9]//g') PART_START=$(parted /dev/${DEV_PART} -ms unit s p | grep "^${PART_NUM}" | cut -f 2 -d: | sed 's/[^0-9]//g')
[ "$PART_START" ] || return 1 [ "$PART_START" ] || return 1
# Return value will likely be error for fdisk as it fails to reload the # Return value will likely be error for fdisk as it fails to reload the
# partition table because the root fs is mounted # partition table because the root fs is mounted
fdisk /dev/${DEV_PART} <<EOF fdisk /dev/${DEV_PART} <<EOF
p p
d d
$PART_NUM $PART_NUM
@ -126,16 +126,20 @@ p
w w
EOF EOF
cat <<EOF > $boothook && cat <<EOF > BOOTHOOKFILE &&
#!/bin/sh #!/bin/sh
echo "Expanding /dev/$ROOT_PART" echo "Expanding /dev/$ROOT_PART"
resize2fs /dev/$ROOT_PART resize2fs /dev/$ROOT_PART
rm -f $boothook
EOF EOF
if [ "RCLOCAL" -eq "1" ]; then
echo "rm -f /etc/rc.local; cp -f /etc/rc.local.bak /etc/rc.local; /etc/rc.local" >> BOOTHOOKFILE
else
echo "rm -f BOOTHOOKFILE" >> BOOTHOOKFILE
fi
reboot reboot
exit exit
} }
raspi_config_expand() { raspi_config_expand() {
/usr/bin/env raspi-config --expand-rootfs /usr/bin/env raspi-config --expand-rootfs
if [[ $? != 0 ]]; then if [[ $? != 0 ]]; then
@ -146,21 +150,25 @@ else
exit exit
fi fi
} }
raspi_config_expand raspi_config_expand
echo "WARNING: Using backup expand..." echo "WARNING: Using backup expand..."
sleep 5 sleep 5
do_expand_rootfs do_expand_rootfs
echo "ERROR: Expanding failed..." echo "ERROR: Expanding failed..."
sleep 5 sleep 5
if [ "$rclocal" -eq "1" ]; then if [ "RCLOCAL" -eq "1" ]; then
if [[ -f /etc/rc.local.bak ]]; then if [[ -f /etc/rc.local.bak ]]; then
cp -f /etc/rc.local.bak /etc/rc.local cp -f /etc/rc.local.bak /etc/rc.local
/etc/rc.local /etc/rc.local
fi fi
fi fi
exit 0 exit 0
EOF1 EOF1
#####End no touch zone#####
sed -i "s#BOOTHOOKFILE#$boothook#g; s#RCLOCAL#$rclocal#g" $mountdir$boothook
cat $mountdir$boothook | grep RCLOCAL
#####End no touch zone#####
chmod +x "$mountdir$boothook" chmod +x "$mountdir$boothook"
fi fi
umount "$mountdir" umount "$mountdir"
@ -435,4 +443,3 @@ aftersize=$(ls -lh "$img" | cut -d ' ' -f 5)
logVariables $LINENO aftersize logVariables $LINENO aftersize
info "Shrunk $img from $beforesize to $aftersize" info "Shrunk $img from $beforesize to $aftersize"