DEV Community

Running MacOS on Windows 10 with WSL2, KVM and QEMU

Nicole Stevens on August 06, 2020

Note - Unfortunately this no longer works due to movement in the WSL offering for Windows 11 Dev Channel. Am leaving this here incase some of the...
Collapse
 
pkostelnik profile image
Pawel Kostelnik • Edited

Finally it's running ! Very, very slow as of now but still it runs:
masOS catalina
and here some Statistics from HTOP (inside the wsl2 Ubuntu 20.04):
HTOP Statistics
And here are my Settings:
.wslconfig

[wsl2]
kernel=***my custom kvm kernel***
kernelCommandLine=amd_iommu=on iommu=pt vfio-pci.ids=1002:66af,1002:ab20 kvm.ignore_msrs=1 kvm-amd.nested=1 kvm-amd.ept=1 kvm-amd.emulate_invalid_guest_state=0 kvm-amd.enable_shadow_vmcs=1 kvm-amd.enable_apicv=1
memory=8GB
processors=8
swap=16GB
localhostForwarding=true
nestedVirtualization=true
pageReporting=true
Enter fullscreen mode Exit fullscreen mode

and here the customized basic.sh:

#!/bin/bash

OSK="ourhardworkbythesewordsguardedpleasedontsteal(c)AppleComputerInc"
VMDIR=$PWD
OVMF=$VMDIR/firmware
#export QEMU_AUDIO_DRV=pa
#QEMU_AUDIO_DRV=pa

qemu-system-x86_64 \
    -enable-kvm \
    -m 8G \
    -machine q35,accel=kvm \
    -smp 8,cores=4 \
    -soundhw ac97 \
    -cpu Penryn,vendor=GenuineIntel,kvm=on,+sse3,+sse4.2,+aes,+xsave,+avx,+xsaveopt,+xsavec,+xgetbv1,+avx2,+bmi2,+smep,+bmi1,+fma,+movbe,+invtsc \
    -device isa-applesmc,osk="$OSK" \
    -smbios type=2 \
    -drive if=pflash,format=raw,readonly,file="$OVMF/OVMF_CODE.fd" \
    -drive if=pflash,format=raw,file="$OVMF/OVMF_VARS-1024x768.fd" \
    -vga qxl \
    -device ich9-intel-hda -device hda-output \
    -usb -device usb-kbd -device usb-tablet\
    -netdev user,id=net0 \
    -device e1000-82545em,netdev=net0,id=net0,mac=52:54:00:c9:18:27 \
    -device ich9-ahci,id=sata \
    -drive id=ESP,if=none,format=qcow2,file=ESP.qcow2 \
    -device ide-hd,bus=sata.2,drive=ESP \
    -drive id=InstallMedia,format=raw,if=none,file=BaseSystem.img \
    -device ide-hd,bus=sata.3,drive=InstallMedia \
    -drive id=SystemDisk,if=none,file=MacOS.qcow2 \
    -device ide-hd,bus=sata.4,drive=SystemDisk \
Enter fullscreen mode Exit fullscreen mode

next step: Speedup that thing!

Collapse
 
nicole profile image
Nicole Stevens

love this :) many thanks for sharing.
Wish I had something running AMD to help in the hunt for speedup tweaks. Will contact a couple of local user groups in the case anyone has something going spare.

Collapse
 
ciparis profile image
MichaelF

I was hoping to join in the optimization testing (3950X w/64GB RAM to play with) but so far I haven't made it past the first reboot when installing. It always stalls at:
"Initialized /dev/rdisk4 as a 10 MB case-insensitive HFS Plus volume".

@pkostelnik I'm using your wsl and basic files... can you share what you changed with the custom kernel?

Thread Thread
 
nicole profile image
Nicole Stevens • Edited

Might be able to help there @pkostelnik didn't use a custom kernel, I think that's what is meant in the first comment, no special build

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik • Edited

it does work with and without the Kernel. I build mine along the tutorial from: Hayden Barns but simply changed from KVM for Intel to KVM for AMD and build it. (not as module).
KVM Kernel for AMD
But it took a couple of hours (i belive) to install the MacOS in the box and also the boot takes about 15min and yes you are not really able to work with but for me it's quite the first step as an engineering sample not even a PoC that it will work. ;-)

