qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/6] Add vmnet.framework based network backend
@ 2021-10-12 10:55 Vladislav Yaroshchuk
  2021-10-12 10:55 ` [PATCH v3 1/6] net/vmnet: dependencies setup, initial preparations Vladislav Yaroshchuk
                   ` (5 more replies)
  0 siblings, 6 replies; 7+ messages in thread
From: Vladislav Yaroshchuk @ 2021-10-12 10:55 UTC (permalink / raw)
  To: qemu-devel; +Cc: jasowang, eblake, r.bolshakov, Vladislav Yaroshchuk

macOS provides networking API for VMs called vmnet.framework.
I tried to add it as a network backend. All three modes are supported:

-shared:
  allows the guest to communicate with other guests in shared mode and
  also with external network (Internet) via NAT

-host:
  allows the guest to communicate with other guests in host mode

-bridged:
  bridges the guest with a physical network interface

Separate netdev for each vmnet mode was created because they use quite
different settings, especially since macOS 11.0 when vmnet.framework
gets a lot of updates.

Not sure that I use qemu_mutex_lock_iothread() and
qemu_mutex_unlock_iothread() in correct way while sending packet
from vmnet interface to QEMU. I'll be happy to receive
recommendations how to make this thing better if I done sth wrong.

Also vmnet.framework requires com.apple.vm.networking entitlement to
run without root privileges. Ad-hoc signing does not fit there,
so I didn't touch anything related to signing. As a result we should
run qemu-system by a privileged user:
`$ sudo qemu-system-x86_64 -nic vmnet-shared`
otherwise vmnet fails with 'general failure'.

But in any way it seems working now,
I tested it within qemu-system-x86-64 on macOS 10.15.7 host, with nic
models:
- e1000-82545em
- virtio-net-pci

and having such guests:
- macOS 10.15.7
- Ubuntu Bionic (server cloudimg)

v1 -> v2:
 Since v1 minor typos were fixed, patches rebased onto latest master, redundant
 changes removed (small commits squashed)

v2 -> v3:
 - QAPI style fixes
 - Typos fixes in comments
 - `#include`'s updated to be in sync with recent master

Vladislav Yaroshchuk (6):
  net/vmnet: dependencies setup, initial preparations
  net/vmnet: create common netdev state structure
  net/vmnet: implement shared mode (vmnet-shared)
  net/vmnet: implement host mode (vmnet-host)
  net/vmnet: implement bridged mode (vmnet-bridged)
  net/vmnet: update qemu-options.hx

 configure           |  31 +++++
 meson.build         |   5 +
 net/clients.h       |  11 ++
 net/meson.build     |   7 ++
 net/net.c           |  10 ++
 net/vmnet-bridged.m | 123 ++++++++++++++++++
 net/vmnet-common.m  | 295 ++++++++++++++++++++++++++++++++++++++++++++
 net/vmnet-host.c    |  93 ++++++++++++++
 net/vmnet-shared.c  |  94 ++++++++++++++
 net/vmnet_int.h     |  48 +++++++
 qapi/net.json       |  99 ++++++++++++++-
 qemu-options.hx     |  17 +++
 12 files changed, 831 insertions(+), 2 deletions(-)
 create mode 100644 net/vmnet-bridged.m
 create mode 100644 net/vmnet-common.m
 create mode 100644 net/vmnet-host.c
 create mode 100644 net/vmnet-shared.c
 create mode 100644 net/vmnet_int.h

-- 
2.23.0



^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2021-10-12 11:35 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-10-12 10:55 [PATCH v3 0/6] Add vmnet.framework based network backend Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 1/6] net/vmnet: dependencies setup, initial preparations Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 2/6] net/vmnet: create common netdev state structure Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 3/6] net/vmnet: implement shared mode (vmnet-shared) Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 4/6] net/vmnet: implement host mode (vmnet-host) Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 5/6] net/vmnet: implement bridged mode (vmnet-bridged) Vladislav Yaroshchuk
2021-10-12 10:55 ` [PATCH v3 6/6] net/vmnet: update qemu-options.hx Vladislav Yaroshchuk

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).