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 v3 20/25] fwd_rule: Move forwarding rule text formatting to common code
Date: Wed, 25 Mar 2026 01:56:34 +0100 (CET)	[thread overview]
Message-ID: <20260325015633.655d7386@elisabeth> (raw)
In-Reply-To: <20260323073732.3158468-21-david@gibson.dropbear.id.au>

On Mon, 23 Mar 2026 18:37:27 +1100
David Gibson <david@gibson.dropbear.id.au> wrote:

> Move the logic for formatting forwarding rules into strings from
> fwd_rules_print() into fwd_rule.c where it can be shared with pesto.
> We also make the function explicitly construct a string, rather than
> directly printing with info(), for greater flexibility.
> 
> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
> ---
>  Makefile   | 11 ++++----
>  fwd.c      | 40 +++---------------------------
>  fwd_rule.c | 73 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  fwd_rule.h | 11 ++++++++
>  4 files changed, 94 insertions(+), 41 deletions(-)
>  create mode 100644 fwd_rule.c
> 
> diff --git a/Makefile b/Makefile
> index bc325482..44c396e7 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -38,13 +38,14 @@ FLAGS += -DVERSION=\"$(VERSION)\"
>  FLAGS += -DDUAL_STACK_SOCKETS=$(DUAL_STACK_SOCKETS)
>  
>  PASST_SRCS = arch.c arp.c checksum.c conf.c dhcp.c dhcpv6.c epoll_ctl.c \
> -	flow.c fwd.c icmp.c igmp.c inany.c iov.c ip.c isolation.c lineread.c \
> -	log.c mld.c ndp.c netlink.c migrate.c packet.c passt.c pasta.c pcap.c \
> -	pif.c repair.c serialise.c tap.c tcp.c tcp_buf.c tcp_splice.c tcp_vu.c \
> -	udp.c udp_flow.c udp_vu.c util.c vhost_user.c virtio.c vu_common.c
> +	flow.c fwd.c fwd_rule.c icmp.c igmp.c inany.c iov.c ip.c isolation.c \
> +	lineread.c log.c mld.c ndp.c netlink.c migrate.c packet.c passt.c \
> +	pasta.c pcap.c pif.c repair.c serialise.c tap.c tcp.c tcp_buf.c \
> +	tcp_splice.c tcp_vu.c udp.c udp_flow.c udp_vu.c util.c vhost_user.c \
> +	virtio.c vu_common.c
>  QRAP_SRCS = qrap.c
>  PASST_REPAIR_SRCS = passt-repair.c
> -PESTO_SRCS = pesto.c inany.c ip.c serialise.c
> +PESTO_SRCS = pesto.c fwd_rule.c inany.c ip.c serialise.c
>  SRCS = $(PASST_SRCS) $(QRAP_SRCS) $(PASST_REPAIR_SRCS) $(PESTO_SRCS)
>  
>  MANPAGES = passt.1 pasta.1 pesto.1 qrap.1 passt-repair.1
> diff --git a/fwd.c b/fwd.c
> index a32d0a20..20409c62 100644
> --- a/fwd.c
> +++ b/fwd.c
> @@ -304,20 +304,6 @@ parse_err:
>  	warn("Unable to parse %s", PORT_RANGE_SYSCTL);
>  }
>  
> -/**
> - * fwd_rule_addr() - Return match address for a rule
> - * @rule:	Forwarding rule
> - *
> - * Return: matching address for rule, NULL if it matches all addresses
> - */
> -static const union inany_addr *fwd_rule_addr(const struct fwd_rule *rule)
> -{
> -	if (rule->flags & FWD_DUAL_STACK_ANY)
> -		return NULL;
> -
> -	return &rule->addr;
> -}
> -
>  /**
>   * fwd_port_map_ephemeral() - Mark ephemeral ports in a bitmap
>   * @map:	Bitmap to update
> @@ -497,28 +483,10 @@ void fwd_rules_print(const struct fwd_table *fwd)
>  	unsigned i;
>  
>  	for (i = 0; i < fwd->count; i++) {
> -		const struct fwd_rule *rule = &fwd->rules[i].rule;
> -		const char *percent = *rule->ifname ? "%" : "";
> -		const char *weak = "", *scan = "";
> -		char addr[INANY_ADDRSTRLEN];
> -
> -		inany_ntop(fwd_rule_addr(rule), addr, sizeof(addr));
> -		if (rule->flags & FWD_WEAK)
> -			weak = " (best effort)";
> -		if (rule->flags & FWD_SCAN)
> -			scan = " (auto-scan)";
> -
> -		if (rule->first == rule->last) {
> -			info("    %s [%s]%s%s:%hu  =>  %hu %s%s",
> -			     ipproto_name(rule->proto), addr, percent,
> -			     rule->ifname, rule->first, rule->to, weak, scan);
> -		} else {
> -			info("    %s [%s]%s%s:%hu-%hu  =>  %hu-%hu %s%s",
> -			     ipproto_name(rule->proto), addr, percent,
> -			     rule->ifname, rule->first, rule->last,
> -			     rule->to, rule->last - rule->first + rule->to,
> -			     weak, scan);
> -		}
> +		char rulestr[FWD_RULE_STRLEN];
> +
> +		info("    %s", fwd_rule_ntop(&fwd->rules[i].rule,
> +					     rulestr, sizeof(rulestr)));
>  	}
>  }
>  
> diff --git a/fwd_rule.c b/fwd_rule.c
> new file mode 100644
> index 00000000..dfbdf683
> --- /dev/null
> +++ b/fwd_rule.c
> @@ -0,0 +1,73 @@
> +// SPDX-License-Identifier: GPL-2.0-or-later
> +
> +/* PASST - Plug A Simple Socket Transport
> + *  for qemu/UNIX domain socket mode
> + *
> + * PASTA - Pack A Subtle Tap Abstraction
> + *  for network namespace/tap device mode
> + *
> + * PESTO - Programmable Extensible Socket Translation Orchestrator
> + *  front-end for passt(1) and pasta(1) forwarding configuration
> + *
> + * fwd_rule.c - Helpers for working with forwarding rule specifications
> + *
> + * Copyright Red Hat
> + * Author: David Gibson <david@gibson.dropbear.id.au>
> + */
> +
> +#include <stdio.h>
> +
> +#include "fwd_rule.h"
> +
> +/**
> + * fwd_rule_addr() - Return match address for a rule
> + * @rule:	Forwarding rule
> + *
> + * Return: matching address for rule, NULL if it matches all addresses
> + */
> +const union inany_addr *fwd_rule_addr(const struct fwd_rule *rule)
> +{
> +	if (rule->flags & FWD_DUAL_STACK_ANY)
> +		return NULL;
> +
> +	return &rule->addr;
> +}
> +
> +/**
> + * fwd_rule_ntop() - Format forwarding rule as a string
> + * @rule:	Rule to format
> + * @dst:	Buffer to store output (should have FWD_RULE_STRLEN bytes)
> + * @size:	Size of @dst
> + */
> +const char *fwd_rule_ntop(const struct fwd_rule *rule, char *dst, size_t size)
> +{
> +	const char *percent = *rule->ifname ? "%" : "";
> +	const char *weak = "", *scan = "";
> +	char addr[INANY_ADDRSTRLEN];
> +	int len;
> +
> +	inany_ntop(fwd_rule_addr(rule), addr, sizeof(addr));
> +	if (rule->flags & FWD_WEAK)
> +		weak = " (best effort)";
> +	if (rule->flags & FWD_SCAN)
> +		scan = " (auto-scan)";
> +
> +	if (rule->first == rule->last) {
> +		len = snprintf(dst, size,
> +			       "%s [%s]%s%s:%hu  =>  %hu %s%s",
> +			       ipproto_name(rule->proto), addr, percent,
> +			       rule->ifname, rule->first, rule->to, weak, scan);
> +	} else {
> +		in_port_t tolast = rule->last - rule->first + rule->to;
> +		len = snprintf(dst, size,
> +			       "%s [%s]%s%s:%hu-%hu  =>  %hu-%hu %s%s",
> +			       ipproto_name(rule->proto), addr, percent,
> +			       rule->ifname, rule->first, rule->last,
> +			       rule->to, tolast, weak, scan);
> +	}
> +
> +	if (len < 0 || (size_t)len >= size)
> +		return NULL;
> +
> +	return dst;
> +}
> diff --git a/fwd_rule.h b/fwd_rule.h
> index 84ec5cbe..59db0e95 100644
> --- a/fwd_rule.h
> +++ b/fwd_rule.h
> @@ -42,4 +42,15 @@ struct fwd_rule {
>  	uint8_t flags;
>  };
>  
> +const union inany_addr *fwd_rule_addr(const struct fwd_rule *rule);
> +
> +#define FWD_RULE_STRLEN					    \
> +	(IPPROTO_STRLEN - 1				    \
> +	 + INANY_ADDRSTRLEN - 1				    \
> +	 + IFNAMSIZ - 1					    \
> +	 + sizeof(" (best effort)") - 1			    \
> +	 + sizeof(" (auto-scan)") - 1			    \
> +	 + 15)