After some checks, seems like kvm is installed but not working ... trying now with a custom kernel and KVM_AMD as module!
Edit:
@nicole and @ciparis it seems like KVM (not as Module) is enabled in the system but didn't used. That`s why the catalina is sooo slow.

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik

just installed over night the insider 20211.1000 now it's a bit faster but still slow:

my ubuntu Ubuntu 20.04.1 LTS linux kernel:

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik • Edited

Ok, next step/s tweaks. Reached up to maybe 30% speedup of the machine:

  1. Compiled the actual Kernel for KVM (not Module but including both systems Intel and AMD).
  2. set up dbus on debian from: DamionGans on Github. After setting up the dbus you need to Terminate the WSL2 distro with: wsl.exe -t distroname on CDM or PowerShell. In my case Ubuntu as distroname.
  3. after next start the dbus incl systemctl will become available.
  4. its still hell slow ;-)
Thread Thread
 
ciparis profile image
MichaelF • Edited

Mine is FINALLY working!

Screenshot

I ended up bailing on macOS-Simple-KVM (I could just never get past the first reboot). I tried everything -- new kernels, various options, nothing worked.

I found another, more complicated approach using OpenCore instead of Clover that ended up working out. Piling on extra RAM helped greatly with performance, as did using as many AMD processor flags as I could for KVM options. I'm pretty happy with where it ended up (using Catalina) but might try Mojave just to compare performance.

Thanks for this guide, Nicole! This post led me down a rabbit hole but it was a good one.

Thread Thread
 
nicole profile image
Nicole Stevens

Great news! Many thanks for the update. That's interesting, am still trying to get my hands on an AMD machine to have a go at this.

Thread Thread
 
nicole profile image
Nicole Stevens

@pkostelnik yeah dbus is a great shout, same IPC etc, did you check the performance gain after the full kernel compile or with both together?

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik

@nicole Not really because there is only a slightly speedup between this changes maybe 10-15%

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik • Edited

@ciparis would you mind to share your configuration please.

Thread Thread
 
ciparis profile image
MichaelF • Edited

Here's the guide I followed:

github.com/kholia/OSX-KVM

I used the 2 networking lines from macOS-Simple-KVM rather than the method he listed, which did not work in WSL2. I've added a few more processor flags to my launch shell script (and changed the name for ease of typing) :

