netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net-next v4 00/12] virtio_net: Add ethtool flow rules support
@ 2025-10-13 15:27 Daniel Jurgens
  2025-10-13 15:27 ` [PATCH net-next v4 01/12] virtio_pci: Remove supported_cap size build assert Daniel Jurgens
                   ` (11 more replies)
  0 siblings, 12 replies; 19+ messages in thread
From: Daniel Jurgens @ 2025-10-13 15:27 UTC (permalink / raw)
  To: netdev, mst, jasowang, alex.williamson, pabeni
  Cc: virtualization, parav, shshitrit, yohadt, xuanzhuo, eperezma,
	shameerali.kolothum.thodi, jgg, kevin.tian, kuba, andrew+netdev,
	edumazet, Daniel Jurgens

This series implements ethtool flow rules support for virtio_net using the
virtio flow filter (FF) specification. The implementation allows users to
configure packet filtering rules through ethtool commands, directing
packets to specific receive queues, or dropping them based on various
header fields.

The series starts with infrastructure changes to expose virtio PCI admin
capabilities and object management APIs. It then creates the virtio_net
directory structure and implements the flow filter functionality with support
for:

- Layer 2 (Ethernet) flow rules
- IPv4 and IPv6 flow rules  
- TCP and UDP flow rules (both IPv4 and IPv6)
- Rule querying and management operations

Setting, deleting and viewing flow filters, -1 action is drop, positive
integers steer to that RQ:

$ ethtool -u ens9
4 RX rings available
Total 0 rules

$ ethtool -U ens9 flow-type ether src 1c:34:da:4a:33:dd action 0
Added rule with ID 0
$ ethtool -U ens9 flow-type udp4 dst-port 5001 action 3
Added rule with ID 1
$ ethtool -U ens9 flow-type tcp6 src-ip fc00::2 dst-port 5001 action 2
Added rule with ID 2
$ ethtool -U ens9 flow-type ip4 src-ip 192.168.51.101 action 1
Added rule with ID 3
$ ethtool -U ens9 flow-type ip6 dst-ip fc00::1 action -1
Added rule with ID 4
$ ethtool -U ens9 flow-type ip6 src-ip fc00::2 action -1
Added rule with ID 5
$ ethtool -U ens9 delete 4
$ ethtool -u ens9
4 RX rings available
Total 5 rules

Filter: 0
        Flow Type: Raw Ethernet
        Src MAC addr: 1C:34:DA:4A:33:DD mask: 00:00:00:00:00:00
        Dest MAC addr: 00:00:00:00:00:00 mask: FF:FF:FF:FF:FF:FF
        Ethertype: 0x0 mask: 0xFFFF
        Action: Direct to queue 0

Filter: 1
        Rule Type: UDP over IPv4
        Src IP addr: 0.0.0.0 mask: 255.255.255.255
        Dest IP addr: 0.0.0.0 mask: 255.255.255.255
        TOS: 0x0 mask: 0xff
        Src port: 0 mask: 0xffff
        Dest port: 5001 mask: 0x0
        Action: Direct to queue 3

Filter: 2
        Rule Type: TCP over IPv6
        Src IP addr: fc00::2 mask: ::
        Dest IP addr: :: mask: ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
        Traffic Class: 0x0 mask: 0xff
        Src port: 0 mask: 0xffff
        Dest port: 5001 mask: 0x0
        Action: Direct to queue 2

Filter: 3
        Rule Type: Raw IPv4
        Src IP addr: 192.168.51.101 mask: 0.0.0.0
        Dest IP addr: 0.0.0.0 mask: 255.255.255.255
        TOS: 0x0 mask: 0xff
        Protocol: 0 mask: 0xff
        L4 bytes: 0x0 mask: 0xffffffff
        Action: Direct to queue 1

Filter: 5
        Rule Type: Raw IPv6
        Src IP addr: fc00::2 mask: ::
        Dest IP addr: :: mask: ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
        Traffic Class: 0x0 mask: 0xff
        Protocol: 0 mask: 0xff
        L4 bytes: 0x0 mask: 0xffffffff
        Action: Drop

