forked from Code-Hex/vz
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request Code-Hex#34 from Code-Hex/add/mac-vm
add macOS VM
- Loading branch information
Showing
37 changed files
with
2,625 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,3 +2,4 @@ virtualization | |
*.log | ||
.envrc | ||
.env | ||
RestoreImage.ipsw |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
package vz | ||
|
||
/* | ||
#cgo darwin CFLAGS: -x objective-c -fno-objc-arc | ||
#cgo darwin LDFLAGS: -lobjc -framework Foundation -framework Virtualization | ||
# include "virtualization.h" | ||
*/ | ||
import "C" | ||
import "runtime" | ||
|
||
// AudioDeviceConfiguration interface for an audio device configuration. | ||
type AudioDeviceConfiguration interface { | ||
NSObject | ||
|
||
audioDeviceConfiguration() | ||
} | ||
|
||
type baseAudioDeviceConfiguration struct{} | ||
|
||
func (*baseAudioDeviceConfiguration) audioDeviceConfiguration() {} | ||
|
||
// VirtioSoundDeviceConfiguration is a struct that defines a Virtio sound device configuration. | ||
// | ||
// Use a VirtioSoundDeviceConfiguration to configure an audio device for your VM. After creating | ||
// this struct, assign appropriate values via the SetStreams method which defines the behaviors of | ||
// the underlying audio streams for this audio device. | ||
// | ||
// After creating and configuring a VirtioSoundDeviceConfiguration struct, assign it to the | ||
// SetAudioDevicesVirtualMachineConfiguration method of your VM’s configuration. | ||
type VirtioSoundDeviceConfiguration struct { | ||
pointer | ||
|
||
*baseAudioDeviceConfiguration | ||
} | ||
|
||
var _ AudioDeviceConfiguration = (*VirtioSoundDeviceConfiguration)(nil) | ||
|
||
// NewVirtioSoundDeviceConfiguration creates a new sound device configuration. | ||
func NewVirtioSoundDeviceConfiguration() *VirtioSoundDeviceConfiguration { | ||
config := &VirtioSoundDeviceConfiguration{ | ||
pointer: pointer{ | ||
ptr: C.newVZVirtioSoundDeviceConfiguration(), | ||
}, | ||
} | ||
runtime.SetFinalizer(config, func(self *VirtioSoundDeviceConfiguration) { | ||
self.Release() | ||
}) | ||
return config | ||
} | ||
|
||
// SetStreams sets the list of audio streams exposed by this device. | ||
func (v *VirtioSoundDeviceConfiguration) SetStreams(streams ...VirtioSoundDeviceStreamConfiguration) { | ||
ptrs := make([]NSObject, len(streams)) | ||
for i, val := range streams { | ||
ptrs[i] = val | ||
} | ||
array := convertToNSMutableArray(ptrs) | ||
C.setStreamsVZVirtioSoundDeviceConfiguration(v.Ptr(), array.Ptr()) | ||
} | ||
|
||
// VirtioSoundDeviceStreamConfiguration interface for Virtio Sound Device Stream Configuration. | ||
type VirtioSoundDeviceStreamConfiguration interface { | ||
NSObject | ||
|
||
virtioSoundDeviceStreamConfiguration() | ||
} | ||
|
||
type baseVirtioSoundDeviceStreamConfiguration struct{} | ||
|
||
func (*baseVirtioSoundDeviceStreamConfiguration) virtioSoundDeviceStreamConfiguration() {} | ||
|
||
// VirtioSoundDeviceHostInputStreamConfiguration is a PCM stream of input audio data, | ||
// such as from a microphone via host. | ||
type VirtioSoundDeviceHostInputStreamConfiguration struct { | ||
pointer | ||
|
||
*baseVirtioSoundDeviceStreamConfiguration | ||
} | ||
|
||
var _ VirtioSoundDeviceStreamConfiguration = (*VirtioSoundDeviceHostInputStreamConfiguration)(nil) | ||
|
||
// NewVirtioSoundDeviceHostInputStreamConfiguration creates a new PCM stream configuration of input audio data from host. | ||
func NewVirtioSoundDeviceHostInputStreamConfiguration() *VirtioSoundDeviceHostInputStreamConfiguration { | ||
config := &VirtioSoundDeviceHostInputStreamConfiguration{ | ||
pointer: pointer{ | ||
ptr: C.newVZVirtioSoundDeviceHostInputStreamConfiguration(), | ||
}, | ||
} | ||
runtime.SetFinalizer(config, func(self *VirtioSoundDeviceHostInputStreamConfiguration) { | ||
self.Release() | ||
}) | ||
return config | ||
} | ||
|
||
// VirtioSoundDeviceHostOutputStreamConfiguration is a struct that | ||
// defines a Virtio host sound device output stream configuration. | ||
// | ||
// A PCM stream of output audio data, such as to a speaker from host. | ||
type VirtioSoundDeviceHostOutputStreamConfiguration struct { | ||
pointer | ||
|
||
*baseVirtioSoundDeviceStreamConfiguration | ||
} | ||
|
||
var _ VirtioSoundDeviceStreamConfiguration = (*VirtioSoundDeviceHostOutputStreamConfiguration)(nil) | ||
|
||
// NewVirtioSoundDeviceHostOutputStreamConfiguration creates a new sounds device output stream configuration. | ||
func NewVirtioSoundDeviceHostOutputStreamConfiguration() *VirtioSoundDeviceHostOutputStreamConfiguration { | ||
config := &VirtioSoundDeviceHostOutputStreamConfiguration{ | ||
pointer: pointer{ | ||
ptr: C.newVZVirtioSoundDeviceHostOutputStreamConfiguration(), | ||
}, | ||
} | ||
runtime.SetFinalizer(config, func(self *VirtioSoundDeviceHostOutputStreamConfiguration) { | ||
self.Release() | ||
}) | ||
return config | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
//go:build darwin && arm64 | ||
// +build darwin,arm64 | ||
|
||
package vz | ||
|
||
/* | ||
#cgo darwin CFLAGS: -x objective-c -fno-objc-arc | ||
#cgo darwin LDFLAGS: -lobjc -framework Foundation -framework Virtualization | ||
# include "virtualization_arm64.h" | ||
*/ | ||
import "C" | ||
import "runtime" | ||
|
||
// MacOSBootLoader is a boot loader configuration for booting macOS on Apple Silicon. | ||
type MacOSBootLoader struct { | ||
pointer | ||
|
||
*baseBootLoader | ||
} | ||
|
||
var _ BootLoader = (*MacOSBootLoader)(nil) | ||
|
||
// NewMacOSBootLoader creates a new MacOSBootLoader struct. | ||
func NewMacOSBootLoader() *MacOSBootLoader { | ||
bootLoader := &MacOSBootLoader{ | ||
pointer: pointer{ | ||
ptr: C.newVZMacOSBootLoader(), | ||
}, | ||
} | ||
runtime.SetFinalizer(bootLoader, func(self *MacOSBootLoader) { | ||
self.Release() | ||
}) | ||
return bootLoader | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
package vz | ||
|
||
import ( | ||
"os" | ||
) | ||
|
||
// CreateDiskImage is creating disk image with specified filename and filesize. | ||
// For example, if you want to create disk with 64GiB, you can set "64 * 1024 * 1024 * 1024" to size. | ||
// | ||
// Note that if you have specified a pathname which already exists, this function | ||
// returns os.ErrExist error. So you can handle it with os.IsExist function. | ||
func CreateDiskImage(pathname string, size int64) error { | ||
f, err := os.OpenFile(pathname, os.O_RDWR|os.O_CREATE|os.O_EXCL, 0600) | ||
if err != nil { | ||
return err | ||
} | ||
defer f.Close() | ||
|
||
if err := f.Truncate(size); err != nil { | ||
return err | ||
} | ||
return nil | ||
} |
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
.PHONY: all | ||
all: build codesign | ||
|
||
.PHONY: codesign | ||
codesign: | ||
codesign --entitlements vz.entitlements -s - ./virtualization | ||
|
||
.PHONY: build | ||
build: | ||
go build -o virtualization . |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
Example | ||
======= | ||
|
||
You can get knowledge build and codesign process in Makefile. | ||
|
||
## Build | ||
|
||
```sh | ||
make all | ||
``` | ||
|
||
## Run | ||
|
||
- `./virtualization -install` install macOS to your VM. | ||
- `./virtualization` run macOS VM. | ||
|
||
## Resources | ||
|
||
Some resources will be created in `VM.bundle` directory on your home directory. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
package main | ||
|
||
import ( | ||
"fmt" | ||
"os" | ||
"path/filepath" | ||
) | ||
|
||
// CreateVMBundle creates macOS VM bundle path if not exists. | ||
func CreateVMBundle() error { | ||
return os.MkdirAll(GetVMBundlePath(), 0777) | ||
} | ||
|
||
// GetVMBundlePath gets macOS VM bundle path. | ||
func GetVMBundlePath() string { | ||
home, err := os.UserHomeDir() | ||
if err != nil { | ||
panic(err) // | ||
} | ||
return filepath.Join(home, "/VM.bundle/") | ||
} | ||
|
||
// GetAuxiliaryStoragePath gets a path for auxiliary storage. | ||
func GetAuxiliaryStoragePath() string { | ||
return filepath.Join(GetVMBundlePath(), "AuxiliaryStorage") | ||
} | ||
|
||
// GetDiskImagePath gets a path for disk image. | ||
func GetDiskImagePath() string { | ||
return filepath.Join(GetVMBundlePath(), "Disk.img") | ||
} | ||
|
||
// GetHardwareModelPath gets a path for hardware model. | ||
func GetHardwareModelPath() string { | ||
return filepath.Join(GetVMBundlePath(), "HardwareModel") | ||
} | ||
|
||
// GetMachineIdentifierPath gets a path for machine identifier. | ||
func GetMachineIdentifierPath() string { | ||
return filepath.Join(GetVMBundlePath(), "MachineIdentifier") | ||
} | ||
|
||
// GetRestoreImagePath gets a path for restore image file. | ||
func GetRestoreImagePath() string { | ||
return filepath.Join(GetVMBundlePath(), "RestoreImage.ipsw") | ||
} | ||
|
||
// CreateFileAndWriteTo creates a new file and write data to it. | ||
func CreateFileAndWriteTo(data []byte, path string) error { | ||
f, err := os.Create(path) | ||
if err != nil { | ||
return fmt.Errorf("failed to create file %q: %w", path, err) | ||
} | ||
defer f.Close() | ||
|
||
_, err = f.Write(data) | ||
if err != nil { | ||
return fmt.Errorf("failed to write data: %w", err) | ||
} | ||
return nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
module github.com/Code-Hex/vz/example/macOS | ||
|
||
go 1.16 | ||
|
||
replace github.com/Code-Hex/vz/v2 => ../../ | ||
|
||
require ( | ||
github.com/Code-Hex/vz/v2 v2.0.0-00010101000000-000000000000 | ||
github.com/pkg/term v1.1.0 | ||
golang.org/x/sys v0.0.0-20220808155132-1c4a2a72c664 | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
github.com/pkg/term v1.1.0 h1:xIAAdCMh3QIAy+5FrE8Ad8XoDhEU4ufwbaSozViP9kk= | ||
github.com/pkg/term v1.1.0/go.mod h1:E25nymQcrSllhX42Ok8MRm1+hyBdHY0dCeiKZ9jpNGw= | ||
github.com/rs/xid v1.4.0 h1:qd7wPTDkN6KQx2VmMBLrpHkiyQwgFXRnkOLacUiaSNY= | ||
github.com/rs/xid v1.4.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg= | ||
golang.org/x/sys v0.0.0-20200909081042-eff7692f9009/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||
golang.org/x/sys v0.0.0-20220808155132-1c4a2a72c664 h1:v1W7bwXHsnLLloWYTVEdvGvA7BHMeBYsPcF0GLDxIRs= | ||
golang.org/x/sys v0.0.0-20220808155132-1c4a2a72c664/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
Oops, something went wrong.