mirror of
https://github.com/containers/podman.git
synced 2025-06-26 04:46:57 +08:00
Merge pull request #15199 from baude/addapplehv
Add interface for apple hypervisor
This commit is contained in:
@ -9,5 +9,5 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func GetSystemDefaultProvider() machine.Provider {
|
func GetSystemDefaultProvider() machine.Provider {
|
||||||
return qemu.GetQemuProvider()
|
return qemu.GetVirtualizationProvider()
|
||||||
}
|
}
|
||||||
|
70
pkg/machine/applehv/machine.go
Normal file
70
pkg/machine/applehv/machine.go
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
//go:build arm64 && !windows && !linux
|
||||||
|
// +build darwin
|
||||||
|
|
||||||
|
package applehv
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/containers/podman/v4/pkg/machine"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Provider struct{}
|
||||||
|
|
||||||
|
var (
|
||||||
|
hvProvider = &Provider{}
|
||||||
|
// vmtype refers to qemu (vs libvirt, krun, etc).
|
||||||
|
vmtype = "apple"
|
||||||
|
)
|
||||||
|
|
||||||
|
func GetVirtualizationProvider() machine.Provider {
|
||||||
|
return hvProvider
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
// Some of this will need to change when we are closer to having
|
||||||
|
// working code.
|
||||||
|
VolumeTypeVirtfs = "virtfs"
|
||||||
|
MountType9p = "9p"
|
||||||
|
dockerSock = "/var/run/docker.sock"
|
||||||
|
dockerConnectTimeout = 5 * time.Second
|
||||||
|
apiUpTimeout = 20 * time.Second
|
||||||
|
)
|
||||||
|
|
||||||
|
type apiForwardingState int
|
||||||
|
|
||||||
|
const (
|
||||||
|
noForwarding apiForwardingState = iota
|
||||||
|
claimUnsupported
|
||||||
|
notInstalled
|
||||||
|
machineLocal
|
||||||
|
dockerGlobal
|
||||||
|
)
|
||||||
|
|
||||||
|
func (p *Provider) NewMachine(opts machine.InitOptions) (machine.VM, error) {
|
||||||
|
return nil, machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) LoadVMByName(name string) (machine.VM, error) {
|
||||||
|
return nil, machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) List(opts machine.ListOptions) ([]*machine.ListResponse, error) {
|
||||||
|
return nil, machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) IsValidVMName(name string) (bool, error) {
|
||||||
|
return false, machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) CheckExclusiveActiveVM() (bool, string, error) {
|
||||||
|
return false, "", machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) RemoveAndCleanMachines() error {
|
||||||
|
return machine.ErrNotImplemented
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Provider) VMType() string {
|
||||||
|
return vmtype
|
||||||
|
}
|
@ -66,6 +66,7 @@ var (
|
|||||||
ErrVMAlreadyExists = errors.New("VM already exists")
|
ErrVMAlreadyExists = errors.New("VM already exists")
|
||||||
ErrVMAlreadyRunning = errors.New("VM already running or starting")
|
ErrVMAlreadyRunning = errors.New("VM already running or starting")
|
||||||
ErrMultipleActiveVM = errors.New("only one VM can be active at a time")
|
ErrMultipleActiveVM = errors.New("only one VM can be active at a time")
|
||||||
|
ErrNotImplemented = errors.New("functionality not implemented")
|
||||||
ForwarderBinaryName = "gvproxy"
|
ForwarderBinaryName = "gvproxy"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ var (
|
|||||||
vmtype = "qemu"
|
vmtype = "qemu"
|
||||||
)
|
)
|
||||||
|
|
||||||
func GetQemuProvider() machine.Provider {
|
func GetVirtualizationProvider() machine.Provider {
|
||||||
return qemuProvider
|
return qemuProvider
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user