From: David Gibson <david@gibson.dropbear.id.au>
To: passt-dev@passt.top, Stefano Brivio <sbrivio@redhat.com>
Cc: David Gibson <david@gibson.dropbear.id.au>
Subject: [PATCH v3 00/20] More flow table preliminaries: address handling improvements
Date: Wed, 28 Feb 2024 22:25:00 +1100 [thread overview]
Message-ID: <20240228112520.2078220-1-david@gibson.dropbear.id.au> (raw)
Here's another batch of cleanups and tweaks in preparation for the
flow table. This set focuses on improved helpers for handling
addresses, particularly in the TCP splice path.
Based on my other series adding more iovecs to the tap and pcap code,
however the only conflicts should be trivial Makefile collisions.
Changes since v2:
* Minor stylistic and formatting changes based on review
* Some clarifying changes to the theory of operation notes on flow
lifecycle
* Rebased on top of new series cleaning up socket pool error
handling. This removes a couple of patches from this series.
* Small edits to commit message for improved clarity
Changes since v1:
* Rebased, and reordered in a way I hope is clearer
* Add patch to rename port_fwd.[ch]
* Added doc comments to clarify flow life cycle
* Added uniform logging of flow start / end to match that lifecycle
* union inany_addr typed special address constants
* inany based tests for unspecified and multicast addresses, as well
as loopback
* Dropped patch allowing NULL parameter to inany_from_af(), turned
out not to be that useful
* Dropped sockaddr_any_init function, turned out not to be very
useful in that form
* Added patch enforcing no loopback addresses on tap interface
* Added logic to sanity check TCP endpoint addresses
* Moved socket creation into tcp_splice_connect()
* Moved epoll ref parsing into tcp_listen_handler()
* Allowed IN4_IS_*() helpers to work on void * addresses
David Gibson (20):
inany: Helper to test for various address types
inany: Add inany_ntop() helper
inany: Provide more conveniently typed constants for special addresses
inany: Introduce union sockaddr_inany
util: Allow IN4_IS_* macros to operate on untyped addresses
tcp, udp: Don't precompute port remappings in epoll references
flow: Add helper to determine a flow's protocol
tcp_splice: Simplify clean up logic
tcp_splice: Don't use flow_trace() before setting flow type
flow: Clarify flow entry life cycle, introduce uniform logging
tcp_splice: More specific variable names in new splice path
tcp_splice: Merge tcp_splice_new() into its caller
tcp_splice: Make tcp_splice_connect() create its own sockets
tcp_splice: Improve error reporting on connect path
tcp_splice: Improve logic deciding when to splice
tcp, tcp_splice: Parse listening socket epoll ref in
tcp_listen_handler()
tcp: Validate TCP endpoint addresses
tap: Disallow loopback addresses on tap interface
port_fwd: Fix copypasta error in port_fwd_scan_udp() comments
fwd: Rename port_fwd.[ch] and their contents
Makefile | 12 ++--
conf.c | 8 +--
flow.c | 84 ++++++++++++++++++++++-
flow.h | 9 +++
port_fwd.c => fwd.c | 32 ++++-----
port_fwd.h => fwd.h | 24 +++----
icmp.c | 18 ++---
inany.c | 50 ++++++++++++++
inany.h | 96 ++++++++++++++++++++++----
passt.h | 2 +-
tap.c | 19 ++++++
tcp.c | 119 +++++++++++++++++++++++---------
tcp.h | 6 +-
tcp_splice.c | 162 +++++++++++++++++++++++++-------------------
tcp_splice.h | 7 +-
udp.c | 32 +++++----
udp.h | 10 +--
util.h | 8 +--
18 files changed, 502 insertions(+), 196 deletions(-)
rename port_fwd.c => fwd.c (83%)
rename port_fwd.h => fwd.h (62%)
create mode 100644 inany.c
--
2.43.2
next reply other threads:[~2024-02-28 11:25 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-02-28 11:25 David Gibson [this message]
2024-02-28 11:25 ` [PATCH v3 01/20] inany: Helper to test for various address types David Gibson
2024-02-28 11:25 ` [PATCH v3 02/20] inany: Add inany_ntop() helper David Gibson
2024-02-28 11:25 ` [PATCH v3 03/20] inany: Provide more conveniently typed constants for special addresses David Gibson
2024-02-28 11:25 ` [PATCH v3 04/20] inany: Introduce union sockaddr_inany David Gibson
2024-02-28 11:25 ` [PATCH v3 05/20] util: Allow IN4_IS_* macros to operate on untyped addresses David Gibson
2024-02-28 11:25 ` [PATCH v3 06/20] tcp, udp: Don't precompute port remappings in epoll references David Gibson
2024-02-28 11:25 ` [PATCH v3 07/20] flow: Add helper to determine a flow's protocol David Gibson
2024-02-28 11:25 ` [PATCH v3 08/20] tcp_splice: Simplify clean up logic David Gibson
2024-02-28 11:25 ` [PATCH v3 09/20] tcp_splice: Don't use flow_trace() before setting flow type David Gibson
2024-02-28 11:25 ` [PATCH v3 10/20] flow: Clarify flow entry life cycle, introduce uniform logging David Gibson
2024-02-28 11:25 ` [PATCH v3 11/20] tcp_splice: More specific variable names in new splice path David Gibson
2024-02-28 11:25 ` [PATCH v3 12/20] tcp_splice: Merge tcp_splice_new() into its caller David Gibson
2024-02-28 11:25 ` [PATCH v3 13/20] tcp_splice: Make tcp_splice_connect() create its own sockets David Gibson
2024-02-28 11:25 ` [PATCH v3 14/20] tcp_splice: Improve error reporting on connect path David Gibson
2024-02-28 11:25 ` [PATCH v3 15/20] tcp_splice: Improve logic deciding when to splice David Gibson
2024-02-28 11:25 ` [PATCH v3 16/20] tcp, tcp_splice: Parse listening socket epoll ref in tcp_listen_handler() David Gibson
2024-02-28 11:25 ` [PATCH v3 17/20] tcp: Validate TCP endpoint addresses David Gibson
2024-02-28 11:25 ` [PATCH v3 18/20] tap: Disallow loopback addresses on tap interface David Gibson
2024-02-28 11:25 ` [PATCH v3 19/20] port_fwd: Fix copypasta error in port_fwd_scan_udp() comments David Gibson
2024-02-28 11:25 ` [PATCH v3 20/20] fwd: Rename port_fwd.[ch] and their contents David Gibson
2024-02-29 10:53 ` [PATCH v3 00/20] More flow table preliminaries: address handling improvements Stefano Brivio
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240228112520.2078220-1-david@gibson.dropbear.id.au \
--to=david@gibson.dropbear.id.au \
--cc=passt-dev@passt.top \
--cc=sbrivio@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://passt.top/passt
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 IMAP folder(s).