summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIru Cai <mytbk920423@gmail.com>2018-12-22 20:51:04 +0800
committerIru Cai <mytbk920423@gmail.com>2018-12-22 20:51:04 +0800
commitd44f8aa5b0241150be607de76b5c612cf61ac767 (patch)
tree123f2283b7fdfa34c63b74f1fc4275f8bc35694f
parent351e53aec275e71b9a4ae5db4b0986d60b482b6d (diff)
downloadliveusb-builder-d44f8aa5b0241150be607de76b5c612cf61ac767.tar.xz
check syslinux paths
-rwxr-xr-xinstall_syslinux44
1 files changed, 36 insertions, 8 deletions
diff --git a/install_syslinux b/install_syslinux
index 0f110a4..78211f4 100755
--- a/install_syslinux
+++ b/install_syslinux
@@ -5,17 +5,45 @@
# Example: ./install_syslinux /dev/sdb /dev/sdb1 /media/boot
set -e
-SYSLINUX_BIOS=/usr/lib/syslinux/bios
+mbr_bin_path=(/usr/lib/syslinux/bios /usr/share/syslinux /usr/lib/syslinux/mbr)
+c32_path=(/usr/lib/syslinux/bios /usr/share/syslinux /usr/lib/syslinux/modules/bios)
+
+MBR_PATH=""
+C32_PATH=""
+
+for path in "${mbr_bin_path[@]}"
+do
+ if test -f "$path/mbr.bin"
+ then
+ MBR_PATH="$path"
+ break
+ fi
+done
+
+if test -z "$MBR_PATH"
+then
+ exit 1
+fi
+
+for path in "${c32_path[@]}"
+do
+ if test -f "$path/linux.c32"
+ then
+ C32_PATH="$path"
+ break
+ fi
+done
+
+if test -z "$C32_PATH"
+then
+ exit 1
+fi
+
DEVNAME="$1"
BOOTPART="$2"
BOOTPATH="$3"
-if [ ! -d "$SYSLINUX_BIOS" ]; then
- SYSLINUX_BIOS=/usr/share/syslinux
-fi
-
-test -d "$SYSLINUX_BIOS"
syslinux -i "$BOOTPART"
-dd bs=440 count=1 conv=notrunc if="$SYSLINUX_BIOS/mbr.bin" of="$DEVNAME"
+dd bs=440 count=1 conv=notrunc if="$MBR_PATH/mbr.bin" of="$DEVNAME"
install -d "$BOOTPATH/syslinux"
-cp "$SYSLINUX_BIOS"/*.c32 "$BOOTPATH/syslinux"
+cp "$C32_PATH"/*.c32 "$BOOTPATH/syslinux"