From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stefano Brivio To: passt-dev@passt.top Subject: [PATCH] conf, tap: Add option to quit once the client closes the connection Date: Fri, 07 Oct 2022 09:16:41 +0200 Message-ID: <20221007071641.1969102-1-sbrivio@redhat.com> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============5099487862178682085==" --===============5099487862178682085== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable This is practical to avoid explicit lifecycle management in users, e.g. libvirtd, and is trivial to implement. Signed-off-by: Stefano Brivio --- conf.c | 17 ++++++++++++++++- passt.1 | 5 +++++ passt.h | 1 + tap.c | 5 +++++ 4 files changed, 27 insertions(+), 1 deletion(-) diff --git a/conf.c b/conf.c index 4ec3153..53a8dcf 100644 --- a/conf.c +++ b/conf.c @@ -712,6 +712,7 @@ static void usage(const char *name) if (strstr(name, "pasta")) goto pasta_opts; =20 + info( " -1, --one-off Quit after handling one single client"); info( " -t, --tcp-ports SPEC TCP port forwarding to guest"); info( " can be specified multiple times"); info( " SPEC can be:"); @@ -1024,6 +1025,7 @@ void conf(struct ctx *c, int argc, char **argv) {"no-map-gw", no_argument, &c->no_map_gw, 1 }, {"ipv4-only", no_argument, NULL, '4' }, {"ipv6-only", no_argument, NULL, '6' }, + {"one-off", no_argument, NULL, '1' }, {"tcp-ports", required_argument, NULL, 't' }, {"udp-ports", required_argument, NULL, 'u' }, {"tcp-ns", required_argument, NULL, 'T' }, @@ -1062,7 +1064,7 @@ void conf(struct ctx *c, int argc, char **argv) c->no_dhcp_dns =3D c->no_dhcp_dns_search =3D 1; optstring =3D "vdqfel:hI:p:P:m:a:n:M:g:i:D:S:46t:u:T:U:"; } else { - optstring =3D "vdqfel:hs:p:P:m:a:n:M:g:i:D:S:46t:u:"; + optstring =3D "vdqfel:hs:p:P:m:a:n:M:g:i:D:S:461t:u:"; } =20 c->tcp.fwd_in.mode =3D c->tcp.fwd_out.mode =3D 0; @@ -1488,6 +1490,19 @@ void conf(struct ctx *c, int argc, char **argv) case '6': v6_only =3D true; break; + case '1': + if (c->mode !=3D MODE_PASST) { + err("--one-off is for passt mode only"); + usage(argv[0]); + } + + if (c->one_off) { + err("Redundant --one-off option"); + usage(argv[0]); + } + + c->one_off =3D true; + break; case 't': case 'u': case 'T': diff --git a/passt.1 b/passt.1 index c63a439..41f8836 100644 --- a/passt.1 +++ b/passt.1 @@ -302,6 +302,11 @@ Path for UNIX domain socket used by \fBqemu\fR(1) or \fB= qrap\fR(1) to connect to 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. =20 +.TP +.BR \-1 ", " \-\-one-off +Quit after handling a single client connection, that is, once the client clo= ses +the socket, or once we get a socket error. + .TP .BR \-t ", " \-\-tcp-ports " " \fIspec Configure TCP port forwarding to guest. \fIspec\fR can be one of: diff --git a/passt.h b/passt.h index de79e7b..67281db 100644 --- a/passt.h +++ b/passt.h @@ -196,6 +196,7 @@ struct ctx { char sock_path[UNIX_PATH_MAX]; char pcap[PATH_MAX]; char pid_file[PATH_MAX]; + int one_off; =20 int pasta_netns_fd; =20 diff --git a/tap.c b/tap.c index bdcc161..78de42c 100644 --- a/tap.c +++ b/tap.c @@ -1011,5 +1011,10 @@ void tap_handler(struct ctx *c, int fd, uint32_t event= s, =20 return; reinit: + if (c->one_off) { + info("Client closed connection, exiting"); + exit(EXIT_SUCCESS); + } + tap_sock_init(c); } --=20 2.35.1 --===============5099487862178682085==--