---
v2: https://lore.kernel.org/netdev/20250908164046.25051-1-danielj@nvidia.com/
  - Fix sparse warnings
  - Fix memory leak on subsequent failure to allocate
  - Fix some Typos

v3: https://lore.kernel.org/netdev/20250923141920.283862-1-danielj@nvidia.com/
  - Added admin_ops to virtio_device kdoc.

v4:
  - Fixed double free bug inserting flows
  - Fixed incorrect protocol field check parsing ip4 headers.
  - (u8 *) changed to (void *)
  - Added kdoc comments to UAPI changes.
  - No longer split up virtio_net.c
  - Added config op to execute admin commands.
      - virtio_pci assigns vp_modern_admin_cmd_exec to this callback.
  - Moved admin command API to new core file virtio_admin_commands.c

Daniel Jurgens (12):
  virtio_pci: Remove supported_cap size build assert
  virtio: Add config_op for admin commands
  virtio: Expose generic device capability operations
  virtio: Expose object create and destroy API
  virtio_net: Query and set flow filter caps
  virtio_net: Create a FF group for ethtool steering
  virtio_net: Implement layer 2 ethtool flow rules
  virtio_net: Use existing classifier if possible
  virtio_net: Implement IPv4 ethtool flow rules
  virtio_net: Add support for IPv6 ethtool steering
  virtio_net: Add support for TCP and UDP ethtool rules
  virtio_net: Add get ethtool flow rules ops

 drivers/net/virtio_net.c               | 1119 ++++++++++++++++++++++++
 drivers/virtio/Makefile                |    2 +-
 drivers/virtio/virtio_admin_commands.c |  166 ++++
 drivers/virtio/virtio_pci_common.h     |    1 -
 drivers/virtio/virtio_pci_modern.c     |    9 +-
 include/linux/virtio_admin.h           |  121 +++
 include/linux/virtio_config.h          |    6 +
 include/uapi/linux/virtio_net_ff.h     |  156 ++++
 include/uapi/linux/virtio_pci.h        |    7 +-
 9 files changed, 1577 insertions(+), 10 deletions(-)
 create mode 100644 drivers/virtio/virtio_admin_commands.c
 create mode 100644 include/linux/virtio_admin.h
 create mode 100644 include/uapi/linux/virtio_net_ff.h

-- 
2.50.1


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

end of thread, other threads:[~2025-10-14  7:05 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-10-13 15:27 [PATCH net-next v4 00/12] virtio_net: Add ethtool flow rules support Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 01/12] virtio_pci: Remove supported_cap size build assert Daniel Jurgens
2025-10-13 16:38   ` [External] : " ALOK TIWARI
2025-10-13 17:57     ` Dan Jurgens
2025-10-14  5:28   ` kernel test robot
2025-10-14  7:04   ` kernel test robot
2025-10-13 15:27 ` [PATCH net-next v4 02/12] virtio: Add config_op for admin commands Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 03/12] virtio: Expose generic device capability operations Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 04/12] virtio: Expose object create and destroy API Daniel Jurgens
2025-10-13 16:25   ` [External] : " ALOK TIWARI
2025-10-13 15:27 ` [PATCH net-next v4 05/12] virtio_net: Query and set flow filter caps Daniel Jurgens
2025-10-14  6:32   ` kernel test robot
2025-10-13 15:27 ` [PATCH net-next v4 06/12] virtio_net: Create a FF group for ethtool steering Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 07/12] virtio_net: Implement layer 2 ethtool flow rules Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 08/12] virtio_net: Use existing classifier if possible Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 09/12] virtio_net: Implement IPv4 ethtool flow rules Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 10/12] virtio_net: Add support for IPv6 ethtool steering Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 11/12] virtio_net: Add support for TCP and UDP ethtool rules Daniel Jurgens
2025-10-13 15:27 ` [PATCH net-next v4 12/12] virtio_net: Add get ethtool flow rules ops Daniel Jurgens

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).