public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
58551382be5606d22591e2ee50040a2c14a9ab91 blob 3644 bytes (raw)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
 
/* SPDX-License-Identifier: GPL-2.0-or-later
 * Copyright Red Hat
 * Author: Stefano Brivio <sbrivio@redhat.com>
 * Author: David Gibson <david@gibson.dropbear.id.au>
 *
 * Forwarding rule definitions shared between passt/pasta and pesto
 */

#ifndef FWD_RULE_H
#define FWD_RULE_H

#include <stdint.h>
#include <net/if.h>
#include <netinet/in.h>

#include "ip.h"
#include "inany.h"
#include "bitmap.h"

/* Number of ports for both TCP and UDP */
#define	NUM_PORTS	(1U << 16)
#define PORT_BITMAP_SIZE	DIV_ROUND_UP(NUM_PORTS, 8)

/* Forwarding capability bits */
#define FWD_CAP_IPV4		BIT(0)
#define FWD_CAP_IPV6		BIT(1)
#define FWD_CAP_TCP		BIT(2)
#define FWD_CAP_UDP		BIT(3)
#define FWD_CAP_SCAN		BIT(4)
#define FWD_CAP_IFNAME		BIT(5)

/**
 * struct fwd_rule - Forwarding rule governing a range of ports
 * @addr:	Address to forward from
 * @ifname:	Interface to forward from
 * @first:	First port number to forward
 * @last:	Last port number to forward
 * @to:		Target port for @first, port n goes to @to + (n - @first)
 * @proto:	Protocol to forward
 * @flags:	Flag mask
 * 	FWD_DUAL_STACK_ANY - match any IPv4 or IPv6 address (@addr should be ::)
 *	FWD_WEAK - Don't give an error if binds fail for some forwards
 *	FWD_SCAN - Only forward if the matching port in the target is listening
 */
struct fwd_rule {
	union inany_addr addr;
	char ifname[IFNAMSIZ];
	in_port_t first;
	in_port_t last;
	in_port_t to;
	uint8_t proto;
#define FWD_DUAL_STACK_ANY	BIT(0)
#define FWD_WEAK		BIT(1)
#define FWD_SCAN		BIT(2)
	uint8_t flags;
};

#define FWD_RULE_BITS	8
#define MAX_FWD_RULES	MAX_FROM_BITS(FWD_RULE_BITS)

/* Maximum number of listening sockets (per pif)
 *
 * Rationale: This lets us listen on every port for two addresses and two
 * protocols (which we need for -T auto -U auto without SO_BINDTODEVICE), plus a
 * comfortable number of extras.
 */
#define MAX_LISTEN_SOCKS	(NUM_PORTS * 5)

/**
 * struct fwd_table - Forwarding state (per initiating pif)
 * @caps:	Forwarding capabilities for this initiating pif
 * @count:	Number of forwarding rules
 * @rules:	Array of forwarding rules
 * @rulesocks:	Parallel array of @rules (@count valid entries) of pointers to
 *		@socks entries giving the start of the corresponding rule's
 *		sockets within the larger array
 * @sock_count:	Number of entries used in @socks (for all rules combined)
 * @socks:	Listening sockets for forwarding
 */
struct fwd_table {
	uint32_t caps;
	unsigned count;
	struct fwd_rule rules[MAX_FWD_RULES];
	int *rulesocks[MAX_FWD_RULES];
	unsigned sock_count;
	int socks[MAX_LISTEN_SOCKS];
};

void fwd_probe_ephemeral(void);

#define FWD_RULE_STRLEN					    \
	(IPPROTO_STRLEN - 1				    \
	 + INANY_ADDRSTRLEN - 1				    \
	 + IFNAMSIZ - 1					    \
	 + 4 * (UINT16_STRLEN - 1)			    \
	 + sizeof(" []%:-  =>  - (best effort) (auto-scan)"))

const union inany_addr *fwd_rule_addr(const struct fwd_rule *rule);
const char *fwd_rule_fmt(const struct fwd_rule *rule, char *dst, size_t size);
void fwd_rule_parse(char optname, const char *optarg, struct fwd_table *fwd);

