public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
From: Stefano Brivio <sbrivio@redhat.com>
To: David Gibson <david@gibson.dropbear.id.au>
Cc: passt-dev@passt.top
Subject: Re: [PATCH 04/18] doc: Consolidate -[tu] option descriptions for passt and pasta
Date: Wed, 08 Apr 2026 01:14:41 +0200 (CEST)	[thread overview]
Message-ID: <20260408011440.0e22829b@elisabeth> (raw)
In-Reply-To: <20260407031630.2457081-5-david@gibson.dropbear.id.au>

On Tue,  7 Apr 2026 13:16:16 +1000
David Gibson <david@gibson.dropbear.id.au> wrote:

> The man page currently has two fairly large, near-identical sections

Not entirely identical also because:

> separately describing the -t and -u options for passt and pasta.  This is
> bulky and potentially confusing.  It will make this information more
> tedious to update as we alter what's possible here with the forwarding
> table.  Consolidate both descriptions to a single one in the common
> options, noting the few passt/pasta difference inline.
> 
> There's similar duplication usage(), consolidate that as well.
> 
> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
> ---
>  conf.c  |  54 +++++---------
>  passt.1 | 216 ++++++++++++++++++--------------------------------------
>  2 files changed, 85 insertions(+), 185 deletions(-)
> 
> diff --git a/conf.c b/conf.c
> index f3b36bb6..751e500f 100644
> --- a/conf.c
> +++ b/conf.c
> @@ -1023,18 +1023,12 @@ static void usage(const char *name, FILE *f, int status)
>  		"  --freebind		Bind to any address for forwarding\n"
>  		"  --no-map-gw		Don't map gateway address to host\n"
>  		"  -4, --ipv4-only	Enable IPv4 operation only\n"
> -		"  -6, --ipv6-only	Enable IPv6 operation only\n");
> -
> -	if (strstr(name, "pasta"))
> -		goto pasta_opts;
> -
> -	FPRINTF(f,
> -		"  -1, --one-off	Quit after handling one single client\n"
> +		"  -6, --ipv6-only	Enable IPv6 operation only\n"
>  		"  -t, --tcp-ports SPEC	TCP port forwarding to guest\n"
>  		"    can be specified multiple times\n"
>  		"    SPEC can be:\n"
>  		"      'none': don't forward any ports\n"
> -		"      'all': forward all unbound, non-ephemeral ports\n"
> +		"%s"
>  		"      a comma-separated list, optionally ranged with '-'\n"
>  		"        and optional target ports after ':', with optional\n"
>  		"        address specification suffixed by '/' and optional\n"
> @@ -1050,43 +1044,29 @@ static void usage(const char *name, FILE *f, int status)
>  		"        -t 192.0.2.1/5	Bind port 5 of 192.0.2.1 to guest\n"
>  		"        -t 5-25,~10-20	Forward ports 5 to 9, and 21 to 25\n"
>  		"        -t ~25		Forward all ports except for 25\n"
> -		"    default: none\n"
> +		"    default: %s\n"
>  		"  -u, --udp-ports SPEC	UDP port forwarding to guest\n"

...this is "guest" for passt and "namespace" for pasta. Now, I know
that you use those terms interchangeably and the code does as well, but
this is directly visible to users so I think we shouldn't confuse them
with "guests" for... containers.

To reaffirm the difference between terms used in the code and terms
used in documentation, could we perhaps do something like:

	char *guest = (mode == MODE_PASTA) ? "namespace" : "guest";

? And then use that later? It might be worth doing that for the
"default" strings too.

>  		"    SPEC is as described for TCP above\n"
> -		"    default: none\n");
> +		"    default: %s\n",
> +		strstr(name, "pasta") ?
> +		"      'auto': forward all ports currently bound in namespace\n"
> +		:
> +		"      'all': forward all unbound, non-ephemeral ports\n",
> +		strstr(name, "pasta") ? "auto" : "none",
> +		strstr(name, "pasta") ? "auto" : "none");
> +
> +	if (strstr(name, "pasta"))
> +		goto pasta_opts;
> +
> +	FPRINTF(f,
> +		"  -1, --one-off	Quit after handling one single client\n"
> +		);
>  
>  	passt_exit(status);
>  
>  pasta_opts:
>  
>  	FPRINTF(f,
> -		"  -t, --tcp-ports SPEC	TCP port forwarding to namespace\n"
> -		"    can be specified multiple times\n"
> -		"    SPEC can be:\n"
> -		"      'none': don't forward any ports\n"
> -		"      'auto': forward all ports currently bound in namespace\n"
> -		"      a comma-separated list, optionally ranged with '-'\n"
> -		"        and optional target ports after ':', with optional\n"
> -		"        address specification suffixed by '/' and optional\n"
> -		"        interface prefixed by '%%'. Examples:\n"
> -		"        -t 22	Forward local port 22 to port 22 in netns\n"
> -		"        -t 22:23	Forward local port 22 to port 23\n"
> -		"        -t 22,25	Forward ports 22, 25 to ports 22, 25\n"
> -		"        -t 22-80	Forward ports 22 to 80\n"
> -		"        -t 22-80:32-90	Forward ports 22 to 80 to\n"
> -		"			corresponding port numbers plus 10\n"
> -		"        -t 192.0.2.1/5	Bind port 5 of 192.0.2.1 to namespace\n"
> -		"        -t 5-25,~10-20	Forward ports 5 to 9, and 21 to 25\n"
> -		"        -t ~25		Forward all bound ports except for 25\n"
> -		"    default: auto\n"
> -		"    IPv6 bound ports are also forwarded for IPv4\n"
> -		"  -u, --udp-ports SPEC	UDP port forwarding to namespace\n"
> -		"    SPEC is as described for TCP above\n"
> -		"    default: auto\n"
> -		"    IPv6 bound ports are also forwarded for IPv4\n"
> -		"    unless specified, with '-t auto', UDP ports with numbers\n"
> -		"    corresponding to forwarded TCP port numbers are\n"
> -		"    forwarded too\n"
>  		"  -T, --tcp-ns SPEC	TCP port forwarding to init namespace\n"
>  		"    SPEC is as described above\n"
>  		"    default: auto\n"
> diff --git a/passt.1 b/passt.1
> index 13e8df9d..a9a8a42a 100644
> --- a/passt.1
> +++ b/passt.1
> @@ -425,78 +425,6 @@ Send \fIname\fR as DHCP option 12 (hostname).
>  FQDN to configure the client with.
>  Send \fIname\fR as Client FQDN: DHCP option 81 and DHCPv6 option 39.
>  
> -.SS \fBpasst\fR-only options
> -
> -.TP
> -.BR \-s ", " \-\-socket-path ", " \-\-socket " " \fIpath
> -Path for UNIX domain socket used by \fBqemu\fR(1) or \fBqrap\fR(1) to connect to
> -\fBpasst\fR.
> -Default is to probe a free socket, not accepting connections, starting from
> -\fI/tmp/passt_1.socket\fR to \fI/tmp/passt_64.socket\fR.
> -
> -.TP
> -.BR \-\-vhost-user
> -Enable vhost-user. The vhost-user command socket is provided by \fB--socket\fR.
> -
> -.TP
> -.BR \-\-print-capabilities
> -Print back-end capabilities in JSON format, only meaningful for vhost-user mode.
> -
> -.TP
> -.BR \-\-repair-path " " \fIpath
> -Path for UNIX domain socket used by the \fBpasst-repair\fR(1) helper to connect
> -to \fBpasst\fR in order to set or clear the TCP_REPAIR option on sockets, during
> -migration. \fB--repair-path none\fR disables this interface (if you need to
> -specify a socket path called "none" you can prefix the path by \fI./\fR).
> -
> -Default, for \-\-vhost-user mode only, is to append \fI.repair\fR to the path
> -chosen for the hypervisor UNIX domain socket. No socket is created if not in
> -\-\-vhost-user mode.
> -
> -.TP
> -.BR \-\-migrate-exit " " (DEPRECATED)
> -Exit after a completed migration as source. By default, \fBpasst\fR keeps
> -running and the migrated guest can continue using its connection, or a new guest
> -can connect.
> -
> -Note that this configuration option is \fBdeprecated\fR and will be removed in a
> -future version. It is not expected to be of any use, and it simply reflects a
> -legacy behaviour. If you have any use for this, refer to \fBREPORTING BUGS\fR
> -below.
> -
> -.TP
> -.BR \-\-migrate-no-linger " " (DEPRECATED)
> -Close TCP sockets on the source instance once migration completes.
> -
> -By default, sockets are kept open, and events on data sockets are ignored, so
> -that any further message reaching sockets after the source migrated is silently
> -ignored, to avoid connection resets in case data is received after migration.
> -
> -Note that this configuration option is \fBdeprecated\fR and will be removed in a
> -future version. It is not expected to be of any use, and it simply reflects a
> -legacy behaviour. If you have any use for this, refer to \fBREPORTING BUGS\fR
> -below.
> -
> -.TP
> -.BR \-F ", " \-\-fd " " \fIFD
> -Pass a pre-opened, connected socket to \fBpasst\fR. Usually the socket is opened
> -in the parent process and \fBpasst\fR inherits it when run as a child. This
> -allows the parent process to open sockets using another address family or
> -requiring special privileges.
> -
> -This option implies the behaviour described for \-\-one-off, once this socket
> -is closed.
> -
> -.TP
> -.BR \-1 ", " \-\-one-off
> -Quit after handling a single client connection, that is, once the client closes
> -the socket, or once we get a socket error.
> -
> -\fBNote\fR: this option has no effect after \fBpasst\fR completes a migration as
> -source, because, in that case, exiting would close sockets for active
> -connections, which would in turn cause connection resets if any further data is
> -received. See also the description of \fI\-\-migrate-no-linger\fR.
> -
>  .TP
>  .BR \-t ", " \-\-tcp-ports " " \fIspec
>  Configure TCP port forwarding to guest. \fIspec\fR can be one of:
> @@ -507,11 +435,17 @@ Configure TCP port forwarding to guest. \fIspec\fR can be one of:
>  Don't forward any ports
>  
>  .TP
> -.BR all
> +.BR all (\fBpasst\fR only)

This is rendered as "passtonly". You need \fBpasst\fR " " only. While
this one goes away in 5/18,

>  Forward all unbound, non-ephemeral ports, as permitted by current capabilities.
>  For low (< 1024) ports, see \fBNOTES\fR. No failures are reported for
>  unavailable ports, unless no ports could be forwarded at all.
>  
> +.TP
> +.BR auto (\fBpasta\fR only)

...this one doesn't.

> +Dynamically forward ports bound in the namespace. The list of ports is
> +periodically derived (every second) from listening sockets reported by
> +\fI/proc/net/tcp\fR and \fI/proc/net/tcp6\fR, see \fBproc\fR(5).
> +
>  .TP
>  .BR ports
>  A comma-separated list of ports, optionally ranged with \fI-\fR, and,
> @@ -563,7 +497,7 @@ and 30
>  Forward all ports to the guest, except for the range from 20000 to 20010
>  .RE
>  
> -Default is \fBnone\fR.
> +Default is \fBnone\fR for \fBpasst\fR and \fBauto\fR for \fBpasta\fR.
>  .RE
>  
>  .TP
> @@ -575,101 +509,87 @@ Note: unless overridden, UDP ports with numbers corresponding to forwarded TCP
>  port numbers are forwarded too, without, however, any port translation. IPv6
>  bound ports are also forwarded for IPv4.
>  
> -Default is \fBnone\fR.
> +Default is \fBnone\fR for \fBpasst\fR and \fBauto\fR for \fBpasta\fR.
>  
> -.SS \fBpasta\fR-only options
> +.SS \fBpasst\fR-only options
>  
>  .TP
> -.BR \-I ", " \-\-ns-ifname " " \fIname
> -Name of tap interface to be created in target namespace.
> -By default, the same interface name as the external, routable interface is used.
> -If no such interface exists, the name \fItap0\fR will be used instead.
> +.BR \-s ", " \-\-socket-path ", " \-\-socket " " \fIpath
> +Path for UNIX domain socket used by \fBqemu\fR(1) or \fBqrap\fR(1) to connect to
> +\fBpasst\fR.
> +Default is to probe a free socket, not accepting connections, starting from
> +\fI/tmp/passt_1.socket\fR to \fI/tmp/passt_64.socket\fR.
>  
>  .TP
> -.BR \-t ", " \-\-tcp-ports " " \fIspec
> -Configure TCP port forwarding to namespace. \fIspec\fR can be one of:
> -.RS
> +.BR \-\-vhost-user
> +Enable vhost-user. The vhost-user command socket is provided by \fB--socket\fR.
>  
>  .TP
> -.BR none
> -Don't forward any ports
> +.BR \-\-print-capabilities
> +Print back-end capabilities in JSON format, only meaningful for vhost-user mode.
>  
>  .TP
> -.BR auto
> -Dynamically forward ports bound in the namespace. The list of ports is
> -periodically derived (every second) from listening sockets reported by
> -\fI/proc/net/tcp\fR and \fI/proc/net/tcp6\fR, see \fBproc\fR(5).
> +.BR \-\-repair-path " " \fIpath
> +Path for UNIX domain socket used by the \fBpasst-repair\fR(1) helper to connect
> +to \fBpasst\fR in order to set or clear the TCP_REPAIR option on sockets, during
> +migration. \fB--repair-path none\fR disables this interface (if you need to
> +specify a socket path called "none" you can prefix the path by \fI./\fR).
> +
> +Default, for \-\-vhost-user mode only, is to append \fI.repair\fR to the path
> +chosen for the hypervisor UNIX domain socket. No socket is created if not in
> +\-\-vhost-user mode.
>  
>  .TP
> -.BR ports
> -A comma-separated list of ports, optionally ranged with \fI-\fR, and,
> -optionally, with target ports after \fI:\fR, if they differ. Specific addresses
> -can be bound as well, separated by \fI/\fR, and also, since Linux 5.7, limited
> -to specific interfaces, prefixed by \fI%\fR. Within given ranges, selected ports
> -and ranges can be excluded by an additional specification prefixed by \fI~\fR.
> +.BR \-\-migrate-exit " " (DEPRECATED)
> +Exit after a completed migration as source. By default, \fBpasst\fR keeps
> +running and the migrated guest can continue using its connection, or a new guest
> +can connect.
>  
> -Specifying excluded ranges only implies that all other ports are forwarded. In
> -this case, no failures are reported for unavailable ports, unless no ports could
> -be forwarded at all.
> +Note that this configuration option is \fBdeprecated\fR and will be removed in a
> +future version. It is not expected to be of any use, and it simply reflects a
> +legacy behaviour. If you have any use for this, refer to \fBREPORTING BUGS\fR
> +below.
>  
> -Examples:
> -.RS
> -.TP
> --t 22
> -Forward local port 22 to 22 in the target namespace

...the passt equivalent says "guest". I think we should replace all
these occurrences by "guest or namespace" at this point.

-- 
Stefano


  reply	other threads:[~2026-04-07 23:16 UTC|newest]

Thread overview: 40+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-07  3:16 [PATCH 00/18] Rework forwarding option parsing David Gibson
2026-04-07  3:16 ` [PATCH 01/18] conf: Split parsing of port specifiers from the rest of -[tuTU] parsing David Gibson
2026-04-07  3:16 ` [PATCH 02/18] conf: Simplify handling of default forwarding mode David Gibson
2026-04-07 23:14   ` Stefano Brivio
2026-04-08  1:10     ` David Gibson
2026-04-07  3:16 ` [PATCH 03/18] conf: Move first pass handling of -[TU] next to handling of -[tu] David Gibson
2026-04-07  3:16 ` [PATCH 04/18] doc: Consolidate -[tu] option descriptions for passt and pasta David Gibson
2026-04-07 23:14   ` Stefano Brivio [this message]
2026-04-08  1:23     ` David Gibson
2026-04-07  3:16 ` [PATCH 05/18] conf: Permit -[tTuU] all in pasta mode David Gibson
2026-04-07  3:16 ` [PATCH 06/18] fwd: Better split forwarding rule specification from associated sockets David Gibson
2026-04-07 23:14   ` Stefano Brivio
2026-04-08  1:30     ` David Gibson
2026-04-08 21:39       ` Stefano Brivio
2026-04-09  0:47         ` David Gibson
2026-04-07  3:16 ` [PATCH 07/18] fwd_rule: Move forwarding rule formatting David Gibson
2026-04-07  3:16 ` [PATCH 08/18] conf: Pass protocol explicitly to conf_ports_range_except() David Gibson
2026-04-07  3:16 ` [PATCH 09/18] fwd: Split rule building from rule adding David Gibson
2026-04-07  3:16 ` [PATCH 10/18] fwd_rule: Move rule conflict checking from fwd_rule_add() to caller David Gibson
2026-04-07 23:14   ` Stefano Brivio
2026-04-08  1:37     ` David Gibson
2026-04-08  4:42       ` David Gibson
2026-04-07  3:16 ` [PATCH 11/18] fwd: Improve error handling in fwd_rule_add() David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-09  0:10     ` David Gibson
2026-04-07  3:16 ` [PATCH 12/18] conf: Don't be strict about exclusivity of forwarding mode David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-09  0:12     ` David Gibson
2026-04-07  3:16 ` [PATCH 13/18] conf: Rework stepping through chunks of port specifiers David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-09  0:13     ` David Gibson
2026-04-07  3:16 ` [PATCH 14/18] conf: Rework checking for garbage after a range David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-09  0:15     ` David Gibson
2026-04-07  3:16 ` [PATCH 15/18] conf: Move "all" handling to port specifier David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-07  3:16 ` [PATCH 16/18] conf: Allow user-specified auto-scanned port forwarding ranges David Gibson
2026-04-08 21:40   ` Stefano Brivio
2026-04-07  3:16 ` [PATCH 17/18] conf: Move SO_BINDTODEVICE workaround to conf_ports() David Gibson
2026-04-07  3:16 ` [PATCH 18/18] conf: Don't pass raw commandline argument to conf_ports_spec() David Gibson

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=20260408011440.0e22829b@elisabeth \
    --to=sbrivio@redhat.com \
    --cc=david@gibson.dropbear.id.au \
    --cc=passt-dev@passt.top \
    /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).