macOS-Simple-KVM/README.md

46 lines
2.1 KiB
Markdown
Raw Normal View History

2019-04-22 09:25:21 +02:00
# macOS-Simple-KVM
2019-04-30 23:48:10 +02:00
Documentation to set up a simple macOS VM in QEMU, accelerated by KVM.
2019-04-23 00:08:10 +02:00
2019-05-11 23:25:09 +02:00
By [@FoxletFox](https://twitter.com/foxletfox), and the help of many others.
2019-06-19 22:22:59 +02:00
Find this useful? [You can donate here!](https://commerce.coinbase.com/checkout/96dc5777-0abf-437d-a9b5-a78ae2c4c227)
2019-05-11 23:25:09 +02:00
2019-05-10 20:07:24 +02:00
## Getting Started
2019-06-07 01:53:57 +02:00
You'll need a Linux system with `qemu`, `python3`, `pip` and the KVM extensions installed for this project. A Mac is **not** required. Some examples for different distributions:
```
2019-06-19 22:08:54 +02:00
sudo apt-get install qemu-system qemu-utils python3 python3-pip # for Ubuntu, Debian, Mint, and PopOS.
sudo pacman -S qemu python python-pip # for Arch.
sudo xbps-install -Su qemu python3 python3-pip # for Void Linux.
2019-06-07 01:53:57 +02:00
```
2019-04-25 22:57:52 +02:00
2019-04-23 00:08:10 +02:00
## Step 1
2019-06-07 01:53:57 +02:00
Run `jumpstart.sh` to download installation media for macOS (internet required). The default installation uses Catalina, but you can choose which version to get by adding either `--high-sierra`, `--mojave`, or `--catalina`. For example:
```
./jumpstart.sh --mojave
```
2019-05-11 23:32:56 +02:00
> Note: You can skip this if you already have `BaseSystem.img` downloaded. If you have `BaseSystem.dmg`, you will need to convert it with the `dmg2img` tool.
2019-04-23 00:08:10 +02:00
2019-04-30 23:48:10 +02:00
## Step 2
2019-05-10 20:07:24 +02:00
Create an empty hard disk using `qemu-img`, changing the name and size to preference:
```
qemu-img create -f qcow2 MyDisk.qcow2 64G
```
2019-05-10 20:07:24 +02:00
and add it to the end of `basic.sh`:
```
-drive id=SystemDisk,if=none,file=MyDisk.qcow2 \
-device ide-hd,bus=sata.4,drive=SystemDisk \
```
2019-06-19 22:08:54 +02:00
> Note: If you're running on a headless system (such as on Cloud providers), you will need `-nographic` and set up `-vnc` to use it.
2019-06-19 22:08:54 +02:00
Then run `basic.sh` to start the machine and install macOS. Remember to partition in Disk Utility first!
2019-04-23 00:08:10 +02:00
2019-05-10 20:07:24 +02:00
## Step 2a (Virtual Machine Manager)
If instead of QEMU, you'd like to import the setup into Virt-Manager for further configuration, just run `make.sh --add`.
2019-04-23 00:08:10 +02:00
## Step 3
2019-04-30 23:48:10 +02:00
You're done!
2019-06-07 22:53:10 +02:00
To fine-tune the system and improve performance, look in the `docs` folder for more information on [adding memory](docs/guide-performance.md), seting up [bridged networking](docs/guide-networking.md), adding [passthrough hardware (for GPUs)](docs/guide-passthrough.md), and enabling sound features.