/**
 * fwd_rules_dump() - Dump forwarding rules
 * @fn:		Printing/logging function to call
 * @rules:	Array of rules to dump
 * @count:	Number of rules to dump
 * @prefix:	String to print at the start of each rule
 * @suffix:	String to print at the end of each rule
 */
#define fwd_rules_dump(fn, rules, count, prefix, suffix)		\
	do {								\
		unsigned i_;						\
		for (i_ = 0; i_ < (count); i_++) {			\
			char buf_[FWD_RULE_STRLEN];			\
			fn("%s%s%s", prefix,				\
			   fwd_rule_fmt(&(rules)[i_], buf_, sizeof(buf_)), \
			   suffix);					\
		}							\
	} while (0)

#endif /* FWD_RULE_H */
debug log:

solving 58551382 ...
found 58551382 in https://archives.passt.top/passt-dev/20260417050520.102247-12-david@gibson.dropbear.id.au/
found f0f4efda in https://archives.passt.top/passt-dev/20260417050520.102247-10-david@gibson.dropbear.id.au/ ||
	https://archives.passt.top/passt-dev/20260410010309.736855-24-david@gibson.dropbear.id.au/
found 5c7b67aa in https://archives.passt.top/passt-dev/20260417050520.102247-9-david@gibson.dropbear.id.au/ ||
	https://archives.passt.top/passt-dev/20260410010309.736855-23-david@gibson.dropbear.id.au/
found edba6782 in https://archives.passt.top/passt-dev/20260417050520.102247-7-david@gibson.dropbear.id.au/ ||
	https://archives.passt.top/passt-dev/20260410010309.736855-21-david@gibson.dropbear.id.au/
found 8506a0c4 in https://passt.top/passt
preparing index
index prepared:
100644 8506a0c4eb07167924f97b21981b465100400f88	fwd_rule.h

applying [1/7] https://archives.passt.top/passt-dev/20260417050520.102247-7-david@gibson.dropbear.id.au/
diff --git a/fwd_rule.h b/fwd_rule.h
index 8506a0c4..edba6782 100644

Checking patch fwd_rule.h...
Applied patch fwd_rule.h cleanly.

skipping https://archives.passt.top/passt-dev/20260410010309.736855-21-david@gibson.dropbear.id.au/ for edba6782
index at:
100644 edba6782d52b1186961de2f0f26c046c02e7c5cf	fwd_rule.h

applying [2/7] https://archives.passt.top/passt-dev/20260417050520.102247-9-david@gibson.dropbear.id.au/
diff --git a/fwd_rule.h b/fwd_rule.h
index edba6782..5c7b67aa 100644

Checking patch fwd_rule.h...
Applied patch fwd_rule.h cleanly.

skipping https://archives.passt.top/passt-dev/20260410010309.736855-23-david@gibson.dropbear.id.au/ for 5c7b67aa
index at:
100644 5c7b67aa7e959a82ae7bbbdc482de8a43e17ce78	fwd_rule.h

applying [3/7] https://archives.passt.top/passt-dev/20260417050520.102247-10-david@gibson.dropbear.id.au/
diff --git a/fwd_rule.h b/fwd_rule.h
index 5c7b67aa..f0f4efda 100644

Checking patch fwd_rule.h...
Applied patch fwd_rule.h cleanly.

skipping https://archives.passt.top/passt-dev/20260410010309.736855-24-david@gibson.dropbear.id.au/ for f0f4efda
index at:
100644 f0f4efda1d3d4409ad1d70a890741f08ad9c21fe	fwd_rule.h

applying [4/7] https://archives.passt.top/passt-dev/20260417050520.102247-12-david@gibson.dropbear.id.au/
diff --git a/fwd_rule.h b/fwd_rule.h
index f0f4efda..58551382 100644

Checking patch fwd_rule.h...
Applied patch fwd_rule.h cleanly.

index at:
100644 58551382be5606d22591e2ee50040a2c14a9ab91	fwd_rule.h

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