public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
84c463e2a5ea28ca27bd6ba8de9bda5c14657dda blob 3494 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
 
/* 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>
 */

#ifndef FWD_H
#define FWD_H

union inany_addr;
struct flowside;

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

void fwd_probe_ephemeral(void);
bool fwd_port_is_ephemeral(in_port_t port);

/**
 * struct fwd_entry - One range of ports to forward
 * @addr:	Address to forward from
 * @ifname:	Interface to forward from
 * @first:	First port number to forward
 * @last:	Last port number to forward
 * @to:		Port number to forward port @first to.
 * @socks:	Array of listening sockets for this entry
 * @flags:	Flag mask
 * 	FWD_DUAL_STACK - forward both IPv4 and IPv6 (requires @addr be ::)
 *	FWD_WEAK - Don't give an error if binds fail for some forwards
 *	FWD_SCAN - Only forward if we scan a listener on the target
 *
 * FIXME: @addr and @ifname currently ignored for outbound tables
 */
struct fwd_entry {
	union inany_addr addr;
	char ifname[IFNAMSIZ];
	in_port_t first, last, to;
	int *socks;
#define FWD_DUAL_STACK		BIT(0)
#define FWD_WEAK		BIT(1)
#define FWD_SCAN		BIT(2)
	uint8_t flags;
};

#define MAX_FWDS	128

enum fwd_ports_mode {
	FWD_UNSET = 0,
	FWD_SPEC = 1,
	FWD_NONE,
	FWD_AUTO,
	FWD_ALL,
};

#define PORT_BITMAP_SIZE	DIV_ROUND_UP(NUM_PORTS, 8)

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

/**
 * fwd_ports() - Describes port forwarding for one protocol and direction
 * @mode:	Overall forwarding mode (all, none, auto, specific ports)
 * @scan4:	/proc/net fd to scan for IPv4 ports when in AUTO mode
 * @scan6:	/proc/net fd to scan for IPv6 ports when in AUTO mode
 * @map:	Bitmap describing which ports are forwarded
 * @delta:	Offset between the original destination and mapped port number
 */
struct fwd_ports {
	enum fwd_ports_mode mode;
	int scan4;
	int scan6;
	unsigned count;
	struct fwd_entry tab[MAX_FWDS];
	uint8_t map[PORT_BITMAP_SIZE];
	in_port_t delta[NUM_PORTS];
	unsigned listen_sock_count;
	int listen_socks[MAX_LISTEN_SOCKS];
};

#define FWD_PORT_SCAN_INTERVAL		1000	/* ms */

void fwd_table_add(struct fwd_ports *fwd, uint8_t flags,
		   const union inany_addr *addr, const char *ifname,
		   in_port_t first, in_port_t last, in_port_t to);
void fwd_table_print(const struct fwd_ports *fwd);

void fwd_scan_ports_init(struct ctx *c);
void fwd_scan_ports_timer(struct ctx * c, const struct timespec *now);

bool nat_inbound(const struct ctx *c, const union inany_addr *addr,
		 union inany_addr *translated);
uint8_t fwd_nat_from_tap(const struct ctx *c, uint8_t proto,
			 const struct flowside *ini, struct flowside *tgt);
uint8_t fwd_nat_from_splice(const struct ctx *c, uint8_t proto,
			    const struct flowside *ini, struct flowside *tgt);
uint8_t fwd_nat_from_host(const struct ctx *c, uint8_t proto,
			  const struct flowside *ini, struct flowside *tgt);
void fwd_neigh_table_update(const struct ctx *c, const union inany_addr *addr,
			    const uint8_t *mac, bool permanent);
void fwd_neigh_table_free(const struct ctx *c,
			  const union inany_addr *addr);
void fwd_neigh_mac_get(const struct ctx *c, const union inany_addr *addr,
		       uint8_t *mac);
void fwd_neigh_table_init(const struct ctx *c);

#endif /* FWD_H */
debug log:

solving 84c463e2 ...
found 84c463e2 in https://archives.passt.top/passt-dev/20251219141904.1758072-8-david@gibson.dropbear.id.au/
found eef507c6 in https://archives.passt.top/passt-dev/20251219141904.1758072-6-david@gibson.dropbear.id.au/
found 21f00cf8 in https://archives.passt.top/passt-dev/20251219141904.1758072-4-david@gibson.dropbear.id.au/
found 77925822 in https://passt.top/passt
preparing index
index prepared:
100644 779258221a9a4f8cf59514a45759e9dc4ba97929	fwd.h

applying [1/3] https://archives.passt.top/passt-dev/20251219141904.1758072-4-david@gibson.dropbear.id.au/
diff --git a/fwd.h b/fwd.h
index 77925822..21f00cf8 100644


applying [2/3] https://archives.passt.top/passt-dev/20251219141904.1758072-6-david@gibson.dropbear.id.au/
diff --git a/fwd.h b/fwd.h
index 21f00cf8..eef507c6 100644


applying [3/3] https://archives.passt.top/passt-dev/20251219141904.1758072-8-david@gibson.dropbear.id.au/
diff --git a/fwd.h b/fwd.h
index eef507c6..84c463e2 100644

Checking patch fwd.h...
Applied patch fwd.h cleanly.
Checking patch fwd.h...
Applied patch fwd.h cleanly.
Checking patch fwd.h...
Applied patch fwd.h cleanly.

index at:
100644 84c463e2a5ea28ca27bd6ba8de9bda5c14657dda	fwd.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).