summarylogtreecommitdiffstats
path: root/mactel-boot-setup
diff options
context:
space:
mode:
Diffstat (limited to 'mactel-boot-setup')
-rw-r--r--mactel-boot-setup66
1 files changed, 66 insertions, 0 deletions
diff --git a/mactel-boot-setup b/mactel-boot-setup
new file mode 100644
index 000000000000..7e0bca327c7b
--- /dev/null
+++ b/mactel-boot-setup
@@ -0,0 +1,66 @@
+#!/usr/bin/env bash
+
+## Based on http://pkgs.fedoraproject.org/gitweb/?p=mactel-boot.git;a=blob_plain;f=mactel-boot-setup;hb=f17
+
+## Execute as root
+
+_HFS_PLUS_PART_MP="${1}"
+_LOADER_PATH="${2}"
+_LOADER_CONFIG="${3}"
+
+if [[ -z "${1}" ]] || [[ -z "${2}" ]]; then
+ echo
+ echo "Usage: mactel-boot-setup <HFS_PLUS_PARTITION_MOUNTPOINT> <LOADER_PATH> <LOADER_CONFIG>"
+ echo
+ echo "Example: mactel-boot-setup /boot/mactel /EFI/refind/refindx64.efi /EFI/refind/refind.conf"
+ echo
+ exit 0
+fi
+
+### check for root
+if [[ ! ${UID} -eq 0 ]]; then
+ echo "ERROR: Please run as root user!"
+ exit 1
+fi
+
+if [[ "$(df -T "${_HFS_PLUS_PART_MP}" | tail -n +2 | awk '{print $2}')" == "hfsplus" ]]; then
+ if [[ -f "${_HFS_PLUS_PART_MP}/${_LOADER_PATH}" ]]; then
+ [[ ! -f "${_HFS_PLUS_PART_MP}/mach_kernel" ]] && echo "This file is required for booting" > "${_HFS_PLUS_PART_MP}/mach_kernel"
+
+ mkdir -p "${_HFS_PLUS_PART_MP}/System/Library/CoreServices"
+ cp -f "/usr/share/mactel-boot/SystemVersion.plist" "${_HFS_PLUS_PART_MP}/System/Library/CoreServices/SystemVersion.plist"
+
+ [[ -z ${_LOADER_CONFIG} ]] && _LOADER_CONFIG="$(echo "${_LOADER_PATH}" | sed 's|efi|cfg|g')"
+
+ ln -f "${_HFS_PLUS_PART_MP}/${_LOADER_PATH}" "${_HFS_PLUS_PART_MP}/System/Library/CoreServices/boot.efi"
+ [[ -f "${_HFS_PLUS_PART_MP}/${_LOADER_CONFIG}" ]] && ln -sf "${_HFS_PLUS_PART_MP}/${_LOADER_CONFIG}" "${_HFS_PLUS_PART_MP}/System/Library/CoreServices/$(basename "${_HFS_PLUS_PART_MP}/${_LOADER_CONFIG}")"
+
+ if [[ -f "/usr/share/mactel-boot/arch.vol" ]]; then
+ cp -f "/usr/share/mactel-boot/arch.vol" "$(dirname "${_HFS_PLUS_PART_MP}/${_LOADER_PATH}")/.disk_label"
+ cp -f "/usr/share/mactel-boot/arch.vol" "${_HFS_PLUS_PART_MP}/System/Library/CoreServices/.disk_label"
+ else
+ touch "$(dirname "${_HFS_PLUS_PART_MP}/${_LOADER_PATH}")/.disk_label"
+ touch "${_HFS_PLUS_PART_MP}/System/Library/CoreServices/.disk_label"
+ fi
+
+ if [[ -f "/boot/efi/EFI/arch/refind/icons/os_arch.icns" ]]; then
+ cp "/boot/efi/EFI/arch/refind/icons/os_arch.icns" "${_HFS_PLUS_PART_MP}/.VolumeIcon.icns"
+ else
+ touch "${_HFS_PLUS_PART_MP}/.VolumeIcon.icns"
+ fi
+
+ hfs-bless "${_HFS_PLUS_PART_MP}/${_LOADER_PATH}"
+ echo
+ else
+ echo "${_HFS_PLUS_PART_MP}/${_LOADER_PATH} not found."
+ fi
+else
+ echo
+ echo "${_HFS_PLUS_PART_MP} is not an HFS-PLUS Partition Mountpoint"
+ echo
+ exit 2
+fi
+
+unset _HFS_PLUS_PART_MP
+unset _LOADER_PATH
+unset _LOADER_CONFIG