mirror of https://github.com/kholia/OSX-KVM.git
updated ubuntun, found bug
This commit is contained in:
parent
cbf0fd015e
commit
f193460e0c
|
@ -1,6 +1,14 @@
|
||||||
#!/usr/bin/bash
|
#!/usr/bin/bash
|
||||||
# macOS KVM Installation Script for a brand-new Linux system
|
|
||||||
# Quick Install: curl -fsSL <URL> | bash
|
# macOS KVM Installation Script with wget/curl support
|
||||||
|
#
|
||||||
|
# Quick Install (one-liner):
|
||||||
|
# curl -fsSL https://raw.githubusercontent.com/yourusername/OSX-KVM/master/install-macos-kvm.sh | bash
|
||||||
|
#
|
||||||
|
# Usage: ./install-macos-kvm.sh [OPTIONS]
|
||||||
|
# Options:
|
||||||
|
# --use-curl Use curl instead of wget for downloads
|
||||||
|
# --help Show this help message
|
||||||
|
|
||||||
set -e # Exit on any error
|
set -e # Exit on any error
|
||||||
|
|
||||||
|
@ -10,24 +18,21 @@ INSTALL_DIR="$HOME/OSX-KVM"
|
||||||
|
|
||||||
# Function to display help
|
# Function to display help
|
||||||
show_help() {
|
show_help() {
|
||||||
cat <<EOF
|
echo "macOS KVM Installation Script"
|
||||||
macOS KVM Installation Script
|
echo ""
|
||||||
|
echo "Usage: $0 [OPTIONS]"
|
||||||
Usage: $0 [OPTIONS]
|
echo ""
|
||||||
|
echo "Options:"
|
||||||
Options:
|
echo " --use-curl Use curl instead of wget for downloads"
|
||||||
--use-curl Use curl instead of wget for downloads
|
echo " --help Show this help message"
|
||||||
--help Show this help message
|
echo ""
|
||||||
|
echo "This script will:"
|
||||||
This script will:
|
echo " 1. Clone the OSX-KVM repository"
|
||||||
1. Install all required packages
|
echo " 2. Download macOS recovery image"
|
||||||
2. Clone the OSX-KVM repository
|
echo " 3. Convert BaseSystem.dmg to raw format"
|
||||||
3. Download macOS recovery image
|
echo " 4. Create macOS disk image (100GB)"
|
||||||
4. Convert BaseSystem.dmg to raw format
|
echo " 5. Set proper permissions for libvirt"
|
||||||
5. Create macOS disk image (100GB)
|
echo " 6. Launch macOS VM"
|
||||||
6. Set proper permissions for libvirt
|
|
||||||
7. Launch macOS VM
|
|
||||||
EOF
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to check if command exists
|
# Function to check if command exists
|
||||||
|
@ -35,25 +40,21 @@ command_exists() {
|
||||||
command -v "$1" >/dev/null 2>&1
|
command -v "$1" >/dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to install packages via apt
|
# Function to download with fallback
|
||||||
install_package() {
|
|
||||||
local pkg="$1"
|
|
||||||
if ! dpkg -s "$pkg" >/dev/null 2>&1; then
|
|
||||||
echo "Installing missing package: $pkg"
|
|
||||||
sudo apt-get install -y "$pkg"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to download files
|
|
||||||
download_file() {
|
download_file() {
|
||||||
local url="$1"
|
local url="$1"
|
||||||
local output="$2"
|
local output="$2"
|
||||||
|
|
||||||
echo "Downloading: $url"
|
echo "Downloading: $url"
|
||||||
|
|
||||||
if [ "$USE_CURL" = true ] && command_exists curl; then
|
if [ "$USE_CURL" = true ] && command_exists curl; then
|
||||||
|
echo "Using curl for download..."
|
||||||
curl -L -o "$output" "$url"
|
curl -L -o "$output" "$url"
|
||||||
elif command_exists wget; then
|
elif command_exists wget; then
|
||||||
|
echo "Using wget for download..."
|
||||||
wget -O "$output" "$url"
|
wget -O "$output" "$url"
|
||||||
elif command_exists curl; then
|
elif command_exists curl; then
|
||||||
|
echo "wget not found, falling back to curl..."
|
||||||
curl -L -o "$output" "$url"
|
curl -L -o "$output" "$url"
|
||||||
else
|
else
|
||||||
echo "Error: Neither wget nor curl found. Please install one of them."
|
echo "Error: Neither wget nor curl found. Please install one of them."
|
||||||
|
@ -74,61 +75,64 @@ while [[ $# -gt 0 ]]; do
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Unknown option: $1"
|
echo "Unknown option: $1"
|
||||||
show_help
|
echo "Use --help for usage information"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "Updating package list..."
|
# Check for required commands
|
||||||
sudo apt-get update -y
|
echo "Checking system requirements..."
|
||||||
|
|
||||||
# Install required packages
|
if ! command_exists git; then
|
||||||
REQUIRED_PKGS=(git wget curl python3 python3-pip qemu-system qemu-utils \
|
echo "Error: git is required but not installed."
|
||||||
uml-utilities virt-manager libguestfs-tools p7zip-full make dmg2img \
|
exit 1
|
||||||
tesseract-ocr tesseract-ocr-eng genisoimage vim net-tools screen)
|
fi
|
||||||
|
|
||||||
for pkg in "${REQUIRED_PKGS[@]}"; do
|
if ! command_exists qemu-img; then
|
||||||
install_package "$pkg"
|
echo "Error: qemu-img is required but not installed."
|
||||||
done
|
echo "Please install qemu-utils or qemu-system package"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
echo "✓ All required packages installed"
|
# Check for download capability
|
||||||
|
if ! command_exists wget && ! command_exists curl; then
|
||||||
|
echo "Error: Neither wget nor curl found."
|
||||||
|
echo "Please install wget or curl to continue."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Check system commands
|
echo "✓ System requirements check passed"
|
||||||
for cmd in git qemu-img wget curl python3 make dmg2img; do
|
|
||||||
if ! command_exists "$cmd"; then
|
|
||||||
echo "Error: $cmd is required but not installed."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
echo "✓ System commands verified"
|
# Create installation directory if it doesn't exist
|
||||||
|
|
||||||
# Create installation directory
|
|
||||||
if [ -d "$INSTALL_DIR" ]; then
|
if [ -d "$INSTALL_DIR" ]; then
|
||||||
echo "Warning: $INSTALL_DIR exists. Backing up to ${INSTALL_DIR}.backup"
|
echo "Warning: $INSTALL_DIR already exists. Backing up to ${INSTALL_DIR}.backup"
|
||||||
mv "$INSTALL_DIR" "${INSTALL_DIR}.backup.$(date +%Y%m%d_%H%M%S)"
|
mv "$INSTALL_DIR" "${INSTALL_DIR}.backup.$(date +%Y%m%d_%H%M%S)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Clone repository
|
# Clone the repository
|
||||||
echo "Cloning OSX-KVM repository..."
|
echo "Cloning OSX-KVM repository..."
|
||||||
git clone https://github.com/kholia/OSX-KVM.git "$INSTALL_DIR"
|
git clone https://github.com/kholia/OSX-KVM.git "$INSTALL_DIR"
|
||||||
cd "$INSTALL_DIR"
|
cd "$INSTALL_DIR"
|
||||||
|
|
||||||
# Setup KVM
|
sudo apt-get install qemu-system uml-utilities virt-manager git \
|
||||||
sudo modprobe kvm
|
wget libguestfs-tools p7zip-full make dmg2img tesseract-ocr \
|
||||||
echo 1 | sudo tee /sys/module/kvm/parameters/ignore_msrs >/dev/null || true
|
tesseract-ocr-eng genisoimage vim net-tools screen -y
|
||||||
[ -f kvm_amd.conf ] && sudo cp kvm_amd.conf /etc/modprobe.d/kvm.conf
|
|
||||||
|
|
||||||
sudo usermod -aG kvm "$(whoami)"
|
sudo modprobe kvm; echo 1 | sudo tee /sys/module/kvm/parameters/ignore_msrs
|
||||||
sudo usermod -aG libvirt "$(whoami)"
|
sudo cp kvm_amd.conf /etc/modprobe.d/kvm.conf # for amd boxes only
|
||||||
sudo usermod -aG input "$(whoami)"
|
|
||||||
|
sudo usermod -aG kvm $(whoami)
|
||||||
|
sudo usermod -aG libvirt $(whoami)
|
||||||
|
sudo usermod -aG input $(whoami)
|
||||||
|
|
||||||
# Download macOS recovery image
|
# Download macOS recovery image
|
||||||
echo "Downloading macOS recovery image..."
|
echo "Downloading macOS recovery image..."
|
||||||
if [ -f "fetch-macOS-v2.py" ]; then
|
if [ -f "fetch-macOS-v2.py" ]; then
|
||||||
python3 fetch-macOS-v2.py
|
python3 fetch-macOS-v2.py
|
||||||
else
|
else
|
||||||
|
echo "Warning: fetch-macOS-v2.py not found, attempting manual download..."
|
||||||
|
# Fallback download URLs for macOS recovery images
|
||||||
RECOVERY_URL="https://updates.cdn-apple.com/2019FallFCS/fullrestores/061-44998/B5A3E286-1C4A-11EA-99D4-864D6786AB92/BaseSystem.dmg"
|
RECOVERY_URL="https://updates.cdn-apple.com/2019FallFCS/fullrestores/061-44998/B5A3E286-1C4A-11EA-99D4-864D6786AB92/BaseSystem.dmg"
|
||||||
download_file "$RECOVERY_URL" "BaseSystem.dmg"
|
download_file "$RECOVERY_URL" "BaseSystem.dmg"
|
||||||
fi
|
fi
|
||||||
|
@ -143,36 +147,78 @@ else
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Create macOS disk image
|
# Create macOS disk image (100GB)
|
||||||
echo "Creating macOS disk image (256GB)..."
|
echo "Creating macOS disk image (100GB)..."
|
||||||
qemu-img create -f qcow2 macOS.qcow2 256G
|
qemu-img create -f qcow2 macOS.qcow2 256G
|
||||||
ln -sf macOS.qcow2 mac_hdd_ng.img
|
echo "✓ macOS.qcow2 created successfully"
|
||||||
echo "✓ Disk image created"
|
|
||||||
|
|
||||||
# Set permissions for libvirt
|
# Create symlink for script compatibility
|
||||||
sudo chown libvirt-qemu:libvirt-qemu macOS.qcow2 2>/dev/null || true
|
echo "Creating compatibility symlink..."
|
||||||
sudo chmod 664 macOS.qcow2 2>/dev/null || true
|
ln -sf macOS.qcow2 mac_hdd_ng.img
|
||||||
sudo chmod 755 "$INSTALL_DIR" 2>/dev/null || true
|
|
||||||
|
# Fix permissions for libvirt
|
||||||
|
echo "Setting up permissions for libvirt..."
|
||||||
|
sudo chown libvirt-qemu:libvirt-qemu macOS.qcow2 2>/dev/null || {
|
||||||
|
echo "Warning: Could not change ownership to libvirt-qemu. You may need to run this manually:"
|
||||||
|
echo " sudo chown libvirt-qemu:libvirt-qemu $INSTALL_DIR/macOS.qcow2"
|
||||||
|
}
|
||||||
|
|
||||||
|
sudo chmod 664 macOS.qcow2 2>/dev/null || {
|
||||||
|
echo "Warning: Could not change permissions. You may need to run this manually:"
|
||||||
|
echo " sudo chmod 664 $INSTALL_DIR/macOS.qcow2"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Fix directory permissions
|
||||||
|
sudo chmod 755 "$INSTALL_DIR" 2>/dev/null || {
|
||||||
|
echo "Warning: Could not change directory permissions. You may need to run this manually:"
|
||||||
|
echo " sudo chmod 755 $INSTALL_DIR"
|
||||||
|
}
|
||||||
|
|
||||||
# Make scripts executable
|
# Make scripts executable
|
||||||
|
echo "Making scripts executable..."
|
||||||
chmod +x *.sh
|
chmod +x *.sh
|
||||||
|
|
||||||
# Build OpenCore if missing
|
# Check if OpenCore exists and build if necessary
|
||||||
if [ ! -f "OpenCore/OpenCore.qcow2" ]; then
|
if [ ! -f "OpenCore/OpenCore.qcow2" ]; then
|
||||||
echo "OpenCore not found, attempting to build..."
|
echo "OpenCore not found, attempting to build..."
|
||||||
cd OpenCore || exit
|
cd OpenCore
|
||||||
[ -f "Makefile" ] && make || echo "Warning: Could not build OpenCore"
|
if [ -f "Makefile" ]; then
|
||||||
|
make
|
||||||
|
else
|
||||||
|
echo "Warning: Could not build OpenCore. You may need to build it manually."
|
||||||
|
fi
|
||||||
cd ..
|
cd ..
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "🎉 Installation completed successfully!"
|
echo "🎉 Installation completed successfully!"
|
||||||
|
echo ""
|
||||||
echo "Next steps:"
|
echo "Next steps:"
|
||||||
echo "1. Start macOS VM: cd $INSTALL_DIR && sudo ./OpenCore-Boot.sh"
|
echo "1. To start the macOS VM using the script:"
|
||||||
echo "2. Use virt-manager: import XML, start VM"
|
echo " cd $INSTALL_DIR && sudo ./OpenCore-Boot.sh"
|
||||||
|
echo ""
|
||||||
|
echo "2. To use with virt-manager:"
|
||||||
|
echo " - Import the provided libvirt XML configuration"
|
||||||
|
echo " - Start the VM through virt-manager interface"
|
||||||
|
echo ""
|
||||||
|
echo "3. During installation:"
|
||||||
|
echo " - Select 'macOS Base System' from OpenCore"
|
||||||
|
echo " - Use Disk Utility to format the 256GB drive"
|
||||||
|
echo " - Install macOS to the formatted drive"
|
||||||
|
echo ""
|
||||||
|
echo "Files created:"
|
||||||
|
echo " - BaseSystem.img (macOS installer)"
|
||||||
|
echo " - macOS.qcow2 (100GB virtual disk)"
|
||||||
|
echo " - mac_hdd_ng.img -> macOS.qcow2 (compatibility symlink)"
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
# Prompt to start VM
|
# Ask if user wants to start the VM now
|
||||||
read -p "Start macOS VM now? (y/n): " -n 1 -r
|
read -p "Would you like to start the macOS VM now? (y/n): " -n 1 -r
|
||||||
echo
|
echo
|
||||||
[[ $REPLY =~ ^[Yy]$ ]] && sudo ./OpenCore-Boot.sh || echo "VM can be started later"
|
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
||||||
|
echo "Starting macOS VM..."
|
||||||
|
sudo ./OpenCore-Boot.sh
|
||||||
|
else
|
||||||
|
echo "You can start the VM later by running:"
|
||||||
|
echo " cd $INSTALL_DIR && sudo ./OpenCore-Boot.sh"
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in New Issue