.wslconf borrowed and modified from yours (I'm pretty sure some of those AMD settings are non-functional) --note that the number of processors is inherited from the host and does not need listing here. When building my own kernel I had to use the 104 one -- the available 128 option failed to mount my C drive after building. I probably didn't need to go that route at all, since the current Insider dev build (20211.1005) has nested KVM support out of the box.

[wsl2]
nestedVirtualization=true
kernel=C:\\Users\\myUserPath\\bzImage
kernelCommandLine=amd_iommu=on iommu=pt vfio-pci.ids=1002:66af,1002:ab20 kvm.ignore_msrs=1 kvm-amd.nested=1 kvm-amd.ept=1 kvm-amd.emulate_invalid_guest_state=0 kvm-amd.enable_shadow_vmcs=1 kvm-amd.enable_apicv=1
memory=24GB
localhostForwarding=true
Enter fullscreen mode Exit fullscreen mode

Launch script from this tutorial with my additions to the flags (I think svm is critical for AMD) and adjustments to RAM/Proc

############################################################################
# NOTE: Tweak the "MY_OPTIONS" line in case you are having booting problems!
############################################################################

MY_OPTIONS="+svm,+hypervisor,+msr,+pcid,+ssse3,+sse4.2,+popcnt,+avx,+avx2,+aes,+xsave,+xsaveopt,check"

# This script works for Big Sur, Catalina, Mojave, and High Sierra. Tested with
# macOS 10.15.6, macOS 10.14.6, and macOS 10.13.6

ALLOCATED_RAM="17166" # MiB
CPU_SOCKETS="1"
CPU_CORES="4"
CPU_THREADS="8"

REPO_PATH="./"
OVMF_DIR="."
Enter fullscreen mode Exit fullscreen mode

It's possible (likely?) that I could trace my original installation-reboot issue by comparing the launch file with the one from macOS-simple-kvm.

That list of processor flags provide a big performance gain, but I'm not done yet. My next step is to place all of the AMD processor flags into the options line and then systematically remove the ones that cause errors -- this is similar to the process used for the huge long list of Intel flags at the bottom of the Accelerated KVM Guests post, and my performance with the graphical Ubuntu shell he walks through the installation of at the bottom is fantastic. Granted that's has a much lighter overhead then macOS.

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik • Edited

@ciparis i'm sure there is also a huge difference with the vCPU which he uses for QEMU.
I also use the switch -deamonize to free the WSL console for htop and other monitoring.

Thread Thread
 
ciparis profile image
MichaelF • Edited

Here's the list of every AMD CPU flag (from /proc/cpuinfo) that is accepted without error by QEMU:

"+fpu,+vme,+de,+pse,+tsc,+msr,+pae,+mce,+cx8,+apic,+sep,+mtrr,+pge,+mca,+cmov,+pat,+pse36,+clflush,+mmx,+fxsr,+sse,+sse2,+ht,+syscall,+nx,+mmxext,+fxsr_opt,+pdpe1gb,+rdtscp,+lm,+pni,+pclmulqdq,+ssse3,+fma,+cx16,+sse4_1,+sse4_2,+movbe,+popcnt,+aes,+xsave,+avx,+f16c,+rdrand,+hypervisor,+lahf_lm,+cmp_legacy,+svm,+abm,+sse4a,+misalignsse,+3dnowprefetch,+osvw,+topoext,+ssbd,+ibpb,+stibp,+fsgsbase,+bmi1,+avx2,+smep,+bmi2,+rdseed,+adx,+smap,+clflushopt,+clwb,+xsaveopt,+xsavec,+xgetbv1,+xsaves,+clzero,+xsaveerptr,+arat,+npt,+nrip_save,+tsc_scale,+vmcb_clean,+flushbyasid,+decodeassists,+pfthreshold,+umip,+rdpid,check"
Enter fullscreen mode Exit fullscreen mode

Performance remains good; I should probably benchmark between this list and the previous one.

Thread Thread
 
ciparis profile image
MichaelF • Edited

@pkostelnik What version of macOS are you using?

I just tried Mojave and it ran much slower than Catalina (the opposite of what I expected). For whatever reason, Catalina is faster on my Ryzen setup. Still laggy, but usable.

Thread Thread
 
pkostelnik profile image
Pawel Kostelnik

@ciparis trying actually both catalina (which started with clover) and also mojave, but trying now to change to opencore.

Collapse
 
pkostelnik profile image
Pawel Kostelnik • Edited

Just trying on my HP Pavillion Gaming 15-EC0002 (or so) with Windows 10 insider (DEV Channel).
AMD Ryzen 3750H Mobile
16GB and some SSD
got Clover to boot and also installed MacOS (Mojave) now.
just got to change some things from Intel to AMD.
As of today no special Kerlen were needed!
My .wslconfig:

[wsl2]
memory=4GB
swap=8GB
localhostForwarding=true
nestedVirtualization=true
pageReporting=true
kernelCommandLine=amd_iommu=on iommu=pt kvm.ignore_msrs=1 kvm-amd.nested=1 kvm-amd.ept=1 kvm-amd.emulate_invalid_guest_state=0 kvm-amd.enable_shadow_vmcs=1 kvm-amd.enable_apicv=1
Enter fullscreen mode Exit fullscreen mode

System is slow but still rebuilding!
Edit: It seems like 4 or 6GB are too less for MacOS.. trying to tweak up that thing ;-)
Still installing, in the time between i tried to build a KVM Kernel but... not even one worked as expected so back to basic.
Installing ...
here the actual TOP from the same Distribution:
WSL2 Ubuntu TOP
Hmm... always running on:

apfs_module_stop:1432 .......... (remaining mem allocated: 0)
Enter fullscreen mode Exit fullscreen mode

still stuck at the same stage ...
even with a rebuild kernel and 8GB + 4core/8Thread (Memory and CPU changed in .wslconfig and also in the basic.sh)

