vsockmon.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. #ifndef _UAPI_VSOCKMON_H
  3. #define _UAPI_VSOCKMON_H
  4. #include <linux/virtio_vsock.h>
  5. /*
  6. * vsockmon is the AF_VSOCK packet capture device. Packets captured have the
  7. * following layout:
  8. *
  9. * +-----------------------------------+
  10. * | vsockmon header |
  11. * | (struct af_vsockmon_hdr) |
  12. * +-----------------------------------+
  13. * | transport header |
  14. * | (af_vsockmon_hdr->len bytes long) |
  15. * +-----------------------------------+
  16. * | payload |
  17. * | (until end of packet) |
  18. * +-----------------------------------+
  19. *
  20. * The vsockmon header is a transport-independent description of the packet.
  21. * It duplicates some of the information from the transport header so that
  22. * no transport-specific knowledge is necessary to process packets.
  23. *
  24. * The transport header is useful for low-level transport-specific packet
  25. * analysis. Transport type is given in af_vsockmon_hdr->transport and
  26. * transport header length is given in af_vsockmon_hdr->len.
  27. *
  28. * If af_vsockmon_hdr->op is AF_VSOCK_OP_PAYLOAD then the payload follows the
  29. * transport header. Other ops do not have a payload.
  30. */
  31. struct af_vsockmon_hdr {
  32. __le64 src_cid;
  33. __le64 dst_cid;
  34. __le32 src_port;
  35. __le32 dst_port;
  36. __le16 op; /* enum af_vsockmon_op */
  37. __le16 transport; /* enum af_vsockmon_transport */
  38. __le16 len; /* Transport header length */
  39. __u8 reserved[2];
  40. };
  41. enum af_vsockmon_op {
  42. AF_VSOCK_OP_UNKNOWN = 0,
  43. AF_VSOCK_OP_CONNECT = 1,
  44. AF_VSOCK_OP_DISCONNECT = 2,
  45. AF_VSOCK_OP_CONTROL = 3,
  46. AF_VSOCK_OP_PAYLOAD = 4,
  47. };
  48. enum af_vsockmon_transport {
  49. AF_VSOCK_TRANSPORT_UNKNOWN = 0,
  50. AF_VSOCK_TRANSPORT_NO_INFO = 1, /* No transport information */
  51. /* Transport header type: struct virtio_vsock_hdr */
  52. AF_VSOCK_TRANSPORT_VIRTIO = 2,
  53. };
  54. #endif