I'm not quite sure about the reason for the 15 here, is there some
constant we can use perhaps?

> +const char *fwd_rule_ntop(const struct fwd_rule *rule, char *dst, size_t size);
> +
>  #endif /* FWD_RULE_H */

-- 
Stefano


  reply	other threads:[~2026-03-25  0:56 UTC|newest]

Thread overview: 49+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-03-23  7:37 [PATCH v3 00/25] RFC: Read-only dynamic update implementation David Gibson
2026-03-23  7:37 ` [PATCH v3 01/25] conf: runas can be const David Gibson
2026-03-23  7:37 ` [PATCH v3 02/25] vhost_user: Fix assorted minor cppcheck warnings David Gibson
2026-03-23  7:37 ` [PATCH v3 03/25] serialise: Split functions user for serialisation from util.c David Gibson
2026-03-25  0:54   ` Stefano Brivio
2026-03-25  1:50     ` David Gibson
2026-03-23  7:37 ` [PATCH v3 04/25] serialise: Add helpers for serialising unsigned integers David Gibson
2026-03-23  7:37 ` [PATCH v3 05/25] fwd: Move selecting correct scan bitmap into fwd_sync_one() David Gibson
2026-03-23  7:37 ` [PATCH v3 06/25] fwd: Look up rule index in fwd_sync_one() David Gibson
2026-03-23  7:37 ` [PATCH v3 07/25] fwd: Store forwarding tables indexed by (origin) pif David Gibson
2026-03-25  0:54   ` Stefano Brivio
2026-03-25  4:04     ` David Gibson
2026-03-23  7:37 ` [PATCH v3 08/25] fwd: Allow FWD_DUAL_STACK_ANY flag to be passed directly to fwd_rule_add() David Gibson
2026-03-25  0:54   ` Stefano Brivio
2026-03-25  4:07     ` David Gibson
2026-03-23  7:37 ` [PATCH v3 09/25] fwd, conf: Expose ephemeral ports as bitmap rather than function David Gibson
2026-03-23  7:37 ` [PATCH v3 10/25] conf: Don't bother complaining about overlapping excluded ranges David Gibson
2026-03-23  7:37 ` [PATCH v3 11/25] conf: Move check for mapping port 0 to caller David Gibson
2026-03-23  7:37 ` [PATCH v3 12/25] conf: Move check for disabled interfaces earlier David Gibson
2026-03-23  7:37 ` [PATCH v3 13/25] pesto: Introduce stub configuration interface and tool David Gibson
2026-03-25  0:54   ` Stefano Brivio
2026-03-23  7:37 ` [PATCH v3 14/25] pesto: Add command line option parsing and debug messages David Gibson
2026-03-25  0:55   ` Stefano Brivio
2026-03-25  4:27     ` David Gibson
2026-03-23  7:37 ` [PATCH v3 15/25] pesto: Expose list of pifs to pesto David Gibson
2026-03-25  0:56   ` Stefano Brivio
2026-03-25  4:34     ` David Gibson
2026-03-25  8:18       ` Stefano Brivio
2026-03-25  8:31         ` David Gibson
2026-03-23  7:37 ` [PATCH v3 16/25] ip: Prepare ip.[ch] for sharing with pesto tool David Gibson
2026-03-23  7:37 ` [PATCH v3 17/25] inany: Prepare inany.[ch] " David Gibson
2026-03-23  7:37 ` [PATCH v3 18/25] fwd: Split forwading rule specification from its implementation state David Gibson
2026-03-23  7:37 ` [PATCH v3 19/25] ip: Define a bound for the string returned by ipproto_name() David Gibson
2026-03-23  7:37 ` [PATCH v3 20/25] fwd_rule: Move forwarding rule text formatting to common code David Gibson
2026-03-25  0:56   ` Stefano Brivio [this message]
2026-03-25  4:42     ` David Gibson
2026-03-25  8:18       ` Stefano Brivio
2026-03-25 23:54         ` David Gibson
2026-03-23  7:37 ` [PATCH v3 21/25] pesto: Read current ruleset from passt/pasta and display it David Gibson
2026-03-25  0:56   ` Stefano Brivio
2026-03-25  4:43     ` David Gibson
2026-03-23  7:37 ` [PATCH v3 22/25] conf: Move port parsing functions to own file, ports.c David Gibson
2026-03-23  7:37 ` [PATCH v3 23/25] conf, fwd, ports, util: Move things around for pesto David Gibson
2026-03-23  7:37 ` [PATCH v3 24/25] pesto, conf: Parse, send and receive new rules David Gibson
2026-03-23  7:37 ` [PATCH v3 25/25] conf, fwd: Allow switching to new rules received from pesto David Gibson
2026-03-23  8:38 ` [PATCH v3 00/25] RFC: Read-only dynamic update implementation David Gibson
2026-03-25  0:56 ` Stefano Brivio
2026-03-25  1:00   ` Stefano Brivio
2026-03-25  4:44     ` 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=20260325015633.655d7386@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).