Collapse
 
nicole profile image
Nicole Stevens

Many thanks for the update on the kernel and your .wslconfig file :)

Thanks for the note on memory too, I think I read something like that on a forum, 8GB was good, if I recall correctly. I just tried to find where I might have seen it but I can't sorry!

Collapse
 
nigamelastic profile image
Kshitij Nigam

Wow this post is so good, i spent a good chunk of time and was finally able to install catalina, updating it to BIGSUR as we speak.
I am new to kvm and unfortunately the qemu documentation is really crap.
May be someone can guide me:
1) how can i connect a usb device to the macos running
2) what is a nice setting for CPU, right now i just removed the thread option and added 6 cores, its not really fast but its ok

Collapse
 
nicole profile image
Nicole Stevens

If you've followed this write up then your virtual disks should be in the folder so yes you can delete it and the bulk of the setup and used data is gone.

It's been a while since I tried this, been waiting for a new laptop so can check it out on Windows 11 but am sure had USB mouse and keyboard running and all was good. What's not working?

Collapse
 
nigamelastic profile image
Kshitij Nigam • Edited

so If i am to insert my iphone, I cant connect the usb ports, I see that in WSL2 in general its not possible however some people have used usb over TCP to do that.
Secondly for some reason. once i installed everything and tried to restart the machine it doesnt start anymore :(

Thread Thread
 
nigamelastic profile image
Kshitij Nigam

hey I found out the issue my cpu settings were incorrect :)

Collapse
 
nigamelastic profile image
Kshitij Nigam

oh also how do u uninstall this just by deleting osx simple kvm folder?

Collapse
 
davepl profile image
davepl

Well, I'm 90 minutes in, but it's unclear to me where jumpstart.sh and basic.sh come from. They're just used like they should be present, but from whence do they originate?

Thanks for any help!

Collapse
 
nicole profile image
Nicole Stevens

No problem! This bit of text from the post :-

The MacOS-Simple-KVM GitHub repo is linked from the original post. It is described as "set up a simple macOS VM in QEMU, accelerated by KVM

Has a link on the "MacOS-Simple-KVM" words taking you to a GitHub repo.

I then start talking about QEMU, move past that and you'll see this paragraph :-

The steps were followed as listed but with the following tweaks. First clone the git repo in, make sure to use the linux filesystem as it is faster at the moment on wsl2 than windows (/mnt).

This might be where there's some confusion. Once you clone the GitHub repo linked to off of "MacOS-Simple-KVM" using your wsl session you need to cd into it. The files you mention are in there.

I hope that is clearer, if so I'll update the post accordingly :)

Collapse
 
davepl profile image
davepl

Thanks! I did go back and spot it but appreciate the prompt followup!

I'm trying this on an i7-4770K before making the leap on the Ryzen 3970X!

Thread Thread
 
nicole profile image
Nicole Stevens

Sounds like a plan :) glad you spotted it!

Collapse
 
davepl profile image
davepl

Found it! It's the KVM Repro mentioned about half way through...

Collapse
 
nicole profile image
Nicole Stevens

How did you get on, did you get it up and running?

Thread Thread
 
davepl profile image
davepl

I bought and installed the X server and got it as far as booting Clover and the original BaseImage.img, but it would hang a ways into the text boot at one of the meeting/rendezvous/sync points in startup. So close, but so far!

Appreciate the write-up! I may give it another shot on the AMD when it enters Beta... I've been waiting on AMD sub-virtualization just for WSL2 under HyperV for a while now!

Thread Thread
 
jared_riddle_real profile image
Jared Riddle

Did you ever get it past hang after clover?
It's 3am, and my eyes are getting blury.

Thread Thread
 
jared_riddle_real profile image
Jared Riddle
  1. I actually gave up on Clover and went with opencore with a different script github.com/kholia/OSX-KVM

And THEN,

  1. Using the config.plist that they provided ( and they admitted it needed work ) I spent a good hour getting it tweaked with:
    opencore.slowgeek.com/

  2. After that it was a matter of selecting which virtual "CPU" I wanted and I think I selected Skylake-Client?
    mankier.com/7/qemu-cpu-models#Desc...
    This list is to select what the cpu is that's being mimiced in the VM, and NOT what hardware model you have on your host machine.

  3. Not to brag, but it's freaking Blazing fast now.

