fix for dietpi (final)
This commit is contained in:
parent
d17cdade6d
commit
058cfc339b
59
pishrink.sh
59
pishrink.sh
|
@ -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"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue