summaryrefslogtreecommitdiffstats
path: root/liveinit
diff options
context:
space:
mode:
author Eric Hameleers <alien@slackware.com>2016-05-05 22:32:42 +0200
committer Eric Hameleers <alien@slackware.com>2016-05-05 22:32:42 +0200
commitc5686627b00f9342f3298c911b6443afa3046853 (patch)
treee043431106e9d0de08958a06c619ab86eb8650a9 /liveinit
parentdd4de2a39717931f491787bd7a4d884e20ce7938 (diff)
downloadliveslak-c5686627b00f9342f3298c911b6443afa3046853.tar.gz
liveslak-c5686627b00f9342f3298c911b6443afa3046853.tar.xz
liveinit: allow PXE server to work even when the Live media is copied to RAM.
Diffstat (limited to '')
-rwxr-xr-xliveinit20
1 files changed, 14 insertions, 6 deletions
diff --git a/liveinit b/liveinit
index 0ee0b85..e718742 100755
--- a/liveinit
+++ b/liveinit
@@ -444,14 +444,17 @@ if [ "$RESCUE" = "" ]; then
find_modloc() {
MY_LOC="$1"
+ MY_BASE="$2"
if [ $TORAM -ne 0 ]; then
# If we need to copy the module to RAM, we need a place for that:
mkdir -p /mnt/live/toram
- # Copy the module to RAM before mounting it:
+ # Copy the module to RAM before mounting it, preserving relative path:
MODNAME="$(basename ${MY_LOC})"
- cp ${MY_LOC} /mnt/live/toram
- MY_LOC=/mnt/live/toram/${MODNAME}
+ MODRELPATH="$(dirname ${MY_LOC} |sed "s,$MY_BASE,,")"
+ mkdir -p /mnt/live/toram/${MODRELPATH}
+ cp "${MY_LOC}" "/mnt/live/toram/${MODRELPATH}"
+ MY_LOC="/mnt/live/toram/${MODRELPATH}/${MODNAME}"
fi
echo "${MY_LOC}"
@@ -478,7 +481,7 @@ if [ "$RESCUE" = "" ]; then
continue
fi
fi
- MODLOC=$(find_modloc ${MODULE})
+ MODLOC=$(find_modloc ${MODULE} /mnt/media)
mkdir /mnt/live/modules/${MODBASE}
mount -t squashfs -o loop ${MODLOC} /mnt/live/modules/${MODBASE}
RODIRS=":/mnt/live/modules/${MODBASE}${RODIRS}"
@@ -737,10 +740,15 @@ if [ "$RESCUE" = "" ]; then
mkdir -p /mnt/overlay/mnt/${LIVEMAIN}fs
mount --bind /mnt/${LIVEMAIN}fs /mnt/overlay/mnt/${LIVEMAIN}fs
+ # Same for the Linux filesystem on the USB stick:
+ mkdir -p /mnt/overlay/mnt/livemedia
if [ $TORAM -eq 0 ]; then
- # Same for the Linux filesystem on the USB stick:
- mkdir -p /mnt/overlay/mnt/livemedia
mount --bind /mnt/media /mnt/overlay/mnt/livemedia
+ else
+ # For PXE server we need to provide kernel and initrd too,
+ # not just the modules:
+ cp -af /mnt/media/boot /mnt/live/toram/
+ mount --bind /mnt/live/toram /mnt/overlay/mnt/livemedia
fi
if [ ! -z "$USE_SWAP" ]; then