public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
* [PATCH 00/12] Use connect()ed sockets for both sides of UDP flows
@ 2025-04-04 10:15 David Gibson
  2025-04-04 10:15 ` [PATCH 01/12] udp: Use connect()ed sockets for initiating side David Gibson
                   ` (11 more replies)
  0 siblings, 12 replies; 13+ messages in thread
From: David Gibson @ 2025-04-04 10:15 UTC (permalink / raw)
  To: Stefano Brivio, passt-dev; +Cc: David Gibson

As discussed, I've been working on using connect()ed sockets, rather
than dups of the listening sockets for handling traffic on the
initiating side of UDP flows.  This improves consistency, avoids some
problems (bug 103) and will allow for some useful future improvements.

It has the nice side effect of allowing some more code to be shared
between various paths, resulting in a pretty nice negative diffstat.

David Gibson (12):
  udp: Use connect()ed sockets for initiating side
  udp: Make udp_sock_recv() take max number of frames as a parameter
  udp: Polish udp_vu_sock_info() and remove from vu specific code
  udp: Don't bother to batch datagrams from "listening" socket
  udp: Parameterize number of datagrams handled by
    udp_*_reply_sock_data()
  udp: Split spliced forwarding path from udp_buf_reply_sock_data()
  udp: Merge vhost-user and "buf" listening socket paths
  udp: Move UDP_MAX_FRAMES to udp.c
  udp_flow: Take pif and port as explicit parameters to
    udp_flow_from_sock()
  udp: Rework udp_listen_sock_data() into udp_sock_fwd()
  udp: Fold udp_splice_prepare and udp_splice_send into udp_sock_to_sock
  udp_flow: Don't discard packets that arrive between bind() and
    connect()

 epoll_type.h   |   4 +-
 flow.c         |   2 +-
 passt.c        |   6 +-
 udp.c          | 332 +++++++++++++++++++++++--------------------------
 udp.h          |   4 +-
 udp_flow.c     | 120 ++++++++++--------
 udp_flow.h     |   8 +-
 udp_internal.h |   4 +-
 udp_vu.c       |  93 +-------------
 udp_vu.h       |   2 +-
 util.c         |   2 +-
 11 files changed, 242 insertions(+), 335 deletions(-)

-- 
2.49.0


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

end of thread, other threads:[~2025-04-04 10:16 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-04-04 10:15 [PATCH 00/12] Use connect()ed sockets for both sides of UDP flows David Gibson
2025-04-04 10:15 ` [PATCH 01/12] udp: Use connect()ed sockets for initiating side David Gibson
2025-04-04 10:15 ` [PATCH 02/12] udp: Make udp_sock_recv() take max number of frames as a parameter David Gibson
2025-04-04 10:15 ` [PATCH 03/12] udp: Polish udp_vu_sock_info() and remove from vu specific code David Gibson
2025-04-04 10:15 ` [PATCH 04/12] udp: Don't bother to batch datagrams from "listening" socket David Gibson
2025-04-04 10:15 ` [PATCH 05/12] udp: Parameterize number of datagrams handled by udp_*_reply_sock_data() David Gibson
2025-04-04 10:15 ` [PATCH 06/12] udp: Split spliced forwarding path from udp_buf_reply_sock_data() David Gibson
2025-04-04 10:15 ` [PATCH 07/12] udp: Merge vhost-user and "buf" listening socket paths David Gibson
2025-04-04 10:15 ` [PATCH 08/12] udp: Move UDP_MAX_FRAMES to udp.c David Gibson
2025-04-04 10:15 ` [PATCH 09/12] udp_flow: Take pif and port as explicit parameters to udp_flow_from_sock() David Gibson
2025-04-04 10:15 ` [PATCH 10/12] udp: Rework udp_listen_sock_data() into udp_sock_fwd() David Gibson
2025-04-04 10:15 ` [PATCH 11/12] udp: Fold udp_splice_prepare and udp_splice_send into udp_sock_to_sock David Gibson
2025-04-04 10:15 ` [PATCH 12/12] udp_flow: Don't discard packets that arrive between bind() and connect() David Gibson

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