[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-id: <20160622161102.8250-1-ggarcia@deic.uab.cat>
Date: Wed, 22 Jun 2016 18:10:59 +0200
From: ggarcia@...a.uab.cat
To: netdev@...r.kernel.org
Cc: jhansen@...are.com, stefanha@...hat.com,
Gerard Garcia <ggarcia@...a.uab.cat>
Subject: [RFC v2 0/3] vsockmon: virtual device to monitor AF_VSOCK sockets.
From: Gerard Garcia <ggarcia@...c.uab.cat>
v2:
* Various simple fixes from the comments received to the first RFC.
* Do not clone skb, instead take ownership before transmitting.
* Split tap functions from af_vsock.c.
* Simplify vsockmon header to remove unnecessary padding and set little endian byte order.
Additionally, we are implementing a tcpdump printer (RFC: http://lists.sandelman.ca/pipermail/tcpdump-workers/2016-June/000546.html, patches: https://github.com/GerardGarcia/tcpdump/tree/vsock) and a wireshark dissector (in progress) to be able to easily monitor vsockmon devices.
Overview:
Virtual socket transports operate at kernel level therefore, there is no easy way to see the traffic exchanged between virtual machines and hypervisors that communicate using AF_VSOCK sockets. In addition, being able to see the control messages exchanged by the transports may be useful for debugging and optimization purposes. This patch adds a virtual device that may be used to see the traffic exchanged between virtual machines and hypervisors through AF_VSOCK sockets.
Its structure is based on the nlmon device and this version just targets the virtio transport, but support for the VMCI transport can be easily implemented. The vsockmon header consists of two structs: a generic header and a header specific to the transport. The generic header allows to follow an AF_VSOCK stream without having to understand the details of the transport while the transport header gives more detail which may be useful for troubleshooting and debugging.
The repository https://github.com/GerardGarcia/linux/tree/vsockmon implements these patches over the Stefan Hajnoczi vsock-next repository https://github.com/stefanha/linux/tree/vsock-next where the virtio trasnport is implemented. In the repository there is also a simple program that shows the traffic from a vsockmon device: https://github.com/GerardGarcia/linux/blob/vsockmon/vsockmon.c that can be used for testing.
Any thoughts and comments will be greatly appreciated.
Thanks to Stefan Hajnoczi for his help.
Gerard
Gerard Garcia (3):
vsockmon: Add tap functions
vsockmon: Add vsockmon device
vsockmon: Add vsock hooks
drivers/net/Kconfig | 8 ++
drivers/net/Makefile | 1 +
drivers/net/vsockmon.c | 167 ++++++++++++++++++++++++++++++++++++++++++
drivers/vhost/vsock.c | 73 ++++++++++++++++++
include/net/af_vsock.h | 13 ++++
include/uapi/linux/Kbuild | 1 +
include/uapi/linux/if_arp.h | 1 +
include/uapi/linux/vsockmon.h | 35 +++++++++
net/vmw_vsock/Makefile | 2 +-
net/vmw_vsock/af_vsock_tap.c | 112 ++++++++++++++++++++++++++++
10 files changed, 412 insertions(+), 1 deletion(-)
create mode 100644 drivers/net/vsockmon.c
create mode 100644 include/uapi/linux/vsockmon.h
create mode 100644 net/vmw_vsock/af_vsock_tap.c
--
2.9.0
Powered by blists - more mailing lists