vz provides the power of the Apple Virtualization.framework in Go. Put here is block quote of overreview which is written what is Virtualization.framework from the document.
The Virtualization framework provides high-level APIs for creating and managing virtual machines (VM) on Apple silicon and Intel-based Mac computers. Use this framework to boot and run macOS or Linux-based operating systems in custom environments that you define. The framework supports the Virtual I/O Device (VIRTIO) specification, which defines standard interfaces for many device types, including network, socket, serial port, storage, entropy, and memory-balloon devices.
Please see the example directory.
Initialize your project by creating a folder and then running go mod init github.com/your/repo
(learn more) inside the folder. Then install vz with the go get command:
$ go get github.com/Code-Hex/vz/v3
Deprecated older versions (v1, v2).
For binaries used in this package, you need to create an entitlements file like the one below and apply the following command.
$ codesign --entitlements vz.entitlements -s - <YOUR BINARY PATH>
A process must have the com.apple.security.virtualization entitlement to use the Virtualization APIs.
If you want to use VZBridgedNetworkDeviceAttachment
, you need to add also com.apple.vm.networking
entitlement.
If you compile using an older Xcode SDK, you will get the following warnings.
This example warns that macOS 12.3 API and macOS 13 API are not available in the binary build. This means these APIs are not available even if you are running this binary on a modern OS (macOS 12.3 or macOS 13).
$ go build .
# github.com/Code-Hex/vz/v3
In file included from _cgo_export.c:4:
In file included from socket.go:6:
In file included from ./virtualization_11.h:9:
./virtualization_helper.h:25:9: warning: macOS 12.3 API has been disabled [-W#pragma-messages]
./virtualization_helper.h:32:9: warning: macOS 13 API has been disabled [-W#pragma-messages]
If you want to build a binary that can use the API on all operating systems, make sure the Xcode SDK is up-to-date.
You can check the version of the Xcode SDK available for each macOS on this site.
The package provides a mechanism for checking the availability of the respective API through error handling:
bootLoader, err := vz.NewEFIBootLoader()
if errors.Is(err, vz.ErrUnsupportedOSVersion) || errors.Is(err, vz.ErrBuildTargetOSVersion) {
return fallbackBootLoader()
}
if err != nil {
return nil, err
}
return bootLoader, nil
There are two items to check.
There is a lot of knowledge required to use this Apple Virtualization.framework, but the information is too scattered and very difficult to understand. In most cases, this can be found in the official documentation. However, the Linux kernel knowledge required to use the feature provided by this framework is not documented. Therefore, I have compiled the knowledge I have gathered so far into this wiki.
https://github.com/Code-Hex/vz/wiki
Anyone is free to edit this wiki. It would help someone if you could add information not listed here. Let's make a good wiki together!
If you want to contribute some code, you will need to add tests.
PUI PUI Linux is used to test this library. This Linux is designed to provide only the minimum functionality required for the Apple Virtualization.framework (Virtio), so the kernel file size is very small.
The test code uses the Makefile
in the project root.
$ # Download PUI PUI Linux, Only required the first time.
$ make download_kernel
$ make test
MIT License