Thread Thread
 
nigamelastic profile image
Kshitij Nigam

wow awesome if u have a guid/gist please share

Collapse
 
mick_p1982 profile image
Mick Pearson • Edited

Mid 2021 (fresh WSLg install on a new AMD system) I'm having some unusual trouble with this. Two things: 1) the VM can't connect to the Internet. The MacOS installer (Reinstall) actually requires a connection to get started. It says "Recovery server could not be contacted" in a message box and sends me back to the menu. (I.e. in the Network Utility there's no response to the Ping function. I feel like you guys would've spoken about network stuff more if you'd encountered this... or you all have something else set up that made this a nonissue.) and 2) the installer UI runs super fast. (I.e. keyboard input is nigh impossible and animations are 10 times faster than they ought to be. Shouldn't a VM have a virtual real-time clock?)

I'm sharing this here because I think anyone doing this now will encounter these troubles, and I've sunk a lot time into trying harebrained fixes (classic Linux-hole wasting-time pattern) to no avail. I've posted a question on Reddit that's gotten some up-votes already (UPDATE: my posts were yanked for "too little information" provided, so I can't recommend these Reddit forums) (reddit.com/r/bashonubuntuonwindows...) that includes a link to a more detailed post on r/hackintosh that looks like it's unlisted, IOW waiting for mod approval that may never come.

Collapse
 
nicole profile image
Nicole Stevens

Hey Mick, many thanks for the update. I haven't had to set this up since the end of 2020, so it's been a few releases for me too. I'm wiping my current setup in a couple of weeks, will try this again then.

Collapse
 
ragmanx profile image
RagManX

Thanks so much for this write-up. I finally got to the installation step - Cataina is installing now. Appreciate all the follow-up you've done in the comments to help people get things working. I managed to make it to the install thanks to your guide plus comments of others, and I'm hoping to be running and testing MacOS before the night is out. Since my wife runs a Mac for her work, I need to learn a bit more about MacOS since I provide tech support. Your guide saves me needing my own Apple hardware, and with 2 kids starting college this year I can't express how much help that is.

Collapse
 
nicole profile image
Nicole Stevens

So glad you found this useful !

Collapse
 
chadacious profile image
Chad Michael • Edited

It seems that the dev channel is locked into wanting to upgrade to windows 11. And I haven't found a way to get access to previous dev channel windows builds otherwise. It seems I need at least the old dev channel build 19619 iso to get past kvm-ok. My system is stuck on 19044, and doesn't support upgrading to windows 11 because of the TPM requirement. Thoughts?

Collapse
 
chadacious profile image
Chad Michael

Well, I decided to be bold and upgrade my bios and eventually upgrade to windows 11 build on the dev channel.

I have mojave installing now, although it says it will take 14 hours so that doesn't bode well. Guess I'll check it in a couple days and see what happens.

Thanks for the tutorial BTW. Was just was I was looking for to get started with this.

Collapse
 
chadacious profile image
Chad Michael • Edited

I had the same issues on the first reboot as MichaelF reported in his comment. So I tried the OSX-KVM he referenced and its working great! Installing Xcode 11.1 now and seeming like it will be completely usable for my purposes.

For reference, I'm on Windows 11 build 22504, Intel i7-6700, and running the Ubuntu 20.04 and Mojave vms using X410.

Collapse
 
silfalion profile image
Silfalion

Do you think it’d be possible to enable gpu acceleration on OSX through WSL 2 gpu support?

Collapse
 
pkostelnik profile image
Pawel Kostelnik

Maybe in the future as soon as the GPU (let's talk about something like "passthrew") will get full support in WSL.

Collapse
 
silfalion profile image
Silfalion

That’ll be a grand day.

Collapse
 
jst68 profile image
jstraten

When I am running kvm-ok, I am getting: KVM acceleration can be used
However, when I run ./basic.sh, I am getting Could not access KVM kernel module: Permission denied
qemu-system-x86_64: failed to initialize KVM: Permission denied
It seems to be some kind of authorization problem, but I can't figure out a solution. Did anybody run into the same problem and has somehow resolved it? Thank you!

Collapse
 
pkostelnik profile image
Pawel Kostelnik • Edited

Sorry being so late with my answer.
Permission denied means mostly that you need to change the permissions on /dev/kvm to 666 :
sudo chmod 666 /dev/kvm
this should resolve your Permission denied problem.

But you will do this after each reboot / restart of wsl.

Collapse
 
aaronngray profile image
Aaron Gray

I am getting the following :-

$ sudo kvm-ok
INFO: Your CPU does not support KVM extensions
KVM acceleration can NOT be used
Enter fullscreen mode Exit fullscreen mode

Although I have an LG Gram 17Z90N with Intel Core-i7 1065G7.

Collapse
 
jared_riddle_real profile image
Jared Riddle

This had me stumped for a long time as well.
Oddly enough, it didn't matter whether I was using my i5 or my Celeron.
The key was getting the Windows DEV Channel version of Windows 10.

Settings > Windows Insider Program > Dev Channel.

It was the very first step in the referenced "PreReq" steps blog post, and I just Blew past it because I didn't understand what "Fast Ring" meant.

Collapse
 
nicole profile image
Nicole Stevens

Hey, sorry missed this last week, did you get this sorted?

Collapse
 
davidgp profile image
DavidGP

Ok so now you can run all sorts of Linux distributions and even Mac OS directly on a Linux subsystem that is contained in Windows 10.

I'm giving up 🤯💥💨

Collapse
 
piyush1104 profile image
Piyush Bansal

Nice writeup! I had recently installed macos on virtualbox using this repo github.com/myspaghetti/macos-virtu.... I was wondering, if running it through KVM improves any performance. Though, I have also installed macos on qemu on a Linux distro, and it is more performant than the virtualbox one. Have you ever tried the virtualbox solution?

Collapse
 
nicole profile image
Nicole Stevens

Hey Piyush, I haven't tried the virtualbox solution, my understanding is KVM should give you an increase, but if you're working with really old hardware, there is a limit to what you can achieve. Your link has this section - github.com/myspaghetti/macos-virtu... which seems to suggest that this may be the case. Just to add, I love virtualbox as a goto for new users, so easy to manage :)

Collapse
 
letrix profile image
Fermín Cirella • Edited

Thank for this article. I made to the point where QEMU runs with KVM (? probably) but whenever I try to boot Ubuntu or Windows install, I end up with a GSOD with HYPERVISOR_ERROR message.
I will try now with OSX-KVM to see if there is any difference. If not, I'll try different kernel versions.
I'm on Ryzen 3600.

EDIT: Tried OSX-KVM with 4.19.104 kernel and default build 21354 but still got GSOD with same error.

EDIT 2: Managed to boot up to the High Sierra installer but on shutting down GSOD HYPERVISOR_ERROR appeared. Setting kvm=off on the main file (OpenCore-Boot.sh) managed to reduce that error.
I will now try Catalina with various options including kvm=off and other tweaks to see if I can get rid of that error.

EDIT 3: Installing Catalina, no GSOD so far.

Collapse
 
truefranco profile image
truefranco • Edited

Running on Windows 11 :P, trying now to get video acceleration but not sure if it is possible on Windows Host.
WSL

Collapse
 
dingdang66686 profile image
Straying

Can you express how to achieve that on windows?

Collapse
 
drakonas profile image
3rdN3rd • Edited

Just wanted to share with the OP that this method is no longer possible with Windows 10, as the Windows 10 Dev channel seems to have been halted in favor of Windows 11 Dev Channel. If you subscribe to Insider Dev or Beta channels when on Windows 10, you are automatically given Windows 11 by default even if you're on unsupported hardware. And the release preview coming up (22H2) doesn't even have the feature either, and it's supposed to be the final release preview I think? So I'm guessing this is a big "oof" and Microsoft decided to not release this for Windows 10 at all. :/

Collapse
 
commonsenseused profile image
Joey R.

Will try this with wslg on 2700x

Collapse
 
nandumoura profile image
Fernando Moura

I finally got it
I've been trying to run some version of macos for a long time and I couldn't. Your tutorial was great for helping me.
Thank you