Skip to content

beweedon/virtsock

 
 

Repository files navigation

This repository contains Go bindings and sample code for Hyper-V sockets and virtio sockets(VSOCK).

Organisation

  • pkg/hvsock: Go binding for Hyper-V sockets
  • pkg/vsock: Go binding for virtio VSOCK
  • examples: Sample Go code and stress test
  • scripts: Miscellaneous scripts
  • c: Sample C code (including benchmarks and stress tests)
  • data: Data from benchmarks

Building

By default the Go sample code is build in a container. Simply type make.

If you want to build binaries on a local system use make build-binaries.

Testing

There are several examples and tests written both in Go and in C. The C code is Hyper-V sockets only while the Go code also works with virtio sockets and HyperKit. The respective READMEs contain instructions on how to run the tests, but the simplest way is to use LinuxKit.

Assuming you have LinuxKit installed, the make target make linuxkit will build a custom Linux image which can be booted on HyperKit or on Windows. The custom Linux image contains the test binaries.

macOS

Boot the Linux VM:

linuxkit run hvtest

This should create a directory called ./hvtest-state.

Run the server in the VM and client on the host:

linux$ virtsock_stress -s -v 1
macos$ ./build/virtsock_stress.darwin -c 3 -m hyperkit:./hvtest-state -v 1

Run the server on the host and the client inside the VM:

macos$ ./build/virtsock_stress.darwin -s -m hyperkit:./hvtest-state -v 1
linux$ virtsock_stress -c 2 -v 1

Windows

TBD

Known limitations

  • hvsock: The Windows side does not implement accept() due to limitations on some Windows builds where a VM can not connect to the host via Hyper-V sockets.

  • vsock: There is general host side implementation as the interface is hypervisor specific. The vsock package includes some support for connecting with the VSOCK implementation in Hyperkit, but there is no implementation for, e.g. qemu.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 41.2%
  • Go 40.7%
  • PowerShell 14.9%
  • Makefile 3.2%